当前位置:首页 » 存储配置 » sql存储过程like

sql存储过程like

发布时间: 2022-07-19 18:34:50

sql SERVER 2005 存储过程中怎样使用 like.

这个应该是说看表是否有外键关系。方法是,在SQL
SERVER
2005的Management但反复执行的动态SQL,可以使用临时存储过程,该过程(临时表)被放在Tempdb中。

② sql存储过程中,模糊查询的写法

ALTER PROCEDURE [dbo].[pro_Search_keys]
@keys nvarchar(max)
AS
BEGIN
SELECT*
FROM text_Text
where Title like ‘%’+@keys+‘%’
END

③ SQL:存储过程中的like问题!

like '%'+rtrim(@para1)+'%'

④ SQL存储过程(含变量)like语句实现不了

@Depart char
首先不要用char,除非你能明确确定字数
其次字符类型一定要标注长度
改为@Depart nvarchar(20)试试

⑤ 关于sql存储过程的相似查询

因为like @date这样将@date整体看做一个变量,或者说将其内部代表的值看做变量,%不在是通配符,而是被转义为一个普通字符

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

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

⑦ sql语句执行指定存储过程在参数字符串中加like对引号的处理

当前有一存储过程
执行的时候
exec
的第一个参数需要加like语句

exec
proc_page
'info2
where
id
not
in(
select
top
(0)
id
from
info2
where
centerclass=152
and
bigcity=1
and
centercity=7
order
by
id
desc)
and
bigcity=1
and
centercity=7
and
centerclass=152
and
smallsubclassinfo
like
''%'||小型犬||'%''
'
,'*',10,10,'id',1,'','id',0
请问对like旁的单引号大家都如何处理才能使存储过程正确执行?

⑧ SQL 存储过程

仔细思考一下我的解决办法是否妥当:

因为过程开头部分已经定义了4个变量,并且都赋初值为'0',

那么,我们做两处变动:

1、在你的select语句执行前,我们写上4个判断,判断这4个变量是否被传入了值,未传入时怎么样处理。

2、修改select语句的where子句(语句中有三个“=”改成like)。

过多的描述也许难以看懂,我直接写出来,新增或修改的部分,我在后面用了注释“//--★”(我的写法是基于Sybase的,你可以看懂的。当然你也可以先看一下后面的【总结】):

if exists(………………………………)
drop ……………………
go
create Proc Proc_ManualSign
@BranchId varchar(10) = '0',
……………………
……………………
@UserName varchar(50) = '0'
as

begin //--★sybase写法,用于过程开始,参考你的数据库,看是否需要加

if @BranchId = '0' //--★如果@BranchId依然为初始值(未传入参数)
select @BranchId = '%' //--★那么将@BranchId赋值为'%'

if @DepartId = '0' //--★如果@DepartId依然为初始值(未传入参数)
select @DepartId = '%' //--★那么将@DepartId赋值为'%'

if @UserId = '0' //--★如果@UserId依然为初始值(未传入参数)
select @UserId = '%' //--★那么将@UserId赋值为'%'

if @UserName = '0' //--★如果@UserName依然为初始值(未传入参数)
select @UserName = '%' //--★那么将@UserName赋值为'%'

select …………
……………………
and b.BranchId like @BranchId --机构 //--★你原来的“=”改成了“like”
and d.DepartId like @DepartId --部门 //--★你原来的“=”改成了“like”
and m.UserId like @UserId --用户Id //--★你原来的“=”改成了“like”
and u.UserName like '%'+@UserName+'%' --用户名

end //--★sybase写法,用于标注过程结束,参考你的数据库,看是否需要加

go

======================================================================

【★★--总结--★★】我的办法:

4个变量初值为'0',excute执行该过程时,if语句就要依次判断各变量的当前值,判断的结果无非两种:①.未传入值(还是'0'),②.传入了值(不是'0')

①.未传入值
if语句判断出某变量未传入值,则将该变量置为'%',那么select语句的where条件中就是该字段 like '%',也就是该字段的检索条件为任意的。

②.传入了值
传入了值,则if语句的判断结果为假(False),那么直接跳出判断去执行select语句,虽然where子句的条件中用的是 like 介词,但没有通配符'%'的话,like 的作用也就是'=',即:【like '销售部'】的作用也就是 【='销售部'】,所以也满足了输入参数的精确查询要求。

执行时:

假如什么参数也不传入,即:查询全部的信息
excute Proc_ManualSign '0', '0', '0', '0'

假如仅部门和用户ID传入参数,则
excute Proc_ManualSign '0', '开发部', '319', '0'

⑨ 在SQL中存储过程的一般语法是什么

1、 创建语法

createproc|procerepro_name

[{@参数数据类型}[=默认值][output],

{@参数数据类型}[=默认值][output],

....

]

as

SQL_statements

2、 创建不带参数存储过程

--创建存储过程

if(exists(select*fromsys.objectswherename='proc_get_student'))

dropprocproc_get_student

go

createprocproc_get_student

as

select*fromstudent;

--调用、执行存储过程

execproc_get_student;

3、 修改存储过程

--修改存储过程

alterprocproc_get_student

as

select*fromstudent;

4、 带参存储过程

--带参存储过程

if(object_id('proc_find_stu','P')isnotnull)

dropprocproc_find_stu

go

createprocproc_find_stu(@startIdint,@endIdint)

as

select*fromstudentwhereidbetween@startIdand@endId

go

execproc_find_stu2,4;

5、 带通配符参数存储过程

--带通配符参数存储过程

if(object_id('proc_findStudentByName','P')isnotnull)

dropprocproc_findStudentByName

go

createprocproc_findStudentByName(@namevarchar(20)='%j%',@nextNamevarchar(20)='%')

as

select*fromstudentwherenamelike@nameandnamelike@nextName;

go

execproc_findStudentByName;execproc_findStudentByName'%o%','t%';

(9)sql存储过程like扩展阅读:

SQL存储过程优点:

1、重复使用。存储过程可以重复使用,从而可以减少数据库开发人员的工作量。

2、减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此降低了网络传输的数据量。

3、安全性。参数化的存储过程可以防止SQL注入式攻击,而且可以将Grant、Deny以及Revoke权限应用于存储过程。

热点内容
浏览器上传不了图片 发布:2025-01-16 14:45:46 浏览:599
汽车是哪个配置的怎么看 发布:2025-01-16 14:43:47 浏览:50
唱吧上传原唱 发布:2025-01-16 14:30:36 浏览:300
负载均衡后端服务器获取真实ip 发布:2025-01-16 14:30:26 浏览:655
linux系统centos如何配置网络 发布:2025-01-16 14:22:32 浏览:600
java培训浙江 发布:2025-01-16 14:13:40 浏览:934
配置型基金如何分配 发布:2025-01-16 14:08:06 浏览:563
adbandroid版本 发布:2025-01-16 13:53:14 浏览:388
直链云存储 发布:2025-01-16 13:19:30 浏览:727
电脑主机服务器多少钱 发布:2025-01-16 13:00:28 浏览:668