亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQL Server查找表名或列名中包含空格的表和列實例代碼

2024-08-31 01:05:26
字體:
來源:轉載
供稿:網友

前言

本文主要給大家介紹的是關于SQL Server查找包含空格的表和列的相關內容,為什么會有這篇文章,是因為最近發現一個數據庫中的某個表有個字段名后面包含了一個空格,這個空格引起了一些小問題,一般出現這種情況,是因為創建對象時,使用雙引號或雙括號的時候,由于粗心或手誤多了一個空格,如下簡單案例所示:

USE TEST;GO --表TEST_COLUMN中兩個字段都包含有空格CREATE TABLE TEST_COLUMN ( "ID " INT IDENTITY (1,1), [Name ] VARCHAR(32), [Normal] VARCHAR(32));GO --表[TEST_TABLE ]中包含空格, 里面對應三個字段,一個前面包含空格(后面詳細闡述),一個字段中間包含空格,一個字段后面包含空格。CREATE TABLE [TEST_TABLE ](  [ F_NAME] NVARCHAR(32), [M NAME]  NVARCHAR(32), [L_NAME ] NVARCHAR(32))GO

實現方法:

那么要如何找出表名或字段名包含空格的相關信息呢? 不管是常規方法還是正則表達式,這個都會效率不高。我們可以用一個取巧的方法,就是通過字段的字符數和字節數的規律來判斷,如果沒有包含空格,那么列名的字節數和字符數滿足下面規律(表名也是如此):

 DATALENGTH(name) = 2* LEN(name)
SELECT name , DATALENGTH(name) AS NAME_BYTES , LEN(name)  AS NAME_CHARACTERFROM sys.columnsWHERE object_id = OBJECT_ID('TEST_COLUMN'); clip_image001

SQLServer,表名,列名,空格,代碼

原理是這樣的,保存這些元數據的字段類型為sysname ,其實這個系統數據類型,用于定義表列、變量以及存儲過程的參數,是nvarchar(128)的同義詞。所以一個字母占2個字節。那么我們安裝這個規律寫了一個腳本來檢查數據中那些表名或字段名包含空格。方便巡檢。如下測試所示

IF OBJECT_ID('tempdb.dbo.#TabColums') IS NOT NULL DROP TABLE dbo.#TabColums; CREATE TABLE #TabColums( object_id   INT , column_id   INT) INSERT INTO #TabColumsSELECT object_id ,  column_idFROM sys.columnsWHERE DATALENGTH(name) != LEN(name) * 2  SELECT  TL.name AS TableName, C.Name AS FieldName, T.Name AS DataType, DATALENGTH(C.name) AS COLUMN_DATALENGTH, LEN(C.name) AS COLUMN_LENGTH, CASE WHEN C.Max_Length = -1 THEN 'Max' ELSE CAST(C.Max_Length AS VARCHAR) END AS Max_Length, CASE WHEN C.is_nullable = 0 THEN '×' ELSE N'√' END AS Is_Nullable, C.is_identity, ISNULL(M.text, '') AS DefaultValue, ISNULL(P.value, '') AS FieldComment FROM sys.columns CINNER JOIN sys.types T ON C.system_type_id = T.user_type_idLEFT JOIN dbo.syscomments M ON M.id = C.default_object_idLEFT JOIN sys.extended_properties P ON P.major_id = C.object_id AND C.column_id = P.minor_id INNER JOIN sys.tables TL ON TL.object_id = C.object_idINNER JOIN #TabColums TC ON C.object_id = TC.object_id AND c.column_id = TC.column_idORDER BY C.Column_Id ASC

SQLServer,表名,列名,空格,代碼

那么為什么表名TEST_TABLE的三個字段里面,前面包含空格與與中間包含空格都識別不出來呢?這個與數據庫的LEN函數有關系,LEN函數返回指定字符串表達式的字符數,其中

不包含尾隨空格。所以這個腳本是無法排查表名或字段名前面包含空格的。如果要排查這種情況,就需要使用下面SQL腳本(中間包含空格在此略過,這個不符合命名規則):

SELECT * FROM sys.columns WHERE NAME LIKE ' %' --字段前面包含空格。

SQLServer,表名,列名,空格,代碼

其實到了這一步,還沒有完,如果一個實例,里面有十幾個數據庫,那么使用上面這個腳本,我要切換數據庫,執行十幾次,對于我這種懶人來說,我覺得無法忍受的。那么必須寫

一個腳本,將所有數據庫全部檢查完。本來想用sys.sp_MSforeachdb,但是這個內部存儲過程有一些限制,遂寫了下面腳本。

