繁体   English   中英

SQL Server中搜索功能的快捷方式

[英]Shortcut for search functionality in SQL Server

我想为下面的SQL代码创建快捷方式

DECLARE @Proc_Name VARCHAR(255)
SET @Proc_Name ='norway'
SELECT * FROM sys.tables WHERE name LIKE '%' + @Proc_Name + '%'

现在我正在使用以下快捷方式 在此处输入图片说明

然后,我输入{LIKE'%test%'},然后按Ctrl + 8。

但是我想使其更加简化(例如,我可以键入{test}并按Ctrl + 8),以便可以快速使用它。

我尝试以不同的方式进行尝试,例如创建proc>然后执行>并将其放在快捷键上。 有关更多信息,请访问以下链接:

单行GO(Batch)语句在SQL Server中给出错误?

谢谢,

维沙尔

我将以下存储的过程添加到SQL Server的主数据库中

USE [master]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

CREATE PROCEDURE [dbo].[SP_FindAllReferences]
@targetText nvarchar(128)
AS
BEGIN
    SET NOCOUNT ON;

    declare @origdb nvarchar(128)
    select @origdb = db_name()

    declare @sql nvarchar(1000)

    set @sql = 'USE [' + @origdb +'];' 
    set @sql += 'select object_name(m.object_id), m.* '
    set @sql += 'from sys.sql_modules m  where m.definition like N' + CHAR(39) + '%' + @targetText + '%' + CHAR(39)

    exec (@sql)

    SET NOCOUNT OFF;
END

然后,将dbo.SP_FindAllReferences添加到了我的SSMS键盘快捷方式之一,以便可以在服务器上任何数据库的上下文中搜索文本。

例如,如果我在SSMS查询窗口中键入user ,突出显示它并按下快捷键组合,那么我会得到包含用户的当前数据库中每个已存储proc的列表。

如果您将我的选择替换为

set @sql = 'USE [' + @origdb +'];' 
set @sql += 'Select * FROM sys.tables WHERE name LIKE N' + CHAR(39) + '%' + @targetText + '%' + CHAR(39)

这样您就可以实现自己的目标。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM