MySQL使用注意事项(一)

今天继续给大家介绍MySQL相关知识,本文主要内容是介绍一些MySQL数据库在运维、管理和使用中一些不被人注意的点,特别是一些刚入门MySQL数据库的新手,建议观看。

一、NULL和空字符串问题

我们都知道,MySQL数据库中,对于一些没有限制NOT NULL的字段,可以插入一个NULL,表示“空值”。但是,除了NULL之外,MySQL还允许插入一个特殊的数值’’。即两个引号,中间没有任何字符,也没有任何空格,这就表示这是一个空字符串,我们把这个空字符串称为MySQL中另一种“空值”,如下所示:
在这里插入图片描述
从上图中,不难看出,MySQL支持对任何数据类型插入这个特殊的“空值”,不管是字符类型、整数类型,甚至enum类型也可以插入这个特殊的“空值”(事实上,date和time类型也可以插入)。
那么,NULL和空字符串之前有什么区别呢?
1、空字符串不占用存储空间,NULL占用存储空间。
这是因为,在MySQL数据库中,’'是真的没有数据,但是对于NULL,MySQL要采用特殊的编码对该处的NULL进行表示。
2、空字符串比NULL效率高。
除了存储上的原因之外,还有一个原因在于NULL对于索引的影响非常大,索引的效率也会向相应下降很多。MySQL难以优化引用可空列查询,它会使索引、索引统计和值更加复杂。可空列需要更多的存储空间,还需要MySQL内部进行特殊处理。当可空列被处理后,每条记录都需要一个额外的字节,还可能导致MyISAM数据表中固定大小的索引编程可变大小的索引。

二、大小写问题

MySQL数据库是不区分大小写的,这一点有时可以帮助我们忽略大小写,在写SQL语句时更加方面。但是,有时却会使得我们在查询数据时出现问题,如下所示:
在这里插入图片描述
从上图中我们可以看出,本来我们想查询bob同学的相关信息,但是由于数据表中还存在一个Bob的同学,因此在MySQL忽略大小写的机制下,我们连同Bob的信息也查询了出来,那么,我们应该如何只查询bob,不查询Bob,达到我们想要的结果呢?
方法非常简单,可以在要匹配的条件前面,加一个binary关键字就可以了,加上了该关键字后,表示该字段的在匹配时,要严格按照二进制进行匹配,这样就解决了MySQL数据库大小写查询问题了,如下所示:
在这里插入图片描述

三、\G问题

我们在使用MySQL数据库时,大多数情况下都是以分号标识一个SQL语句的结束,这在大多数情况下是没有问题的,但是有时由于我们要查询的数据太长,使用分号结尾可能会出现格式换乱的现象,如下所示:
在这里插入图片描述
从上图中,我们可以看出,本来是一个很正常的select查询数据的语句,但是,由于该数据表中数据过长,无法在一行之内写下,因此出现了格式混乱的问题。
此时,我们可以使用\G来代替分号,如下所示:
在这里插入图片描述
\G代表按行显示,这样,我们在显示时就不会出现乱码问题了。

四、修改表字段问题

在数据库设计和规划时,我们就必须要考虑好整个业务的需求,以及日后的发展,这样好的对数据库库表结构进行更好的设计。在创建好数据库并且插入数据后,再来更改数据库的库表结构显示不是一个很好的解决方案,这会带来一系列的问题。
最简单、最直接的问题,就是因为数据表中已经存在的数据对修改的字段造成影响,MySQL数据库会拒绝我们的修改,如下所示:
在这里插入图片描述
从图中可以看出,当我们尝试向存在重复值得字段添加主键索引时,MySQL会拒绝该操作。
但是,问题在于,MySQL数据库的机制对于我们更改数据表过于“宽容”,导致一些本来该拒绝的操作,MySQL进行了“变通执行”,这就会导致我们的原本数据遭到破坏,如下所示:
在这里插入图片描述
在上图中,对数据库的字段类型进行修改,导致一些数据丢失了。
在这里插入图片描述
在上图中,对该数据表的name字段进行修改,使得修改后的长度无法存储下原有的数据,数据表修改成功,但是数据丢失了。
因此,我们在对已经插入数据的数据库字段进行修改表结构时,一定要慎重修改,审慎决策,必须要进行修改时,也必须提前做好备份,选择合适的时间,防止出现问题影响业务。
原创不易,转载请说明出处:https://blog.csdn.net/weixin_40228200

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

永远是少年啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值