婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > SQL Server查找表名或列名中包含空格的表和列實(shí)例代碼

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

熱門標(biāo)簽:外呼系統(tǒng)電銷專用 怎樣在地圖上標(biāo)注路線圖標(biāo) 智能語(yǔ)音外呼系統(tǒng)選哪家 優(yōu)質(zhì)地圖標(biāo)注 千呼電銷機(jī)器人價(jià)格 百度地圖標(biāo)注不同路線 京華物流公司地圖標(biāo)注 奧威地圖標(biāo)注多個(gè)地方 武漢長(zhǎng)沙外呼系統(tǒng)方法和技巧

前言

本文主要給大家介紹的是關(guān)于SQL Server查找包含空格的表和列的相關(guān)內(nèi)容,為什么會(huì)有這篇文章,是因?yàn)樽罱l(fā)現(xiàn)一個(gè)數(shù)據(jù)庫(kù)中的某個(gè)表有個(gè)字段名后面包含了一個(gè)空格,這個(gè)空格引起了一些小問(wèn)題,一般出現(xiàn)這種情況,是因?yàn)閯?chuàng)建對(duì)象時(shí),使用雙引號(hào)或雙括號(hào)的時(shí)候,由于粗心或手誤多了一個(gè)空格,如下簡(jiǎn)單案例所示:

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

實(shí)現(xiàn)方法:

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

 DATALENGTH(name) = 2* LEN(name)
SELECT name ,
 DATALENGTH(name) AS NAME_BYTES ,
 LEN(name)  AS NAME_CHARACTER
FROM sys.columns
WHERE object_id = OBJECT_ID('TEST_COLUMN');
 

clip_image001

 

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

IF OBJECT_ID('tempdb.dbo.#TabColums') IS NOT NULL
 DROP TABLE dbo.#TabColums;
 
CREATE TABLE #TabColums
(
 object_id   INT ,
 column_id   INT
)
 
INSERT INTO #TabColums
SELECT object_id ,
  column_id
FROM sys.columns
WHERE 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 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

那么為什么表名TEST_TABLE的三個(gè)字段里面,前面包含空格與與中間包含空格都識(shí)別不出來(lái)呢?這個(gè)與數(shù)據(jù)庫(kù)的LEN函數(shù)有關(guān)系,LEN函數(shù)返回指定字符串表達(dá)式的字符數(shù),其中

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

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

 

其實(shí)到了這一步,還沒有完,如果一個(gè)實(shí)例,里面有十幾個(gè)數(shù)據(jù)庫(kù),那么使用上面這個(gè)腳本,我要切換數(shù)據(jù)庫(kù),執(zhí)行十幾次,對(duì)于我這種懶人來(lái)說(shuō),我覺得無(wú)法忍受的。那么必須寫

一個(gè)腳本,將所有數(shù)據(jù)庫(kù)全部檢查完。本來(lái)想用sys.sp_MSforeachdb,但是這個(gè)內(nèi)部存儲(chǔ)過(guò)程有一些限制,遂寫了下面腳本。

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 @db
SELECT 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;

另外,對(duì)應(yīng)表名而言,可以使用下面腳本。在此略過(guò),不做過(guò)多介紹!

DECLARE @db_name NVARCHAR(32);
DECLARE @sql_text NVARCHAR(MAX);
 
DECLARE @db TABLE 
(
 database_name NVARCHAR(64)
);
 
 
 
INSERT INTO @db
SELECT 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

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • SQLServer行轉(zhuǎn)列實(shí)現(xiàn)思路記錄
  • SQL Server將一列的多行內(nèi)容拼接成一行的實(shí)現(xiàn)方法
  • Sql Server 2000 行轉(zhuǎn)列的實(shí)現(xiàn)(橫排)
  • sqlserver2005 行列轉(zhuǎn)換實(shí)現(xiàn)方法
  • sqlserver下將數(shù)據(jù)庫(kù)記錄的列記錄轉(zhuǎn)換成行記錄的方法
  • sqlserver 行列互轉(zhuǎn)實(shí)現(xiàn)小結(jié)
  • SQLServer行列互轉(zhuǎn)實(shí)現(xiàn)思路(聚合函數(shù))
  • SQL Server行轉(zhuǎn)列的方法解析

