关于MySQL的检查约束不生效的问题

关于MySQL的检查约束不生效的问题,第1张

在使用MySQL的检查(check)约束时,向表中插入不符合约束条件的数据行时,也能插入成功不会报错!

建表语句如下:

向其中插入行

居然返回

看来check约束是白写了,没有起作用.

经过上网查看发现,MySQL只是可以使用check约束, 但不会强制的遵循check约束!

官方推荐使用 枚举类型(ENUM) 来替代以上的使用check约束的情况.将表中的gender字段修改成如下类型:

(注意修改前的表中数据不能有gender字段含有不是'M'或'F'的数据行,否则不能执行以下语句,会报错)

执行alter语句后的person表的gender就会在插入和修改时严格验证属于的数据是否合法啦!

测试一下:

如下插入语句会报错

当输入正确的语句时不会报错,通过验证

一:检查是否锁表, 查询进程并杀死进程

1) 查询是否锁表

show open tables where in_use >0

2) 查询进程(如果您有SUPER权限,您可以看到所有线程。否则,您只能看到您自己的线程)

show processlist

二:查看在锁事务,杀死事务对应的线程ID

1) 查看正在锁的事务

select * from information_schema.INNODB_LOCKS

2) 杀死进程id(就是[select * from information_schema.INNODB_LOCKS]命令的trx_mysql_thread_id列)

kill 线程ID

3) 查看等待锁的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS

其它:

1) 查看服务器状态

show status like '%lock%'

2) 查看超时时间:

show variables like '%timeout%'

你是用的windows还是linux?如果是linux,在系统终端输入mysql -u root -p,然后输入你的mysql密码,如果能够登录进去,说敏安装成功了。windows也是一样的,打开mysql的终端,输入上述命令


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/7466994.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-06
下一篇2023-04-06

发表评论

登录后才能评论

评论列表(0条)

    保存