五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動(dòng)態(tài)

SqlServer存儲(chǔ)過程實(shí)現(xiàn)及拼接sql的注意點(diǎn)

發(fā)布日期:2021-12-18 19:47 | 文章來源:gibhub

這里我昨天碰到的問題就是執(zhí)行一段根據(jù)變量tableName對(duì)不同的表進(jìn)行字段狀態(tài)的更改。由于服務(wù)器原因,我不能直接在數(shù)據(jù)訪問層寫SQL,所以只好抽離出來放到存儲(chǔ)過程里面。

這里就出現(xiàn)了一個(gè)問題,我花費(fèi)了好久才弄通!

其實(shí)就是很簡單的一個(gè)SQL語句:

  update table1 set field1=value1,field2 = value2 where id = id

我寫成什么樣子了呢?大家且看: 

declare @tableName nvarchar(50),
      @field1 int,
      @field2 nvarchar,
      @id int
  declare @sql nvarchar(max)
  set @sql = 'update '+@tableName+' set field1= '+@field1+',field2= '+@field2+' where id='+@id
  exec @sql 

有過這方面經(jīng)驗(yàn)的同學(xué)肯定知道這樣寫明顯是錯(cuò)的,sql會(huì)報(bào)異常,說無法講nvarchar轉(zhuǎn)換成int類型

那么這個(gè)錯(cuò)誤是具體是值什么呢?其實(shí)就是說,在拼接sql的時(shí)候,這個(gè)@sql要是一個(gè)字符串類型,所有的變量也都必須用字符串表示,我上面的@field1和@id是int,所以要轉(zhuǎn)化成nvarchar類型,并且是nvarchar類型的變量(字段)必須用單引號(hào)括起來;注:在sql中單引號(hào)是用兩個(gè)單引號(hào)表示的

所以經(jīng)過修改,正確的拼接sql代碼是:

set @sql='update '+@tableName+ ' set field1='+cast(@field1 as varchar)+',field2='''+@field2+''' where id='+CAST(@id as varchar) 

這個(gè)問題其實(shí)非常簡單,但是由于我在SQL方面的知識(shí)很是不足,所以在這里記錄來鞏固自己。

以上所述是小編給大家介紹的SqlServer存儲(chǔ)過程實(shí)現(xiàn)及拼接sql的注意點(diǎn),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)本站網(wǎng)站的支持!

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

實(shí)時(shí)開通

自選配置、實(shí)時(shí)開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對(duì)1客戶咨詢顧問

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部