校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 根據表名和索引獲取需要的列名的存儲過程

根據表名和索引獲取需要的列名的存儲過程

熱門標簽:陜西電銷外呼系統好用嗎 成都電話外呼系統一般多少錢 最新人工智能電銷機器人 蘭州語音外呼系統運營商 銀川高頻外呼回撥系統多少錢 如何做地圖標注圖鋪 沒聽見電話機器人幫你接 al智能電話機器人 數字匠心電銷機器人
復制代碼 代碼如下:

create proc p_sword_getblcolumn
(
@tblName varchar(200),
@fromIndex int,
@toIndex int,
@columnName varchar(3000) output
)
as
begin
declare @tempColumn varchar(3000)
declare @errMsg varchar(200)
declare @i int
set @i=1
set @columnName=''
set @errMsg=''
declare tempColumnCur cursor for
select syscolumns.name from syscolumns join sysobjects on syscolumns.id = sysobjects.id
where sysobjects.name =@tblName order by syscolumns.colorder
open tempColumnCur
fetch next from tempColumnCur into @tempColumn
while @@FETCH_STATUS=0
begin
if(@fromIndex=0 and @toIndex=0)
begin
set @columnName=@columnName+','+@tempColumn
end
if(@fromIndex=0 and @toIndex>0)
begin
if(@i=@toIndex)
set @columnName=@columnName+','+@tempColumn
end
else if(@fromIndex >0 and @toIndex=0)
begin
if(@i>=@fromIndex)
set @columnName=@columnName+','+@tempColumn
end
else if(@i>=@fromIndex and @i=@toIndex)
begin
set @columnName=@columnName+','+@tempColumn
end
set @i=@i+1
print @i
fetch next from tempColumnCur into @tempColumn
end
close tempColumnCur
deallocate tempColumnCur
set @columnName=SUBSTRING(@columnName,2,len(@columnName))
print @columnName
if(@@ERROR>0)
begin
set @errMsg='get column error '
goto errorproc
end
else
return 0
end
errorproc:
begin
raiserror(@errMsg,16,1)
return 1
end
go

其中涉及到了raiserror函數
RAISERROR ( { msg_id | msg_str | @local_variable }
{ ,severity ,state }
[ ,argument [ ,...n ] ]
)
[ WITH option [ ,...n ] ]
參數說明:
第一個參數:{ msg_id | msg_str | @local_variable }
msg_id:表示可以是一個sys.messages表中定義的消息代號;
使用 sp_addmessage 存儲在 sys.messages 目錄視圖中的用戶定義錯誤消息號。
用戶定義錯誤消息的錯誤號應當大于 50000。
msg_str:表示也可以是一個用戶定義消息,該錯誤消息最長可以有 2047 個字符;
(如果是常量,請使用N'xxxx',因為是nvarchar的)
當指定 msg_str 時,RAISERROR 將引發一個錯誤號為 5000 的錯誤消息。
@local_variable:表示也可以是按照 msg_str 方式的格式化字符串變量。
第二個參數:severity
用戶定義的與該消息關聯的嚴重級別。(這個很重要)
任何用戶都可以指定 0 到 18 之間的嚴重級別。
[0,10]的閉區間內,不會跳到catch;
如果是[11,19],則跳到catch;
如果[20,無窮),則直接終止數據庫連接;
第三個參數:state
如果在多個位置引發相同的用戶定義錯誤,
則針對每個位置使用唯一的狀態號有助于找到引發錯誤的代碼段。
介于 1 至 127 之間的任意整數。(state 默認值為1)
當state 值為 0 或大于 127 時會生成錯誤!
第四個參數:argument
用于代替 msg_str 或對應于 msg_id 的消息中的定義的變量的參數。
第五個參數:option
錯誤的自定義選項,可以是下表中的任一值:
LOG :在錯誤日志和應用程序日志中記錄錯誤;
NOWAIT:將消息立即發送給客戶端;
SETERROR:將 @@ERROR 值和 ERROR_NUMBER 值設置為 msg_id 或 50000;

標簽:鹽城 邢臺 宜春 本溪 巴彥淖爾 朔州 通化 遼源

巨人網絡通訊聲明:本文標題《根據表名和索引獲取需要的列名的存儲過程》,本文關鍵詞  根據,表名,和,索引,獲取,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《根據表名和索引獲取需要的列名的存儲過程》相關的同類信息!
  • 本頁收集關于根據表名和索引獲取需要的列名的存儲過程的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 台中市| 永平县| 博乐市| 宜君县| 绥滨县| 富阳市| 黑龙江省| 怀远县| 元谋县| 德兴市| 英德市| 汽车| 南丰县| 临邑县| 宁河县| 丰城市| 亚东县| 屯昌县| 桓台县| 镇远县| 剑河县| 三穗县| 潜山县| 贵港市| 崇礼县| 邢台县| 拉萨市| 庆元县| 呈贡县| 左云县| 紫阳县| 射阳县| 连城县| 邛崃市| 定兴县| 定边县| 平邑县| 庆安县| 天柱县| 南部县| 呼图壁县|