微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何为sql server中的特定字符创建约束?

如何解决如何为sql server中的特定字符创建约束?

我试图为图书 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_IDBookID。列名中有空格只会使查询变得混乱。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。