DECLARE @db_name NVARCHAR(32);DECLARE @sql_text NVARCHAR(MAX); DECLARE @db TABLE ( database_name NVARCHAR(64)); IF OBJECT_ID('tempdb.dbo.#TabColums') IS NOT NULL  DROP TABLE dbo.#TabColums; CREATE TABLE #TabColums( object_id   INT , column_id   INT);  INSERT INTO @dbSELECT name FROM sys.databases WHERE state_desc='ONLINE' AND database_id !=2;  WHILE (1=1)BEGIN SELECT TOP 1 @db_name = database_name FROM @db ORDER BY 1;  IF @@ROWCOUNT = 0 RETURN;  SET @sql_text =N'USE ' + @db_name +';      TRUNCATE TABLE #TabColums;       INSERT INTO #TabColums     SELECT object_id ,       column_id     FROM sys.columns     WHERE DATALENGTH(name) != LEN(name) * 2;         SELECT ''' + @db_name + ''' AS DatabaseName,       TL.name AS TableName ,       C.name AS FieldName ,       T.name AS DataType ,       DATALENGTH(C.name) AS COLUMN_DATALENGTH ,       LEN(C.name) AS COLUMN_LENGTH ,       CASE WHEN C.max_length = -1 THEN ''Max''         ELSE CAST(C.max_length AS VARCHAR)       END AS Max_Length ,       CASE WHEN C.is_nullable = 0 THEN ''×''         ELSE ''√''       END AS Is_Nullable ,       C.is_identity ,       ISNULL(M.text, '''') AS DefaultValue ,       ISNULL(P.value, '''') AS FieldComment     FROM sys.columns C       INNER JOIN sys.types T ON C.system_type_id = T.user_type_id       LEFT JOIN dbo.syscomments M ON M.id = C.default_object_id       LEFT JOIN sys.extended_properties P ON P.major_id = C.object_id                 AND C.column_id = P.minor_id       INNER JOIN sys.tables TL ON TL.object_id = C.object_id       INNER JOIN #TabColums TC ON C.object_id = TC.object_id              AND C.column_id = TC.column_id     ORDER BY C.column_id ASC;';  PRINT(@sql_text);   EXECUTE(@sql_text);   DELETE FROM @db WHERE database_name=@db_name; END TRUNCATE TABLE #TabColums;DROP TABLE #TabColums;

另外,對應表名而言,可以使用下面腳本。在此略過,不做過多介紹!

