日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

sql 数据库中只靠一个数据,查询到所在表和列名

發布時間:2024/4/14 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sql 数据库中只靠一个数据,查询到所在表和列名 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

有時候我們想通過一個值知道這個值來自數據庫的哪個表以及哪個字段,在網上搜了一下,找到一個比較好的方法,通過一個存儲過程實現的。只需要傳入一個想要查找的值,即可查詢出這個值所在的表和字段名。

前提是要將這個存儲過程放在所查詢的數據庫。

注:1步驟是創建存儲過程,可以在任何一個數據庫中使用,2步驟是調用它來查找數據庫中所有牽扯到的列以及對應的表。 只需要一個數據 真是非常方便

一、首先 點擊新建查詢 ,左上角選擇到自己的數據庫,然后把下面這段復制進去 ?然后運行 CREATE?PROCEDURE?[dbo].[SP_FindValueInDB]
(
????@value?VARCHAR(1024)
)????????
AS
BEGIN
????--?SET?NOCOUNT?ON?added?to?prevent?extra?result?sets?from
????--?interfering?with?SELECT?statements.
SET?NOCOUNT?ON;
DECLARE?@sql?VARCHAR(1024)?
DECLARE?@table?VARCHAR(64)?
DECLARE?@column?VARCHAR(64)?

CREATE?TABLE?#t?(?
????tablename?VARCHAR(64),?
????columnname?VARCHAR(64)?
)?

DECLARE?TABLES?CURSOR?
FOR?

????SELECT?o.name,?c.name?
????FROM?syscolumns?c?
????INNER?JOIN?sysobjects?o?ON?c.id?=?o.id?
????WHERE?o.type?=?'U'?AND?c.xtype?IN?(167,?175,?231,?239)?
????ORDER?BY?o.name,?c.name?

OPEN?TABLES?

FETCH?NEXT?FROM?TABLES?
INTO?@table,?@column?

WHILE?@@FETCH_STATUS?=?0?
BEGIN?
????SET?@sql?=?'IF?EXISTS(SELECT?NULL?FROM?['?+?@table?+?']?'?
????SET?@sql?=?@sql?+?'WHERE?RTRIM(LTRIM(['?+?@column?+?']))?LIKE?''%'?+?@value?+?'%'')?'?
????SET?@sql?=?@sql?+?'INSERT?INTO?#t?VALUES?('''?+?@table?+?''',?'''?
????SET?@sql?=?@sql?+?@column?+?''')'?

????EXEC(@sql)?

????FETCH?NEXT?FROM?TABLES?
????INTO?@table,?@column?
END?

CLOSE?TABLES?
DEALLOCATE?TABLES?

SELECT?*?
FROM?#t?

DROP?TABLE?#t?
End

二、然后,輸入 ? ?EXEC [SP_findvalueindb] '這里是你要查的內容值' ? ?運行就ok了

例如,要查詢值'BBQ CHIC SW',結果如下:

返回三條記錄,說明這個值存在于三個表中,分別為_dts_menudef, g_dts_menudef和g_recipe中,字段名分別為name1, name1, name。

非常好用。

轉載于:https://www.cnblogs.com/javabg/p/7544790.html

總結

以上是生活随笔為你收集整理的sql 数据库中只靠一个数据,查询到所在表和列名的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。