zoukankan      html  css  js  c++  java
  • sql中的split函数的实现

    --创建一个函数,函数中有两个参数
    Create FUNCTION [dbo].[SplitToTable]
    (
    @SplitString nvarchar(max),--输入的字符串
    @Separator nvarchar(10)=' '--分割条件
    )
    --返回的数据为一个表
    RETURNS @SplitStringsTable TABLE
    (
    [id] int identity(1,1),
    [value] nvarchar(max)
    )
    AS
    BEGIN
    DECLARE @CurrentIndex int;--当前索引
    DECLARE @NextIndex int;--下一个索引
    DECLARE @ReturnText nvarchar(max);--返回内容
    SELECT @CurrentIndex=1;--设置当前索引初始值为1
    --当当前索引小于字符串长度时,执行循环体
    WHILE(@CurrentIndex<=len(@SplitString))
    BEGIN
    --CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用方法如下:
    --CHARINDEX ( expression1 , expression2 [ , start_location ] )
    -- Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。
    SELECT @NextIndex=charindex(@Separator,@SplitString,@CurrentIndex);
    IF(@NextIndex=0 OR @NextIndex IS NULL)
    SELECT @NextIndex=len(@SplitString)+1;
    --函数用法:SUBSTRING ( expression, start, length )
    SELECT @ReturnText=substring(@SplitString,@CurrentIndex,@NextIndex-@CurrentIndex);
    INSERT INTO @SplitStringsTable([value]) VALUES(@ReturnText);
    SELECT @CurrentIndex=@NextIndex+1;
    END
    RETURN;
    END
    go
    --测试函数
    select * FROm dbo.SplitToTable('a,b,c,d,e,f,g', ',')

    (本文的代码非原创,代码由本人稍作修改并且添加了注释,希望我们共同学习!)

    作者:Elaine
    交流QQ:392989505
  • 相关阅读:
    java 文件及流读取
    Image对象及其子类BufferedImage
    形状特征提取-Hu不变矩(转载)
    图像的灰度共生矩阵(转载)
    如何实现图片逐渐加载逐渐显示 转载
    JavaScript的函数和事件(转)
    Java图像文件的读写
    图像处理之常用颜色RGB、灰度值
    Hadoop之TaskInputOutputContext类
    ajax获取城市和相应的地区
  • 原文地址:https://www.cnblogs.com/ITGirl00/p/2916314.html
Copyright © 2011-2022 走看看