亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

校驗表中數據是否有循環編碼的通用存儲過程.sql

系統 2348 0

CREATE PROC p_VerifyData
@TableName???? sysname,?? --要校驗樹形數據的表
@CodeField????? sysname,? --編碼字段名
@ParentCodeField sysname? --上級編碼字段名
AS
SET NOCOUNT ON
--參數檢查
IF ISNULL(OBJECTPROPERTY(OBJECT_ID(@TableName),N'IsUserTable'),0)=0
BEGIN
?RAISERROR(N'"%s"不存在,或者不是用戶表',1,16,@TableName)
?RETURN
END
IF NOT EXISTS(SELECT * FROM SYSCOLUMNS WHERE ID=OBJECT_ID(@TableName) AND name=@CodeField )
BEGIN
?RAISERROR(N'列"%s"在用戶表"%s"中不存在',1,16,@CodeField,@TableName)
?RETURN?
END
IF NOT EXISTS(SELECT * FROM SYSCOLUMNS WHERE ID=OBJECT_ID(@TableName) AND name=@ParentCodeField )
BEGIN
?RAISERROR(N'列"%s"在用戶表"%s"中不存在',1,16,@ParentCodeField,@TableName)
?RETURN?
END
SELECT @TableName=QUOTENAME(@TableName),
?@CodeField=QUOTENAME(@CodeField),
?@ParentCodeField=QUOTENAME(@ParentCodeField)

--數據檢查
EXEC(N'
--檢查導致循環的節點
DECLARE @Level int
SET @Level=1
SELECT ID,PID,Path=CAST(ID as varchar(8000)),Level=@Level
INTO # FROM(--列出所有父節點不是根節點的數據(使用子查詢是防止編碼列為IDENTITY列時,導致后面的插入處理出錯)
?SELECT ID=a.'+@CodeField+N',PID=a.'+@ParentCodeField+N'
?FROM '+@TableName+N' a,'+@TableName+N' b
?WHERE a.'+@ParentCodeField+N'=b.'+@CodeField+N'
??AND b.'+@ParentCodeField+N' IS NOT NULL)a
WHILE @@ROWCOUNT>0
BEGIN
?SET @Level=@Level+1
?INSERT # SELECT a.'+@CodeField+N',b.PID ,
??CAST( a.'+@CodeField+N' as varchar(8000))+''>''+b.Path,@Level
?FROM '+@TableName+N' a,# b
?WHERE a.'+@ParentCodeField+N'=b.ID
??AND b.Level=@Level-1
??AND b.ID<>b.PID
END

--顯示結果
SELECT '+@CodeField+N',Description=N'' 父節點無效''
FROM '+@TableName+N' a
WHERE '+@ParentCodeField+N' IS NOT NULL
?AND NOT EXISTS(
??SELECT * FROM '+@TableName+N'
??WHERE '+@CodeField+N'=a.'+@ParentCodeField+N' )
UNION ALL --顯示產生循環的節點
SELECT ID,N''循環:''+Path+''>''+CAST(ID as varchar(8000))
FROM # WHERE ID=PID
')

校驗表中數據是否有循環編碼的通用存儲過程.sql


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 操片免费看 | 深夜日韩| 国产精品欧美一区二区 | 四虎在线最新地址公告 | 久草久| 亚洲一成人毛片 | 亚洲尹人 | 国产成人精品三区 | 久久香蕉国产线看观看乱码 | 99久久精品国产片 | 久久精品国产在热久久2019 | 中文字幕在线激情日韩一区 | 国产成人精品视频 | 在线观看 一区二区 麻豆 | 日本一级毛片私人影院 | 国产精品成人h片在线 | 久久99久久精品97久久综合 | 美女很黄很黄免费的 | 热思思久久 | 国产成人亚洲精品91专区手机 | 奇米影视在线视频 | 精品在线免费视频 | 亚洲日韩aⅴ在线视频 | 欧美成人精品高清在线观看 | 日本人一级毛片免费完整视频 | 日韩欧美网址 | 欧美日韩在线看 | 日本人成18在线播放 | 国产视频久久久 | 中文字幕亚洲一区二区三区 | 岛国片欧美一级毛片 | 精品久久久久久久久免费影院 | 日本在线观看中文字幕 | 久久精品成人一区二区三区 | 亚洲第一二三四区 | 四虎4hu永久免费国产精品 | 一级毛片免费视频日本 | 中文字幕一区2区 | 91精品国产91久久久久青草 | 亚洲午夜网 | 蜜桃精品免费久久久久影院 |