我们有一个数据库(SQL Server2005),我们希望将其置于源代码管理之下。作为其中的一部分,我们将有一个版本表来存储数据库的当前版本号。有没有办法将该表限制为只包含一行?或者将版本号存储在表中是不是一个好主意?
最终使用了这种方法:
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发布于 2008-12-29 21:37:46
使用触发器。
发布于 2008-12-29 21:41:35
泛化该表以保存“设置”,并使其成为键/值对
CREATE TABLE Settings (Key nvarchar(max), Value nvarchar(max))然后在Key上建立唯一的索引。
CREATE UNIQUE INDEX SettingsIDX ON Settings (Key)这将创建一个具有唯一键值对的表,其中一个可以是Version。
INSERT INTO Settings (Key, Value) VALUES ('Version','1');发布于 2012-08-11 06:38:05
你可以使用Joe Celko的default+primary+check技术:
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
https://stackoverflow.com/questions/398747
复制相似问题