DECLARE @db_name NVARCHAR(32);DECLARE @sql_text NVARCHAR(MAX); DECLARE @db TABLE ( database_name NVARCHAR(64));   INSERT INTO @dbSELECT name FROM sys.databases WHERE state_desc='ONLINE' AND database_id !=2;  WHILE (1=1)BEGIN SELECT TOP 1 @db_name = database_name FROM @db ORDER BY 1;  IF @@ROWCOUNT = 0 RETURN;  SET @sql_text =N'USE ' + @db_name +';               SELECT ''' + @db_name + ''' as database_name, name,        DATALENGTH(name) as table_name_bytes,       LEN(name)   as table_name_character,       type_desc,create_date,modify_date      FROM sys.tables     WHERE DATALENGTH(name) != LEN(name) * 2;     ';  PRINT(@sql_text);   EXECUTE(@sql_text);   DELETE FROM @db WHERE database_name=@db_name; END

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品69精品一区二区三区| 欧美高清视频一区二区| 亚洲天堂影视av| 久久人体大胆视频| 中文字幕免费精品一区| 欧美日韩国产专区| 91日韩在线视频| 91九色视频导航| 亚洲欧美综合图区| 久久久999精品免费| 国产精品久久久久久av福利软件| 亚洲天堂免费在线| 性亚洲最疯狂xxxx高清| 亚洲国产另类 国产精品国产免费| 精品国产1区2区| 日韩av一区在线观看| 欧美区在线播放| 欧美性生交大片免费| 日韩在线国产精品| 亚洲欧美国产日韩中文字幕| 亚洲va欧美va国产综合剧情| 久久久久久久久久久国产| 国产精品一区专区欧美日韩| 亚洲热线99精品视频| 2018中文字幕一区二区三区| 欧美亚洲午夜视频在线观看| 久久精品在线播放| 欧美国产日产韩国视频| 成人黄色大片在线免费观看| 国产精品色悠悠| 午夜精品视频在线| 91欧美激情另类亚洲| 欧美成人午夜影院| 亚洲天堂久久av| 91手机视频在线观看| 日韩久久精品成人| 国产午夜精品全部视频在线播放| 欧美精品九九久久| 国产午夜精品免费一区二区三区| 日本一区二区不卡| 久久久久久av| 亚州成人av在线| 欧美做受高潮电影o| 亚洲a成v人在线观看| 91av在线看| 亚洲欧美日韩另类| 国产精品久久久久久久久男| 91精品国产色综合| 日韩在线视频观看| 精品国产91久久久久久老师| 亚洲欧美综合区自拍另类| 亚洲色图国产精品| 欧美大片网站在线观看| 国产成人jvid在线播放| 日韩一区av在线| 亚洲国产精久久久久久久| 中文字幕欧美精品日韩中文字幕| 亚洲精品一区中文| 91精品国产九九九久久久亚洲| 欧美孕妇孕交黑巨大网站| 久久精品男人天堂| 国产精品大片wwwwww| 国产91成人video| 日韩精品免费综合视频在线播放| 精品欧美aⅴ在线网站| 欧美性猛交丰臀xxxxx网站| 久久久久久亚洲精品中文字幕| 国精产品一区一区三区有限在线| 色噜噜久久综合伊人一本| 欧美日韩亚洲视频一区| 中文字幕日韩精品在线观看| 自拍偷拍亚洲欧美| 国产精品亚洲片夜色在线| 欧美日本中文字幕| 国产亚洲aⅴaaaaaa毛片| 欧美中文在线观看国产| 国产精品国产三级国产专播精品人| 欧美极度另类性三渗透| 国产伊人精品在线| 综合国产在线观看| 欧美在线视频网站| 中文字幕日韩在线播放| 亚洲精品综合久久中文字幕| 一本色道久久综合亚洲精品小说| 久久国产精品久久久久久| 欧美成人久久久| 日韩av影院在线观看| 蜜月aⅴ免费一区二区三区| 欧美日韩另类视频| 色综合亚洲精品激情狠狠| 亚洲欧美成人一区二区在线电影| 欧美精品成人在线| 岛国av一区二区在线在线观看| 国产日韩欧美视频| 亚洲第一中文字幕| 国产欧美日韩精品丝袜高跟鞋| 亚洲福利视频久久| 在线观看国产精品日韩av| 亚州av一区二区| 亚洲图片欧洲图片av| 97在线看免费观看视频在线观看| 91国产视频在线| 91亚洲精品久久久久久久久久久久| 日韩av影院在线观看| 午夜精品福利在线观看| 日韩国产欧美精品一区二区三区| 国产日韩综合一区二区性色av| 国产精品免费观看在线| 91中文字幕一区| 97精品伊人久久久大香线蕉| 日韩经典一区二区三区| 亚洲理论电影网| 精品一区二区三区电影| 久久久久国色av免费观看性色| 日本aⅴ大伊香蕉精品视频| 精品毛片网大全| 久久在线免费观看视频| 欧美成人精品一区二区三区| 久久色在线播放| 国产精品美女午夜av| 日本高清+成人网在线观看| 国产成人精品在线| 亚洲最大中文字幕| 国产日韩欧美成人| 黑丝美女久久久| 国自产精品手机在线观看视频| 日本精品久久久| 国产日本欧美一区二区三区在线| 91在线播放国产| 亚洲成人在线视频播放| 国产噜噜噜噜噜久久久久久久久| 亚洲欧美国产另类| 久久久人成影片一区二区三区| 久久影视电视剧凤归四时歌| 色偷偷噜噜噜亚洲男人| 国产精品成熟老女人| 日韩欧美国产中文字幕| 亚洲娇小xxxx欧美娇小| 久久99青青精品免费观看| 日韩在线观看免费高清完整版| 久久偷看各类女兵18女厕嘘嘘| 欧美激情三级免费| 亚洲性视频网址| 一区二区成人精品| 欧美日韩一区二区免费在线观看| 夜色77av精品影院| 精品久久久久久久久久久久| 久久久免费高清电视剧观看| 国产一区二区三区视频免费| 亚洲男人天堂九九视频| 日韩精品视频中文在线观看| 亚洲成人av中文字幕| 日韩av有码在线| 欧美黄网免费在线观看| 国产精品成人品| 欧美成人网在线| 日韩中文有码在线视频| 国产91精品最新在线播放| 亚洲成av人片在线观看香蕉| 欧洲成人免费视频| 中文字幕亚洲激情| 91久久久国产精品| 久久99久久99精品中文字幕| 亚洲精品电影在线观看|