sql 数据库中只靠一个数据,查询到所在表和列名
生活随笔
收集整理的這篇文章主要介紹了
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 数据库中只靠一个数据,查询到所在表和列名的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JAVA异常处理分析(中)
- 下一篇: vi相关操作