MySQL之Field‘***’doesn’t have a default value错误解决办法

  手上负责的一个项目在用户注册的时候会报错,找了下原因是因为字段没有默认值,我本地环境 mysql5.5 没有问题,test 环境是mysql5.6,通过查资料知道了原来跟 my.ini 的配置有关。

解决方案:

打开 my.ini,查找

sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

去掉 STRICT_TRANS_TABLES, 修改为:

sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

然后重启 MySQL 即可。

原理解析

  在 STRICT_TRANS_TABLES 模式 ( 严格模式 ) 下,当我们插入数据时,MySQL 会严格的进行数据的校验,当发现插入列值未满足要求,直接报 error 错误,保证了错误数据无法插入到数据库中。

MySql不停机添加丛库小记

  拖了很长时间才开始写这篇文章,本来打算上线之后第二天立刻开始记录的,一直有很多碎片事情要做。

  基础是已经有一主一丛,或一主多从,由于业务需要增加新的丛库来分担读的压力。查看如何配置主从复制

不停机平滑加丛库主要原理是: 

1、停掉当前的丛库同步 stop slave。做这一步之前需要需要代码层的改动,将这个从库从web业务脱离,建议访问量少时候操作。

2、查看丛库状态,show slave status  记下 Relay_Master_Log_file 和 Exec_Master_Log_Pos 

3、备份丛库,Myisam直接打包文件拷贝到另一台机器就可以了。Innodb的可以用xtrabackup备份,数据量少可以直接用Navicat数据传输,或者mysqldump导出。 

4、将数据库备份拷贝到待加丛库的机器,数据怎么弄过来方法很多,一定要保证拷贝过来的数据与上一个丛库的数据一致,数据表正常可用。 

5、编辑配置文件 my.cnf  修改 server-id (不要与之前的丛库相同) replicate-do-db(同步的库)  这两个参数

6、在新丛库设置主库的连接信息

change master to
master_host='192.168.0.xxx',
master_port=3306,
master_user='userdb_slave',     
master_password='xxxxxxxxxxxxxxxxx',
master_log_file='mysql-bin.000169',     # 上面记录的
master_log_pos=824721706;               # 上面记录的

7、重启数据库,start slave 开启同步。show slave status  

看这两个参数 Slave_IO_Running    Yes   Slave_SQL_Running   Yes  那就证明主从正常了

8、不要忘了把上一个丛库开启同步 start slave,查看上一个丛库和新加丛库是否正常同步可用,最后加入到web业务代码里面。

SQL四种语言:DDL,DML,DCL,TCL

1.DDLData Definition Language数据库定义语言statements are used to define the database structure or schema.

DDL是SQL语言的四大功能之一。
用于定义数据库的三级结构,包括外模式、概念模式、内模式及其相互之间的映像,定义数据的完整性、安全控制等约束
DDL不需要commit.
CREATE
ALTER
DROP
TRUNCATE
COMMENT
RENAME

2.DMLData Manipulation Language数据操纵语言statements are used for managing data within schema objects.

- 阅读全文 -

中文关键字搜索,出现 Illegal mix of collations for operation

  一套老程序,条件查询出现错误[Err] 1271 - Illegal mix of collations for operation 'like',打出sql,放到查询器出现这个报错。

blob.png

错误原理分析以及错误解决方法:

在 MySQL 5.5 以上, 若字段 Type 是 time,date,datetime 

在 select 時若使用 like '%中文%' 会出現 Illegal mix of collations for operation 'like'

在写程序时要对每个字段进行搜索,在执行时可能就会出现时间字段 like '%中文%' 这种语法,

这在比较久的版本MySQL是不会出现错误的。但是升级到MySQL 5.5以上,必需改成like binary '%中文%' 即可避免出现错误


我的是 blob.png,用的mysql5.6,所以就出错了。


blob.png

修改之后的sql,查询成功。