MySQL一些默认规则

MySQL的默认规则

MySQL插入数据,需要加引号的数据类型

在平日使用的时候并没有注意到MySQL插入数据的时候字段对应的数据到底需不需要加上单引号。有些字段必须是要加上单引号的,否则会报错。但是有些确实加不加都无所谓。这有点意思。
见下图:
在这里插入图片描述
教师表teacher中tno为长度为3的字符型,在插入时加不加单引号都可以插入,甚至查询时where tno='111’和where tno=111都可以查询出相同结果。
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
通过查询,得知以下类型是需要加上单引号的:

  • 字符串类型和日期类型需要加单引号
  • 整数和浮点型的不需要加

MySQL加单引号和不加单引号的性能比较

还是刚才的teacher表,又存在一个新的问题,查询时where tno='111’和where tno=111都可以查询出相同结果。那他们有什么性能上的差距吗?详细可见
在这里插入图片描述
上面结果显示,都可以查询出结果,但是通过explain可以查看出2个SQL语句的不同。效率上的不同。
在这里插入图片描述

  • 第一个是没加单引号,是全扫描,未使用到主键索引;
  • 第二个加上单引号,使用了索引,效率高;

总结:我们在写SQL查询的时候,对应字符类型就还是的加上单引号吧,似乎那没有坏处。在mysql中单引号是代表字符不需要再编辑了,如果不是字符还需要mysql进行一个类型判断操作所以自然就慢了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值