|
|
 |
专题栏目 |
 |
 |
相关文章 |
 |
|
|
|
|
 |
SQL分隔字符串的存储过程 |
热 |
|
| SQL分隔字符串的存储过程 |
|
作者:Not 文章来源:不详 点击数: 更新时间:2007-11-14 10:59:24  |
|
我在做一个项目时研究了查询多个关键字的技术,这是其中用到的一个技术。
“分隔字符串”存储过程的作用就是把“jiangjs,shenxy,cheng”类的字符串隔开保存到一个表中。
CREATE PROCEDURE [分隔字符串] ( @String NVARCHAR(1000), -- 要分隔的字符串 @SPLITCHAR NVARCHAR(10) = '''','''', -- 分隔字符 @TableName NVARCHAR(50), -- 存入的表名称 @FieldName NVARCHAR(50) = ''''[ID]'''' -- 存入的字段名称 ) AS
-- 将字符串分隔开放进表中
DECLARE @L INT -- 第一个分隔字符的位置 DECLARE @S INT -- 第二个分隔字符的位置 SET @L = 0 SET @S = CHARINDEX(@SPLITCHAR, @String, @L)
WHILE @L <= LEN(@String) BEGIN DECLARE @ID NVARCHAR(50)
IF @S = 0 SET @S = LEN(@String) + 1 -- 如果到最后一个字符串那么第二个分隔字符的位置就是这个字符串的长度加一 SET @ID = SUBSTRING(@String, @L, @S - @L) -- 取值 SET @L = @S + 1 SET @S = CHARINDEX(@SPLITCHAR, @String, @L)
IF LTRIM(RTRIM(@ID)) = '''''''' CONTINUE -- 如果是空字符串就跳过
DECLARE @SQL NVARCHAR(1000) SET @SQL = ''''INSERT INTO '''' + @TableName + '''' (''''+ @FieldName +'''') VALUES('''''''''''' + @ID + '''''''''''')'''' EXEC sp_executesql @SQL END GO
----------
Not
MSN Messenger : notking@hotmail.com
|
|
| 文章录入:mintao 责任编辑:mintao |
|
|
上一篇文章: 使用正则表达式检验sql语句(只支持select(不含函数,子查询)) 下一篇文章: PL/SQL中的几种异常处理方法 |
|
|
| 【字体:小 大】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 |
|
注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网] |
网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) |
| |
|
|
|
|