我正在一个项目中工作,其中数据库项目没有被删除,而只是被标记为已删除。像这样的东西:
id name deleted
--- ------- --------
1 Thingy1 0
2 Thingy2 0
3 Thingy3 0
我希望能够在name
列上定义类似 UNIQUE 约束的东西。看起来很容易,对吧?
让我们想象一个场景,其中“Thingy3”被删除,并创建了一个新的(可能是几年后)。我们得到:
id name deleted
--- ------- --------
1 Thingy1 0
2 Thingy2 0
3 Thingy3 1
...
100 Thingy3 0
从用户的角度来看,他删除了一个项目并创建了一个新项目。就像删除文件并创建新文件一样。所以对他来说很明显,新项目与旧项目相关的任何数据无关且不附加。
这已经处理好了,因为数据库只关心id
,并且由于新项目id
的 100 而不是 3,所以它们完全不同。
当我想阻止用户创建另一个“Thingy3”项目时,我的困难就出现了。如果我有一个 UNIQUE 约束,它只查看未标记的项目deleted
,那么我会解决一个问题。
(当然,然后我必须处理当有人撤消删除时会发生什么......)
那么,我该如何定义这种约束呢?