首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >你能限制(数据库)表中的行数吗?

你能限制(数据库)表中的行数吗?
EN

Stack Overflow用户
提问于 2008-12-29 21:35:12
回答 7查看 5.4K关注 0票数 4

我们有一个数据库(SQL Server2005),我们希望将其置于源代码管理之下。作为其中的一部分,我们将有一个版本表来存储数据库的当前版本号。有没有办法将该表限制为只包含一行?或者将版本号存储在表中是不是一个好主意?

最终使用了这种方法:

代码语言:javascript
复制
CREATE TABLE [dbo].[DatabaseVersion]
    (
        [MajorVersionNumber] [int]  NOT NULL,
        [MinorVersionNumber] [int]  NOT NULL,
        [RevisionNumber] [int]  NOT NULL
    )
GO

Insert DataBaseVersion (MajorVersionNumber,  MinorVersionNumber,  RevisionNumber) values (0, 0, 0)
GO

CREATE TRIGGER DataBaseVersion_Prevent_Delete
ON DataBaseVersion INSTEAD OF DELETE
AS
BEGIN
    RAISERROR ('DatabaseVersion must always have one Row. (source = INSTEAD OF DELETE)', 16, 1) 
END
GO

CREATE TRIGGER DataBaseVersion_Prevent_Insert
ON DataBaseVersion INSTEAD OF INSERT
AS
BEGIN
    RAISERROR ('DatabaseVersion must always have one Row. (source = INSTEAD OF INSERT)', 16, 1) 
END
GO
EN

回答 7

Stack Overflow用户

回答已采纳

发布于 2008-12-29 21:37:46

使用触发器。

票数 7
EN

Stack Overflow用户

发布于 2008-12-29 21:41:35

泛化该表以保存“设置”,并使其成为键/值对

代码语言:javascript
复制
CREATE TABLE Settings (Key nvarchar(max), Value nvarchar(max))

然后在Key上建立唯一的索引。

代码语言:javascript
复制
CREATE UNIQUE INDEX SettingsIDX ON Settings (Key)

这将创建一个具有唯一键值对的表,其中一个可以是Version。

代码语言:javascript
复制
INSERT INTO Settings (Key, Value) VALUES ('Version','1');
票数 6
EN

Stack Overflow用户

发布于 2012-08-11 06:38:05

你可以使用Joe Celko的default+primary+check技术:

代码语言:javascript
复制
create table database_version (

  lock char(1) primary key default 'x' check (lock='x'),
  major_version_number int NOT NULL,
  minor_version_number int NOT NULL,
  revision_number int NOT NULL
);

使用它进行Fiddle

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/398747

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档