打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
自己动手写SQL字符串分解函数Split

  前段时间,在做一个可以批量审核或删除数据的功能时,遇到这么个问题:

  因为审核或删除操作是在存储过程进行的,所以,就打算将选中的数据的主键拼成字符串,传到存储过程进行分离,再继续处理。

  C#中和JavaScript中都有相应的分离字符串的Split函数,就想当然的以为SQL中也会有类似的函数,结果查了半天的MSSQL帮助文档,也没找到。

  没办法,只好自己写了,在网上搜了下相关的,看了一两篇关于SQL分离字符串的自定义函数的文章,结果,有点失望,可能是自己水平差,或者是因为人家的代码没写注释吧,总之就是看着挺吃力的,还没看完就决定自己写了。。。

  思路很简单:在需要分解的字符串中,如果存在指定的分隔符,则将第一个分隔符前面的字符串取出,存入表内,然后在需要分解的字符串中将已取出的字符串及第一个分隔符删除,然后继续下一次分解(如果还存在指定的分隔符,就分解)

  以下是SQL:

按 Ctrl+C 复制代码
按 Ctrl+C 复制代码

  (分隔符允许是多位的)

  按一般的习惯来说,在组织多个字符串时,一般都是这种写法:strKeys += strSingleKey + ",";

  所以可能最终该字符串可能会以逗号结尾,如果组织完成后,将结尾的逗号去掉了,那就不会以逗号结尾,所以,在循环分解完成后,如果剩下的原字符串中(去除左右空格后),如果还有内容 ,则也应该存入表中。  

  可能我这种写法不是最好的,也可能会有问题,如确实有需要改进的,还请指出,不胜感激!!!

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
示例详解VBA的Split函数
T-SQL象数组一样处理字符串、分割字符串
SQL SERVER比较一个字符串中是否含含另一个字符串中的一个字符
巧用SQL:Oracle中实现split相关方法总结
sqlserver中,如何把一列中的多行数据在一行显示
SQL SERVER:select 字符串拼接问题
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服