怎么浅析SQLServer中的Scanf与Printf

发布时间:2021-12-20 15:13:52 作者:柒染
来源:亿速云 阅读:159

怎么浅析SQLServer中的Scanf与Printf,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

SQLServer中有两个扩展存储过程实现Scanf和Printf功能,恰当的使用它们可以在提取和拼接字符串时大幅度简化SQL代码。1、xp_sscanf,用它可以分解格式相对固定的字符串,这对于厌倦使用一堆substring和charindex的朋友来说不错。比如前几天的一个帖子中提出的如何分解ip地址,相对简练且通用的代码应该是下面这样

代码如下: 

if (object_id ('f_getip' ) is not null )drop function f_getip go create function dbo . f_getip (@ ip varchar (100 ))returns @ t table (a int , b int , c int , d int )as begin  set @ ip = replace (@ ip , '.' , ' ' ) 

declare  @ s1 varchar (3 ) , @ s2 varchar (3 ),  @ s3 varchar (3 ) , @ s4 varchar (3 ) exec xp_sscanf @ ip , 

'%s %s %s %s' , 

@ s1 output , @ s2 output , @ s3 output , @ s4 output  insert into 

@ t select @ s1 , @ s2 , @ s3 , @ s4  return end go select * from dbo . f_getip ('192.168.0.1' )go /* a b c d 

----------- ----------- ----------- ----------- 192 168 0 1 */

2、xp_sprintf,用它可以拼接出一个字符串而不用担心过多的加号很引号难以控制,比如一个动态执行sql语句的存储过程

 代码如下: 

if (object_id ('p_select' ) is not null )drop proc p_select go create proc p_select (@ tb varchar (100 ), 

@ cols varchar (100 ), 

@ wherecol varchar (100 ), 

@ value varchar (100 ))as begin  declare 

@ s varchar (8000 ) exec xp_sprintf @ s output ,

 'select %s from %s where %s=''%s''' , 

@ cols , @ tb , @ wherecol , @ value  exec (@ s)end go exec p_select 'sysobjects' , 'id,xtype,crdate' , 'name' , 'p_select' /* id xtype crdate 

----------- ----- ----------------------- 898102240 P 2009-08-18 03:01:51.153 */

看完上述内容,你们掌握怎么浅析SQLServer中的Scanf与Printf的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

推荐阅读:
  1. printf & scanf函数
  2. scanf()函数中*的用法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sqlserver scanf printf

上一篇:如何进行MySQL Memory 存储引擎的浅析

下一篇:UML之时序图的示例分析

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》