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

T-SQL:更新后哪些 COLUMNS 發生了變化?

T-SQL: what COLUMNS have changed after an update?(T-SQL:更新后哪些 COLUMNS 發生了變化?)
本文介紹了T-SQL:更新后哪些 COLUMNS 發生了變化?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

好的.我正在對表中的單行進行更新.除主鍵外,所有字段都將被新數據覆蓋.但是,并非所有值都會更改更新的 b/c.例如,如果我的表如下:

OK. I'm doing an update on a single row in a table. All fields will be overwritten with new data except for the primary key. However, not all values will change b/c of the update. For example, if my table is as follows:

TABLE (id int ident, foo varchar(50), bar varchar(50))

初始值為:

id   foo   bar
-----------------
1    hi    there

然后我執行 UPDATE tbl SET foo = 'hi', bar = 'something else' WHERE id = 1

我想知道的是哪個列的值發生了變化,其原始值是多少,新值是什么.

What I want to know is what column has had its value changed and what was its original value and what is its new value.

在上面的示例中,我希望看到列bar"從那里"更改為其他地方".

In the above example, I would want to see that the column "bar" was changed from "there" to "something else".

可以不進行逐列比較嗎?是否有一些優雅的 SQL 語句,例如 EXCEPT 會比行更細粒度?

Possible without doing a column by column comparison? Is there some elegant SQL statement like EXCEPT that will be more fine-grained than just the row?

謝謝.

推薦答案

沒有您可以運行的特殊語句來準確地告訴您哪些列發生了更改,但是查詢并不難編寫:

There is no special statement you can run that will tell you exactly which columns changed, but nevertheless the query is not difficult to write:

DECLARE @Updates TABLE
(
    OldFoo varchar(50),
    NewFoo varchar(50),
    OldBar varchar(50),
    NewBar varchar(50)
)

UPDATE FooBars
SET <some_columns> = <some_values>
OUTPUT deleted.foo, inserted.foo, deleted.bar, inserted.bar INTO @Updates
WHERE <some_conditions>

SELECT *
FROM @Updates
WHERE OldFoo != NewFoo
OR OldBar != NewBar

如果你想真正做一些事情作為這些變化的結果,那么最好寫一個觸發器:

If you're trying to actually do something as a result of these changes, then best to write a trigger:

CREATE TRIGGER tr_FooBars_Update
ON FooBars
FOR UPDATE AS
BEGIN
    IF UPDATE(foo) OR UPDATE(bar)
        INSERT FooBarChanges (OldFoo, NewFoo, OldBar, NewBar)
            SELECT d.foo, i.foo, d.bar, i.bar
            FROM inserted i
            INNER JOIN deleted d
                ON i.id = d.id
            WHERE d.foo <> i.foo
            OR d.bar <> i.bar
END

(當然,您可能希望在觸發器中執行更多操作,但有一個非常簡單的操作示例)

(Of course you'd probably want to do more than this in a trigger, but there's an example of a very simplistic action)

您可以使用 COLUMNS_UPDATED 而不是 UPDATE 但我覺得這很痛苦,而且它仍然不會告訴您哪些列實際更改了,只是哪些列包含在 UPDATE 語句中.因此,例如,您可以編寫 UPDATE MyTable SET Col1 = Col1 并且它仍然會告訴您 Col1 已更新,即使沒有一個值實際更改.編寫觸發器時,您需要實際測試各個前后值,以確保獲得真正的更改(如果這是您想要的).

You can use COLUMNS_UPDATED instead of UPDATE but I find it to be pain, and it still won't tell you which columns actually changed, just which columns were included in the UPDATE statement. So for example you can write UPDATE MyTable SET Col1 = Col1 and it will still tell you that Col1 was updated even though not one single value actually changed. When writing a trigger you need to actually test the individual before-and-after values in order to ensure you're getting real changes (if that's what you want).

附言您也可以像 Rob 所說的那樣 UNPIVOT,但您仍然需要在 UNPIVOT 子句中明確指定列,這并不神奇.

P.S. You can also UNPIVOT as Rob says, but you'll still need to explicitly specify the columns in the UNPIVOT clause, it's not magic.

這篇關于T-SQL:更新后哪些 COLUMNS 發生了變化?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

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

相關文檔推薦

Converting Every Child Tags in to a Single Column with multiple Delimiters -SQL Server (3)(將每個子標記轉換為具有多個分隔符的單列-SQL Server (3))
How can I create a view from more than one table?(如何從多個表創建視圖?)
Create calculated value based on calculated value inside previous row(根據前一行內的計算值創建計算值)
How do I stack the first two columns of a table into a single column, but also pair third column with the first column only?(如何將表格的前兩列堆疊成一列,但也僅將第三列與第一列配對?) - IT屋-程序員軟件開發技
Recursive t-sql query(遞歸 t-sql 查詢)
Convert Month Name to Date / Month Number (Combinations of Questions amp; Answers)(將月份名稱轉換為日期/月份編號(問題和答案的組合))
主站蜘蛛池模板: 精品久久久久久久久久久久 | 亚洲精品99| 色婷婷亚洲国产女人的天堂 | 精品久久久久久久久久久久久久 | 中文在线一区二区 | 黑人性hd| 男人天堂999 | 亚洲成在线观看 | 国产精品区二区三区日本 | 欧美日韩在线观看一区 | 国产视频第一页 | 男女午夜激情视频 | 国产高清视频在线观看 | 成人深夜福利网站 | 午夜视频在线观看网址 | 国产午夜精品一区二区三区 | 日韩一二区 | 久久高清免费视频 | 99在线精品视频 | 亚洲一级淫片 | 国产精品三级久久久久久电影 | 中文字幕日韩一区二区 | 国产91精品久久久久久久网曝门 | 日韩一级黄色片 | 黄色一级免费 | 九一视频在线播放 | 免费在线性爱视频 | 国产精品亚洲一区 | 欧美精品一区二区三区在线 | 自拍偷拍亚洲一区 | 999国产精品视频免费 | 久久久99国产精品免费 | 6080yy精品一区二区三区 | 久久亚洲欧美日韩精品专区 | 中文在线a在线 | 中文字幕日韩欧美一区二区三区 | 欧美中文字幕一区二区三区亚洲 | 九九热在线视频观看这里只有精品 | 性xxxxx| 久久成人国产 | 91成人在线视频 |