有关SQL存储过程变量模糊查询

2024年12月01日 09:55
有2个网友回答
网友(1):

小菜一叠啦^_^

DECLARE @CaseID varchar(256)
SET @CaseID = '125'
SELECT * FROM [tb_tableName] WHERE 字段ID LIKE '%['+@CaseID+']%'

上面这个正则查询就可以满足你的要求呀

DECLARE @CaseID varchar(256)
SET @CaseID = '19999'
SELECT * FROM [tb_aTemp] WHERE 字段ID LIKE '%['+@CaseID+']%'

TO:我用一个变量在SQL存储过程中可以返回一个结果.现在是想通过执行存储过程一次性返回多个结果,请问变量该怎么定义?

RE:

CREATE PROCEDURE SP_tableName(
@CaseID NVARCHAR(50)
)
AS
BEGIN
SET NOCOUNT ON
DECLARE INT @Identity
SET @Identity = 0
INSERT INTO [tb_tableName] (CaseID)VALUES(@CaseID)
SET @Identity = SCOPE_IDENTITY()

IF (@Identity)>0
BEGIN
SELECT * FROM [tb_tableName] --这里根据你的查询条件,返回的多个需要的得到的字段
END
SET NOCOUNT OFF
END
GO

-- 程序调用的时候用 DataSet 来获得多个你需要的字段值,如果 DataSet 返回 0 或者抛出异常则插入数据失败

-- 带返回值的

CREATE PROCEDURE SP_tableName(
@CaseID NVARCHAR(50),
@Identity INT OUTPUT
)
AS
BEGIN
SET NOCOUNT ON
INSERT INTO [tb_tableName] (CaseID)VALUES(@CaseID)
SET @Identity = SCOPE_IDENTITY()

IF (@Identity)>0
BEGIN
SELECT * FROM [tb_tableName] --这里根据你的查询条件,返回的多个需要的得到的字段
END
SET NOCOUNT OFF
RETURN @Identity
END
GO

-- 程序调用的时候用 DataSet 来获得多个你需要的字段值, 并可获得刚插入的自动编号输出参数
-- 如果 DataSet 返回 0 ,或者 @Identity 返回0, 或者 DataSet 抛出异常则插入数据失败

首先你要明白模糊查询和精确查询的概念,试想百度,GOOGLE的技术力量那么专业强大,其模糊查询的结果不同样也存在很多很多的冗余数据吗

CaseID like '%['+@CaseID+']%' 结果当然是贪婪模式

当然,你也可以采用如下方法使其尽可能的接近目标匹配:

%
_
[]
[^]
等等...........

如果精确查询,必须

CaseID=@CaseID

或者

CaseID IN (@CaseID)

在模糊查询的情况下,解决重复数据的唯一方法就是再增加一个(或N个)查询条件

网友(2):

select
*
from
user
where
user_name
like
'%'
||
变量
||
'%'
这样写就可以了。