问题描述
我试图为图书 ID 创建一个约束,即 BID 之后的剩余 3 个字符必须是 001 到 999。我可以做什么来代替使用 % ?
CREATE TABLE Book
(
[Book ID] CHAR(6),[Title] VARCHAR(50) NOT NULL,[Genre] VARCHAR(50) NOT NULL,[Author] VARCHAR(50) NOT NULL,[Price] DECIMAL(18,2) NOT NULL,CONSTRAINT Book_PK PRIMARY KEY ([Book ID]),CONSTRAINT chk_BookID CHECK ([Book ID] like 'BID%'),);
解决方法
SQL Server 支持 LIKE
中的字符类:
CONSTRAINT chk_BookID CHECK ([Book ID] like 'BID[0-9][0-9][0-9]')
注意:我建议您将该列重命名为 Book_ID
或 BookID
。列名中有空格只会使查询变得混乱。