国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

SQL UPDATE如何工作

2019-11-03 08:35:50
字體:
供稿:網(wǎng)友
在SQL UPDATE語(yǔ)句中,對(duì)換兩個(gè)變量的值,不需要臨時(shí)變量。=右側(cè)的值在整個(gè)UPDATE語(yǔ)句中都是一致的;所有的更新同時(shí)發(fā)生,而不是一個(gè)接著一個(gè)發(fā)生。

例如:

UPDATE offenceTeam

        SET goalShooter=wingAttack,

               wingAttack=goalShooter;

我在SQL SERVER中試驗(yàn)過,goalShooter和wingAttack字段的值確實(shí)對(duì)換了。值得說明的是:這個(gè)情況只在Oracle,SQL SERVER和PostgreSQL中發(fā)生,在MySQL里面是不成立的。這個(gè)例子來源于《SQL Hacks》。下面是他的解釋:

當(dāng)關(guān)系數(shù)據(jù)庫(kù)執(zhí)行更新時(shí),它必須在某個(gè)位置維護(hù)一份所有原始值的副本,以便確保隔離事務(wù)。一條UPDATE語(yǔ)句可能影響數(shù)千行數(shù)據(jù),也可能要花上數(shù)分鐘的時(shí)間才能完成。如果在更新過程中發(fā)生失敗,系統(tǒng)確保能夠回滾,不提供任何修改。

系統(tǒng)在第一次修改發(fā)生之前能夠訪問所有值。并且,正常情況下你也無(wú)法預(yù)測(cè)更新發(fā)生的次序,因此,明智的行為是,相對(duì)于原始值應(yīng)用修改,而不考慮命令執(zhí)行過程中產(chǎn)生的修改。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 闻喜县| 鸡东县| 宝丰县| 康定县| 郁南县| 和林格尔县| 钦州市| 潢川县| 赤城县| 龙门县| 彭山县| 合作市| 喀什市| 贵阳市| 秭归县| 明溪县| 东乡县| 安福县| 扶余县| 班玛县| 西丰县| 汕尾市| 西充县| 潮安县| 卢氏县| 乌鲁木齐市| 安平县| 七台河市| 乐至县| 大新县| 甘谷县| 海南省| 晋宁县| 文登市| 康平县| 常德市| 曲麻莱县| 南康市| 云浮市| 无为县| 宁德市|