天天看点

21年-外包-面试题背景题目

目录

  • 背景
  • 题目
    • 1.sql执行过程
    • 2.判断sql是否执行成功?
    • 3.get和post区别
    • 补充:为什么get比post更快
    • 4.线程池
    • 5.线程的创建方式
    • 6.索引失效了怎么办
    • [email protected]用法
    • 8.索引有几种

背景

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.索引失效了怎么办

[email protected]用法

8.索引有几种

主键索引

唯一索引

普通索引

全文索引