联合索引和最左前缀
-
联合索引可以看成排好序的数组。
排序规则是:先按照第一个列进行排序,第二列再按照第一列排好序的基础上再进行排序,依次类推
需要按照最左前缀原则才能生效 -
最左前缀原则:按照最左边的列开始的顺序并且不能跳过其中的列。
如:(name, age,position)是一个联合索引,支持(name)(name, age)(name, age,position)查找,不支持( age,position)查找
有的时候你没有使用最左前缀原则写sql,优化器可能会帮你进行优化成最左前缀原则,如(age,name )也可能使用联合索引。但是写sql 的时候还是要严格按照最左前缀原则而不是依靠优化器
三次握手
- 第一次
第一次握手:建立连接时,客户端发送syn包(seq=j)到服务器,并进入SYN_SENT状态,等待服务器确认;SYN:同步序列编号(Synchronize Sequence Numbers)。 - 第二次
第二次握手:服务器收到syn包,必须确认客户端的SYN(ack=j+1),同时自己也发送一个SYN包(seq=k),即SYN+ACK包,此时服务器进入SYN_RECV状态。 - 第三次
第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED(TCP连接成功)状态,完成三次握手。