第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

使 SQL INSERT 語句更易于閱讀

使 SQL INSERT 語句更易于閱讀

Go
千萬里不及你 2021-06-24 22:29:05
我正在用 Go 編寫一個(gè)程序,它大量使用 MySQL。為了可讀性,是否可以在 INSERT 語句中的每個(gè)列名之后包含列的值?喜歡:INSERT INTO `table` (`column1` = 'value1', `column2` = 'value2'...);代替INSERT INTO `table` (`column`, `column2`,...) VALUES('value1', 'value2'...);以便更容易查看哪個(gè)值與哪個(gè)列相關(guān)聯(lián),考慮到 SQL 字符串通常會(huì)變得相當(dāng)長
查看完整描述

3 回答

?
守著星空守著你

TA貢獻(xiàn)1799條經(jīng)驗(yàn) 獲得超8個(gè)贊

不,您不能使用您建議的語法(盡管它會(huì)很好)。


一種方法是排列列名和值:


INSERT INTO `table` 

(`column`, `column2`,...) 

VALUES

('value1', 'value2'...);

更新響應(yīng)您的評(píng)論“語句包含來自字符串外部的變量”:如果您參數(shù)化您的 SQL 語句,那么將列名與變量匹配很容易檢查參數(shù)是否為其各自的列命名:@ColumnName。


這實(shí)際上是我在 TSQL 腳本中的做法:


INSERT INTO `table` 

(

    `column`, 

    `column2`,

    ...

VALUES

(

    'value1', 

    'value2',

    ...

);

(將逗號(hào)放在行首也很常見)


但老實(shí)說,一旦你得到足夠多的列,很容易混淆列的位置。如果它們具有相同的類型(和相似的值范圍),您可能不會(huì)立即注意到......


查看完整回答
反對(duì) 回復(fù) 2021-06-28
?
隔江千里

TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超10個(gè)贊

雖然這個(gè)問題有點(diǎn)老,但我會(huì)把它放在這里供未來的研究人員使用。


我建議使用 SET 語法而不是丑陋的 VALUES 列表語法。


INSERT INTO table

SET

column1 = 'value1',

column2 = 'value2';

恕我直言,這是 MySQL 中最干凈的方式。


查看完整回答
反對(duì) 回復(fù) 2021-06-28
  • 3 回答
  • 0 關(guān)注
  • 216 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)