sql语句过滤百分号的主意分享,批量删减所有存储进程的法门分享

转自: 

转自:

转自:http://www.maomao365.com/?p=6864

摘自:

摘要:

下文讲述sql脚本中过滤百分号的不二法门:


实验环境:sql server 2008 R2 


摘要:

sql语句过滤百分号的主意分享,批量删减所有存储进程的法门分享。摘要:
下文介绍sql server中,sql脚本幸免出现除零不当的点子分享


下文讲述选取sql脚本批量剔除所有存储进程的措施,如下所示:
试行环境:sqlserver
2008 R2


百分号:在sql脚本编写中“百分号”被限定为一种通配符,那么只要我们需寻找数据中是还是不是存在百分号时,需利用何种措施呢?
下文通过实例的措施分析百分号的协作格局。
 

摘要:


在各个事情种类开发中,平常会蒙受除零的失实,下文分享了三种处理措施:
方法1: case when end 

1        ---在sql server中,如果需要检索百分号是否存在数据中,我们使用以下方法:
2       ---方法1:中括号括起百分号进行过滤操作
3            select * from tableName where [列名]  like '%[%]%'  ---采用中括号括起百分号
4       ---方法2.1:  采用escape指定匹配条件中转义字符为~,对百分号进行转义查询
5        select *,'1.2' as [例2] from tableName where [列名]  like '%~%%'   escape '~' 
6         ---2.2采用escape指定匹配条件中转义字符为t,对百分号进行转义查询
7        select *,'1.3' as [例3] from tableName where [列名]  like '%t%%'   escape 't'
8  

下文将享受应用sql脚本输出excel的法门
 
此脚本可以运用于 表或视图生成excel的艺术,
若需使用sql脚本输出excel数据,我们可将sql脚本生成视图或临时表,

平日使用sql脚本,删除存储过程,我们只可以动用删除命令一条一条的删除存储进程,下文介绍一种便利方法,可以对系统中持有的储存进程进行删除,
<span style=”color:red;”>
心想事成思路:
1 选拔临时表将积存进程名称缓存
2 通过巡回临时表,输出删除存储进度脚本
3 执行脚本

declare @a int ---分子
declare @b int ---分母
select  case  when @b=0 then NULL else @a/@b end  as [a除以b]

 

下一场再输出excel

输出excel语法简介:
exec
master..xp_cmdshell ‘bcp
[数据库名称].[架构名].[表名] out [excel存放地点全路线] -c -q
-S”服务器Ip” -U “sql用户名” -P “sql密码”‘

---例1:
exec 
master..xp_cmdshell 'bcp test.dbo.tableName out d:\test.xls -c -q -S"." -U "sa" -P "erp"'
---将数据库test中tablName输出值d盘test.xls文件
---服务器地址.
---sql账户sa
---sql密码erp
--------------------------------------------
例2: 根据动态文件名输出excel的方法
declare @name varchar(30) ---动态文件名
set @name ='d:\test123.xlsx'

exec 
('master..xp_cmdshell ''bcp test.dbo.tableName out '+@name+' -c -q -S"." -U "sa" -P "erp"''') ---拼接操作语句,并采用exec执行

注意事项:

*1 使用脚本输出的excel ,无表头
2
可动态文件名和动态sa账户密码生成相关音信
997755.com澳门葡京,3
若是出口sql脚本的数目至excel,大家需先将sql脚本生成的数码缓存至表中,然后输出表数据至excel

xp_cmdshell相关权力需打开
*

declare @t table(keyId int identity(1,1),tableName varchar(256))
----生成临时表
insert into @t(tableName) 
select [name] from sysobjects where type='P'

declare @i int @iMax int ,@info varchar(256)
set @i =1 
select @imax=max(keyId) from @t as t

while @i <@imax
begin
select @info = t.tableName from @t as t where t.keyId =@i

if @info is not null 
begin
exec ('drop proc '+@info) ---遍历删除存储过程
end 

set @i = @i+1 
set @info =null 
end

 

方法2:nullif
nullif(表达式A,表达式B)
—-如果表明式A不等于表明式B,则赶回表明式A
—-反之再次回到NULL 

 

declare @a int ---分子
declare @b int ---分母
select @a/nullif(@b,0) as [a除以b]

 

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*
*
Website