標(biāo)簽:益陽(yáng) 威海 天水 來(lái)賓 防疫戰(zhàn)設(shè) 銅仁 七臺(tái)河 宿州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server查找表名或列名中包含空格的表和列實(shí)例代碼》,本文關(guān)鍵詞  SQL,Server,查找,表名,或,列名,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server查找表名或列名中包含空格的表和列實(shí)例代碼》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于SQL Server查找表名或列名中包含空格的表和列實(shí)例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美午夜精品理论片a级按摩| 日本欧美肥老太交大片| 精品国产一区二区三区久久影院 | 国产精品1024| 国产乱码精品一区二区三区忘忧草 | 精品国产91乱码一区二区三区| 国产三级一区二区三区| 亚洲一线二线三线视频| 精品一区二区久久| 欧美日韩国产a| 一区二区在线免费| 国产精品影视天天线| 欧美日韩成人高清| 成人免费小视频| 精品午夜一区二区三区在线观看| 欧美性生活大片视频| 一区二区三区精品在线| 国产真实精品久久二三区| 欧美日韩极品在线观看一区| 国产精品美女久久久久久2018| 精油按摩中文字幕久久| 色94色欧美sute亚洲13| 日韩av高清在线观看| 日本丶国产丶欧美色综合| 91网站视频在线观看| 久久综合五月天婷婷伊人| 五月天激情小说综合| 91小宝寻花一区二区三区| 亚洲欧洲日产国码二区| av亚洲精华国产精华精华| 国产欧美一区二区精品久导航| 国产午夜精品一区二区三区视频| 亚洲欧美影音先锋| 欧美在线|欧美| 日日夜夜免费精品视频| 国产精品白丝在线| 91美女精品福利| 色狠狠色狠狠综合| 亚洲激情欧美激情| 91免费视频大全| 91猫先生在线| 在线中文字幕一区二区| 欧美电影影音先锋| 欧美激情在线看| 国内精品免费在线观看| 免费成人在线观看视频| 亚洲不卡一区二区三区| 热久久免费视频| 亚洲婷婷综合久久一本伊一区 | 亚洲激情中文1区| 久久久久国产精品麻豆| 国产欧美视频在线观看| 午夜婷婷国产麻豆精品| 国产精品国产三级国产普通话蜜臀| 国产99久久久久久免费看农村| 在线观看91精品国产入口| 无码av免费一区二区三区试看| 欧美亚洲一区二区在线| 黄网站免费久久| 久久久激情视频| 成人免费三级在线| 国产精品午夜电影| 欧美人体做爰大胆视频| 蜜桃视频在线观看一区| 久久久久综合网| 91福利区一区二区三区| 韩国av一区二区三区| 亚洲日本va午夜在线影院| 精品视频资源站| 懂色av中文一区二区三区| 国产精品欧美极品| 欧美日韩国产首页| 成人一二三区视频| 夜夜嗨av一区二区三区| 2023国产一二三区日本精品2022| 成人av免费在线播放| 欧美精品一区二区三区在线播放| 精品一区二区三区在线视频| 欧美电影免费观看高清完整版在| 狠狠色综合播放一区二区| 最新国产成人在线观看| 日韩美女视频一区二区在线观看| 97精品久久久午夜一区二区三区 | 日本一区二区视频在线观看| 在线视频你懂得一区二区三区| 裸体歌舞表演一区二区| 亚洲在线视频一区| 亚洲国产成人午夜在线一区| 欧美一区中文字幕| 懂色av一区二区在线播放| 久久se这里有精品| 国产精品色在线| 视频在线在亚洲| 日本不卡高清视频| 韩国成人福利片在线播放| 不卡视频一二三四| 亚洲成人一区在线| 欧美国产1区2区| 麻豆视频一区二区| 一区二区三区四区在线| 欧美网站一区二区| 国产91丝袜在线播放九色| 亚洲视频免费看| 欧美日韩一级片在线观看| 国产色产综合产在线视频| 午夜成人免费视频| 911国产精品| 国产精品久久久久久久久免费樱桃| 性欧美大战久久久久久久久| 日韩精品午夜视频| 色哟哟精品一区| 国产91精品露脸国语对白| 国产精品水嫩水嫩| 中文字幕欧美一区| 国模大尺度一区二区三区| 欧美精品自拍偷拍| 国产精品系列在线观看| 国产不卡视频一区二区三区| 99久久久久久| 91麻豆精品国产91久久久资源速度 | 欧美日韩精品欧美日韩精品一| 色噜噜夜夜夜综合网| 日韩欧美的一区| 777久久久精品| 成人av动漫在线| 欧美日韩日日骚| 欧美成人免费网站| 最新不卡av在线| 国产自产视频一区二区三区| 亚洲日本va午夜在线影院| 亚洲成av人片| 精品无人码麻豆乱码1区2区 | 亚洲综合999| 国产精品一区二区视频| 91亚洲男人天堂| 2020国产精品久久精品美国| 丁香激情综合五月| 欧美男同性恋视频网站| 欧美日韩免费不卡视频一区二区三区| 欧美午夜片在线看| 亚洲国产综合91精品麻豆| 国产精品无遮挡| 国产精品色噜噜| 亚洲精品老司机| 成人精品一区二区三区四区| 极品少妇一区二区三区精品视频 | 国产综合久久久久影院| 精一区二区三区| 国产婷婷色一区二区三区四区| 美女任你摸久久| 成人激情视频网站| 亚洲欧洲国产日韩| 日韩欧美成人激情| 久久国产三级精品| 波多野结衣欧美| 综合色天天鬼久久鬼色| 久久久91精品国产一区二区三区| 97se亚洲国产综合自在线| 国产成人三级在线观看| 色综合中文字幕国产 | 欧美日韩午夜精品| 成人免费精品视频| 欧美韩国日本综合| 亚洲chinese男男1069| 天堂久久久久va久久久久| 成人免费一区二区三区在线观看| 日韩成人免费看| 一区二区三区国产精华| 精品88久久久久88久久久| 成人在线综合网站| 午夜精品福利一区二区蜜股av| 国产日产亚洲精品系列| 麻豆91精品视频| 欧美手机在线视频| 国产美女久久久久| 韩国三级中文字幕hd久久精品| 国产综合色视频| 91视频国产资源| 国产精品免费久久| 中文字幕高清不卡| 欧美激情一区二区三区在线| 国产精品久久综合| 亚洲欧美激情插| 国产精品国模大尺度视频| 日韩成人午夜电影| 97精品电影院| 精品国产91亚洲一区二区三区婷婷| 亚洲卡通动漫在线| 中文无字幕一区二区三区 | 国产精品一二二区| 3atv一区二区三区| 欧美一区二区免费视频| 国产亚洲一区字幕| 欧美国产一区视频在线观看| 久久精品久久久精品美女| 国产精品一二三区在线| 亚洲视频一区二区免费在线观看| 91精品福利视频| 成人网页在线观看| 波多野结衣一区二区三区|