目录
背景
21年5月,应聘杭州余杭某外包。
题目的答案,是根据我的理解写的。可能有不对的地方,欢迎大家指正。
题目
1.sql执行过程
2.判断sql是否执行成功?
表述1:通过sql返回值-受影响的行数,判断是否执行成功
受影响的行数>=1,执行成功
表述2:在SQL语句附近加上 mysql_affected_rows() ,如果 mysql_affected_rows()的值为“-1”,则执行失败,如果大于等于0,则语句执行成功!
3.get和post区别
一般的区别:
(1)post更安全(不会作为url的一部分,不会被缓存、保存在服务器日志、以及浏览器浏览记录中)
(2)post发送的数据更大(get有url长度限制)
(3)post能发送更多的数据类型(get只能发送ASCII字符)
(4)post比get慢
(5)post用于修改和写入数据,get一般用于搜索排序和筛选之类的操作(淘宝,支付宝的搜索查询都是get提交),目的是资源的获取,读取数据
补充:为什么get比post更快
1.post请求包含更多的请求头
因为post需要在请求的body部分包含数据,所以会多了几个数据描述部分的首部字段(如:content-type),这其实是微乎其微的。
2.最重要的一条,post在真正接收数据之前会先将请求头发送给服务器进行确认,然后才真正发送数据
post请求的过程:
(1)浏览器请求tcp连接(第一次握手)
(2)服务器答应进行tcp连接(第二次握手)
(3)浏览器确认,并发送post请求头(第三次握手,这个报文比较小,所以http会在此时进行第一次数据发送)
(4)服务器返回100 Continue响应
(5)浏览器发送数据
(6)服务器返回200 OK响应
get请求的过程:
(1)浏览器请求tcp连接(第一次握手)
(2)服务器答应进行tcp连接(第二次握手)
(3)浏览器确认,并发送get请求头和数据(第三次握手,这个报文比较小,所以http会在此时进行第一次数据发送)
(4)服务器返回200 OK响应
也就是说,目测get的总耗是post的2/3左右,
3.get会将数据缓存起来,而post不会
4.线程池
Executors.newCachedThreadPool
Executors.newFixedThreadPool
Executors.newScheduledThreadPool
Executors.newSingleThreadExecutor
5.线程的创建方式
6.索引失效了怎么办
7.@mapper用法
8.索引有几种
主键索引
唯一索引
普通索引
全文索引