为什么TiDB忽略check约束?

为提高效率,请提供以下信息,问题描述清晰能够更快得到解决:

【TiDB 版本】v4.0.10

【问题描述】
为什么TiDB会忽略Check约束检查?
https://docs.pingcap.com/zh/tidb/stable/constraints#check-约束


若提问为性能优化、故障排查类问题,请下载脚本运行。终端输出的打印结果,请务必全选并复制粘贴上传。

1 个赞

这个是一个未完善的功能点。
这样做只是为了建表时的语法兼容。

2 个赞

您可以测试一下,创建一个带check 约束的表以后,show create table 查看表的定义,是没有这个 check 语句的。说明在创建表的时候,这个 check 语句就已经被忽略掉了。

1 个赞

果然!

CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CHECK (P_Id>0)
);

TiDB> show create table persons;
+---------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table   | Create Table                                                                                                                                                                                                                                                                        | 
+---------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Persons | CREATE TABLE `Persons` (
  `P_Id` int(11) NOT NULL,
  `LastName` varchar(255) NOT NULL,
  `FirstName` varchar(255) DEFAULT NULL,
  `Address` varchar(255) DEFAULT NULL,
  `City` varchar(255) DEFAULT NULL,
  KEY `` ()
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin | 
+---------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
1 个赞

:+1: 我们也会慢慢补上这个check 功能。

1 个赞

此话题已在最后回复的 1 分钟后被自动关闭。不再允许新回复。