guqing
毕生所求无它,爱与自由而已
MySQL 如何使用 explain 执行计划
explain执行计划包含的信息 其中最重要的字段为:id、type、key、rows、Extra 字段详解 id select查询的序列号,包含一组数字,表示查询中执行select子句或操作表的顺序 三种情况: 1、id相同:执行顺序由上至下 2、id不同:如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行 3、id相同又不同(两种情况同时存在):id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id值越大,优先级越高,越先执行 select_type 查询的类型,主要是用于区分普通查询、联合查询、子查询等复杂的查询 1、SIMPLE:简单的select查询,查询中不包含子查询或者union 2、PRIMARY:查询中包含任何复杂的子部分,最外层查询则被标记为primary 3、SUBQUERY:在select 或 where列表中包含了子查询 4、DERIVED:在from列表中包含的子查询被标记为derived(衍生),mysql或递归执行这些子查询,把结果放在零时表里 5、UNION:若第二个select出现在union之后,则被标记为union;若union包含在from子句的子查询中,外层select将被标记为derived 6、UNION RESULT:从union表获取结果的select type 访问类型,sql查询优化中一个很重要的指标,结果值从好到坏依次是: system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL 一般来说,好的sql查询至少达到range级别,最好能达到ref 1、system:表只有一行记录(等于系统表),这是const类型的特例,平时不会出现,可以忽略不计 2、const:表示通过索引一次就找到了,const用于比较primary key 或者 unique索引。
你会使用 mysql索引吗
经常用在范围内搜索的列上创建索引,因为索引已经排序了,其指定的范围是连续的 索引优缺点 优点 索引由数据库中一列或多列组合而成,其作用是提高对表中数据的查询速度 索引的优点是可以提高检索数据的速度 缺点 索引的缺点是创建和维护索引需要耗费时间 索引可以提高查询速度,会减慢写入速度 索引并不是越多越好,索引固然可以提高相应的 select 的效率,但同时也降低了 insert 及 update 的效率,因为 insert 或 update 时有可能会重建索引,所以怎样建索引需要慎重考虑,视具体情况而定。
Java 8 新特性
冗余的Lambda场景 来看一个简单的函数式接口以应用Lambda表达式: Lambda表达式的目的,打印参数传递的字符串把参数str,传递给了System.out对象,调用out对象中的方法println对字符串进行了输出 注意: System.out对象是已经存在的 println方法也是已经存在的 所以我们可以使用方法引用来优化Lambda表达式可以使用System.out方法直接引用(调用)printin方法 请注意其中的双冒号::写法,这被称为“方法引用”,而双冒号是一种新的语法。
多线程基础篇
注:一般推荐采用实现接口的方式来创建多线程 线程的生命周期 线程安全问题 产生原因: 多个线程在操作共享的数据 操作共享数据的线程代码有多条 当一个线程在操作共享数据的多条代码过程中,其他线程参与了运算,就会导致线程安全问题 解决线程安全问题的思路: 就是将多条操作共享数据的代码封装起来,当线程 在执行这些代码的时候,必须要当前线程把这些代码都执行完毕后,其他线程才可以参与运算 在Java中,用同步代码块就可以解决这个问题 同步代码块的格式: 同步的好处: 解决了线程安全问题 弊端: 相对降低了效率,因为同步外的线程都会判断同步锁,消耗资源 同步的前提: 同步中必须有多个线程并使用同一个锁 案例分析: 分析上面代码是否存在线程安全问题,从产生线程安全问题的原因分析: 首先需要判断是否存在共享数据 操作共享数据的线程代码是否有多条 对于上面的代码Bank被线程任务执行 所以会产生线程安全问题,解决办法:加锁 同步代码块 同步函数(同步函数用的锁时this对象) 同步函数和同步代码块的区别: 同步函数的锁是固定的this,也就是当前的对象 同步代码块使用的锁是任意对象 建议使用同步代码块 静态同步函数的锁: 还是以上的实例,这样也是可以的,这说明静态同步函数的锁绝对不是this,因为静态函数根本就没有this,那锁是什么呢?
Redis 详解指南
9.Redis的复制(Master和Slave) 备机与主机使用slaveof ip 端口建立连接后备机会将主机的所有数据备份到备机 主从复制,读写分离:只有主机可以写,从机只能读,如果从机使用写命令会报错 如果主机挂了,备机依然是备机,不会夺位,除非手动操作 如果主机修复了,备机依然会继续备份无需任何操作 如果某台备机挂了,修复后启动redis会变成master,需要与主机重新连接才可以继续备份slaveof ip 端口 上一个Slave可以是下一个slave的Master,Slave同样可以接收其他slaves的连接和同步请求,那么该slave作为了链条中下一个的master,可以有效减轻master的写压力 中途变更转向:会清除之前的数据,重新建立,拷贝最新的 SLAVEOF no one可以使当前数据库停止与其他数据库的同步,转成主数据库 复制的原理 Slave启动成功连接到master后会发送一个sync命令 Master接到命令启动后台的存盘进程,同时收集所有接收到的用于修改数据集命令, 在后台进程执行完毕之后,master将传送整个数据文件到slave,以完成一次完全同步 全量复制:而slave服务在接收到数据库文件数据后,将其存盘并加载到内存中。
Vue 学习之九Vue计算属性与webpack
文章已迁移到新地址,访问 https://guqing.xyz/archives/how-to-use-vue2
Vue 学习笔记之八获取组件对象和使用 vue-router
8 获取dom对象和组件的对象 ref 被用来给元素或子组件注册引用信息。 如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子组件上,引用就指向组件实例: 关于 ref 注册时间的重要说明:因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在! 包含的功能有: 嵌套的路由/视图表 模块化的、基于组件的路由配置 路由参数、查询、通配符 基于 Vue.js 过渡系统的视图过渡效果 细粒度的导航控制 带有自动激活的 CSS class 的链接 HTML5 历史模式或 hash 模式,在 IE9 中自动降级 自定义的滚动条行为 9.1 路由写法和传参 引入vuejs和vue-router 9.2 嵌套路由
Vue 学习笔记之六进入/离开 & 列表过渡
包括以下工具: 在 CSS 过渡和动画中自动应用 class 可以配合使用第三方 CSS 动画库,如 Animate.css 在过渡钩子函数中使用 JavaScript 直接操作 DOM 可以配合使用第三方 JavaScript 动画库,如 Velocity.js 6.2 transition过渡 Vue 提供了 transition 的封装组件,在下列情形中,可以给任何元素和组件添加进入/离开过渡 条件渲染 (使用 v-if) 条件展示 (使用 v-show) 动态组件 组件根节点 当插入或删除包含在 transition 组件中的元素时,Vue 将会做以下处理: 自动嗅探目标元素是否应用了 CSS 过渡或动画,如果是,在恰当的时机添加/删除 CSS 类名。
Vue 学习笔记之七组件的使用
7.4 组件的动态切换 首先注册两个组件,login和regist 组件的切换使用component标签的is属性 只要控制is的值即可控制组件的显示,如上通过点击事件改变cname的值来切换组件 7.5 父组件与子组件传值 父组件向子组件传值 定义组件 在组件中有一个props属性在其中定义变量负责接收父组件传递过来的值 然后在组件模板中使用插值表达式接收{{name}} 父组件如何向子组件传递值?
Vue 学习笔记之四Vue的Ajax请求
Vue的Ajax请求 4.1 Vue-resource插件介绍 下载地址: $.ajax能做的事情,vue-resource插件一样也能做到,而且vue-resource的API更为简洁。 另外,vue-resource还提供了非常有用的inteceptor功能,使用inteceptor可以在请求前和请求后附加一些行为,比如使用inteceptor在ajax请求时显示loading界面。 支持拦截器 拦截器是全局的,拦截器可以在请求发送前和发送请求后做一些处理。