MySQL的小笔记

报错在这里插入图片描述
有冲突在sql_mode=on_full_group_by
搜一下,很明显这是一个mysql5.7的一个问题,因为5.7要求更严格,要求select到的列都能在group by中出现。这个是5.7默认开启的。
所以我们把这个给关闭掉就行了。
说白了,5.7默认管理严格一点,更规范。但是由于多种原因吧,我们不需要太紧,太紧进不去,肯定不爽又着急。所以适当的拓宽一下口子,方便进出。
解决方案:

sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

在[mysqld]下面补充一下代码

sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

保存,然后重启mysql

sudo service mysql restart

重新连接试试吧


show processlist;

查看正在执行的sql语句,可以看到慢的语句方便排查问题


ip装换为数字ip函数:INET_ATON(‘192.168.1.212’) = 3232235988
数字ip转换为ip: INET_NTOA(3232235988) = ‘192.168.1.212’


mysql加密保存数据
首先字段设置为:binary类型
INSERT INTO user(password) VALUES (AES_ENCRYPT("123456","salt"))
这样保存的数据就是加密后
获取数据:
SELECT AES_DECRYPT(password,"salt") FROM user


复制数据表出现
1067 - Invalid default value for 'time'这个问题
原因:mysql.6之后严格模式
timestamp设定默认值规则改变,
第一个TIMESTAMP字段会自动被加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP属性。
第一个TIMESTAMP之后的字段,会被自动加上DEFAULT ‘0000-00-00 00:00:00’属性。
5.7版本的sql_mode变量中含有NO_ZERO_DATE,表示’0000-00-00 00:00:00’格式非法,这与严格模式有关。
所以需要修改全局变量sql_mode,去掉NO_ZERO_IN_DATE,NO_ZERO_DATE
set global sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
set global explicit_defaults_for_timestamp = ON;

这两部执行成功基本搞定

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值