久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

對兩個字段的唯一約束,以及它們的相反

Unique constraint on two fields, and their opposite(對兩個字段的唯一約束,以及它們的相反)
本文介紹了對兩個字段的唯一約束,以及它們的相反的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

限時送ChatGPT賬號..

我有一個數據結構,我必須在其中存儲元素對.每對中正好有 2 個值,因此我們使用了一個表,其中包含字段 (leftvalue, rightvalue....).這些對應該是唯一的,如果鍵被更改,它們被認為是相同的.

I have a data structure, where I have to store pairs of elements. Each pair has exactly 2 values in it, so we are employing a table, with the fields(leftvalue, rightvalue....). These pairs should be unique, and they are considered the same, if the keys are changed.

Example: (Fruit, Apple) is the same as (Apple, Fruit).

如果可能以一種有效的方式,我會在字段上設置數據庫約束,但不會以任何代價 - 性能更重要.

If it is possible in an efficient way, I would put a database constraint on the fields, but not at any cost - performance is more important.

我們目前使用的是 MSSQL server 2008,但可以更新.

We are using MSSQL server 2008 currently, but an update is possible.

有沒有有效的方法來實現這一目標?

Is there an efficient way of achieving this?

推薦答案

兩種解決方案,實際上都是將問題變得更簡單.如果可以接受強制改變消費者,我通常更喜歡 T1 解決方案:

Two solutions, both really about changing the problem into an easier one. I'd usually prefer the T1 solution if forcing a change on consumers is acceptable:

create table dbo.T1 (
    Lft int not null,
    Rgt int not null,
    constraint CK_T1 CHECK (Lft < Rgt),
    constraint UQ_T1 UNIQUE (Lft,Rgt)
)
go
create table dbo.T2 (
    Lft int not null,
    Rgt int not null
)
go
create view dbo.T2_DRI
with schemabinding
as
    select
        CASE WHEN Lft<Rgt THEN Lft ELSE Rgt END as Lft,
        CASE WHEN Lft<Rgt THEN Rgt ELSE Lft END as Rgt
    from dbo.T2
go
create unique clustered index IX_T2_DRI on dbo.T2_DRI(Lft,Rgt)
go

在這兩種情況下,T1T2 都不能在 Lft,Rgt 對中包含重復值.

In both cases, neither T1 nor T2 can contain duplicate values in the Lft,Rgt pairs.

這篇關于對兩個字段的唯一約束,以及它們的相反的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

What SQL Server Datatype Should I Use To Store A Byte[](我應該使用什么 SQL Server 數據類型來存儲字節 [])
Interpreting type codes in sys.objects in SQL Server(解釋 SQL Server 中 sys.objects 中的類型代碼)
Typeorm Does not return all data(Typeorm 不返回所有數據)
Typeorm .loadRelationCountAndMap returns zeros(Typeorm .loadRelationCountAndMap 返回零)
How to convert #39;2016-07-01 01:12:22 PM#39; to #39;2016-07-01 13:12:22#39; hour format?(如何將“2016-07-01 01:12:22 PM轉換為“2016-07-01 13:12:22小時格式?)
MS SQL: Should ISDATE() Return quot;1quot; when Cannot Cast as Date?(MS SQL:ISDATE() 是否應該返回“1?什么時候不能投射為日期?)
主站蜘蛛池模板: 日日草夜夜草 | 天天综合成人网 | 日韩福利在线 | 欧美日韩免费一区二区三区 | 卡通动漫第一页 | 欧美亚洲一区二区三区 | av在线电影网 | av一级久久| 最新黄色在线观看 | 日韩伦理电影免费在线观看 | 日本中出视频 | 亚洲欧美日韩一区 | 国产精品久久久久久影院8一贰佰 | 久久99视频免费观看 | 中文字幕在线观看精品 | 国产小视频在线 | 中文字幕一区二区三区精彩视频 | 成人a视频 | 在线视频91 | 日日碰碰 | 久久久国产精品视频 | 国内av在线| 久久伊人一区 | 九九热精品视频 | 超碰成人免费 | 亚洲精品免费视频 | 国产成人精品免高潮在线观看 | 就操在线 | 激情国产 | 精品国产一区二区在线 | 国产免费一区二区三区最新6 | 免费午夜视频在线观看 | 亚洲欧洲激情 | 欧美精品一区二区三区四区 在线 | 午夜小电影| 久久久精品网站 | 日韩成人一区二区 | 国产福利久久 | 久久精品国产亚洲夜色av网站 | 天天操天天射综合网 | 一区二区三区国产好 |