报错
有冲突在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;
这两部执行成功基本搞定