表值函数与JS中split()的联系

在公司用云平台做开发就是麻烦 ,做了很多功能或者有些收获,都没办法写博客,结果回家了自己要把大脑里面记住的写出来。

split()这个函数我们并不陌生,但是当前台有许多字段然后随意勾选后的这些参数传递到后台做处理的时候却麻烦了,我们这个时候需要把这些当字符串传递到存储过程,在存储过程里面将这些字符串分割成一个个单独的个体,我这里不说数组,是因为存储过程没有数组这一说。

这时候我们就会想到表值函数。表值函数返回的是一个Table类型的表。说到这里我想很多人都想到了,这不就是一个数组形式么?一个表就是一个数组,每一行就是一个数组中的值,但是里面的值怎么遍历或者取出来呢?我想我们可以用游标的形式去遍历出来

之前我做过一个gompertz的算法模型,将VBA写的算法,全部用存储过程写出来,里面涉及到很多的一位数组,二维数组。我就是用一个个虚拟表写的。

现在我们言归正传!

这里我们先不管内联表值函数还是多语句表值函数

//语法结构,函数体由一条return语句组成,最后调用的时候跟查表一样
CREATE FUNCTION [ schema_name. ] function_name
( [ { @parameter_name [ AS ] [ type_schema_name. ] parameter_data_type
    [ = default ] }
    [ ,...n ]
  ]
)
RETURNS TABLE
    [ WITH <function_option> [ ,...n ] ]
    [ AS ]
    RETURN [ ( ] select_stmt [ ) ]
[ ; ]

这样比较抽象,现在来个具体的使用的函数。

CREATE FUNCTION Split(@Text NVARCHAR(4000),@Sign NVARCHAR(4000))
RETURNS  @tempTable TABLE(id INT IDENTITY(1,1) PRIMARY KEY,[VALUE] NVARCHAR(4000))
AS
BEGIN
    DECLARE @StartIndex INT                --开始查找的位置
    DECLARE @FindIndex  INT                --找到的位置
    DECLARE @Content    VARCHAR(4000)      --找到的值  

    SET @StartIndex = 1   
    SET @FindIndex=0  

    --开始循环查找字符串逗号
    WHILE(@StartIndex <= LEN(@Text))
    BEGIN
        SELECT @FindIndex = CHARINDEX(@Sign,@Text,@StartIndex)
        IF(@FindIndex =0 OR @FindIndex IS NULL)
        BEGIN
        --如果没有找到者表示找完了
            SET @FindIndex = LEN(@Text)+1
        END
        SET @Content = LTRIM(RTRIM(SUBSTRING(@Text,@StartIndex,@FindIndex-@StartIndex)))
        --初始化下次查找的位置
        SET @StartIndex = @FindIndex+1
        --把找的的值插入到要返回的Table类型中
        INSERT INTO @tempTable ([VALUE]) VALUES (@Content)
    END
    RETURN
END  

-------------------------------------------------------------------
SELECT * FROM dbo.Split('a,b,c,d,e,f,g',',')  

 

这里面涉及到了5个函数。

第一个:LEN() 这个没得说的,就是类似JS中的length

第二个:LTRIM() 这个从字符串左侧删除空格或其他预定义字符

第三个:RTRIM() 字符串的末端开始删除空白字符或其他预定义字符

第四个: CHARINDEX(expression1 , expression2 , [ start_location ] )  返回值是  int 这个函数有点意思了,也很重要。

  • 第一个参数是要找的字符串  ;
  • 第二个参数是在哪里查找这个字符串 ;
  • 第三个参数是开始查找的位置  ;

这个函数类似于C#中的StartWith(),IndexWith()等函数。

  例子:CustomName包含客户的First Name和Last Name,它们之间被一个空格隔开。我们用CHARINDX函数确定两个名字中间空格的位置。通过这个方法,我们可以分析ContactName列的空格位置,这样可以只显示这个列的last name部分。

第五个: SUBSTRING(str, pos, len)  这个函数类似JS中的substring() 是用来抓出一个栏位资料中的其中一部分/截取字符串的一个方法 。

  • 第一个参数是要截取的字符串 ;
  • 第二个参数是开始的位置;
  • 第三个参数是截取的长度 

  例子:SELECT SUBSTR (Store_Name, 2, 4) FROM Geography WHERE Store_Name = 'San Diego';

转载:http://www.cnblogs.com/zqzjs/p/4552883.html

时间: 2024-10-29 14:10:55

表值函数与JS中split()的联系的相关文章

js中split和replace的用法实例

 这篇文章主要介绍了js中split和replace的用法,实例分析了split和replace的功能及使用技巧,需要的朋友可以参考下     本文实例讲述了js中split和replace的用法.分享给大家供大家参考.具体分析如下: 1. split : 代码如下: <html> <head> <title> 从业人员继续教育报名列表--打印签到表 sdfsd</tr><tr></tr> sdfsd </title> &

JS中split()用法(将字符串按指定符号分割成数组)_javascript技巧

废话不多说了,直接给大家贴代码. <!DOCTYPE html> <html> <head> <meta charset="{CHARSET}"> <title></title> </head> <body> </body> <script type="text/javascript"> //在Javascript脚本中,将字符串按指定符号进行分割

escape函数解决js中ajax传递中文出现乱码问题_javascript技巧

本文实例讲述了escape函数解决js中ajax传递中文出现乱码问题,分享给大家供大家参考.具体方法如下: 一.问题描述: 本来网页特效中的escape()是将中文按iso-8859-1字符集进行url编码的,那样通过 request.getparameter()是能直接获取到请求参数的,但后来的javascript将escape()换成了unicode字符集编 码,如此一来,在jsp教程和servlet中就没法直接拿到请求参数了,具体原因我也不知道. 二.解决办法: 1.首先对中文字符进行两次

js中split和replace的用法实例_javascript技巧

本文实例讲述了js中split和replace的用法.分享给大家供大家参考.具体分析如下: 1. split : 复制代码 代码如下: <html> <head>     <title>     从业人员继续教育报名列表--打印签到表 sdfsd</tr><tr></tr>  sdfsd     </title> </head> <body>      <script type="t

js中split函数的使用方法说明_javascript技巧

splitsplit与join作用相反,用于把一个字符串分割成字符串数组.stringObject.split(a,b)这是它的语法. a是必须的 决定从a这分割.b不是必须的,可选.该参数可指定返回的数组的最大长度 .如果设置了该参数,返回的子串不会多于这个参数指定的数组.如果没有设置该参数,整个字符串都会被分割,不   考虑它的长度. 注意返回的数组中不包括a本身: 提示和注释注释:如果把空字符串 ("") 用作 a,那么 stringObject 中的每个字符之间都会被分割.注释

Javascript中split函数的使用方法说明

 本篇文章主要是对js中split函数的使用方法进行了说明介绍,需要的朋友可以过来参考下,希望对大家有所帮助 split split与join作用相反,用于把一个字符串分割成字符串数组. stringObject.split(a,b)这是它的语法.   a是必须的 决定从a这分割. b不是必须的,可选.该参数可指定返回的数组的最大长度 .如果设置了该参数,返回的子串不会多于这个参数指定的数组.如果没有设置该参数,整个字符串都会被分割,不   考虑它的长度.   注意返回的数组中不包括a本身:  

asp中Split的用法示例

示例|split 大家有没有碰到过要想取一字符串里的某些值而无从下手?有没有觉得看书或教材对split的写法糊里糊涂--如果有此疑问的话,请看下面我对例子的解释,相信您会对这个有一定的了解. 例如我想取得一个ftp里的用户名及密码(服务器等)值(用IE当FTP时或从表中取出FTP的值).下面是我的解决思路:设url为收到的URL值,这里指:url=ftp://username:password@server,请注意这句暗墓媛?br>我想大家都看清楚这个URL里的规律了吧,就是各个部分都被"

JavaScript中split() 使用方法汇总_javascript技巧

split() 方法用于把一个字符串分割成字符串数组. 例子 1 在本例中,我们将按照不同的方式来分割字符串: var str="How are you doing today?" document.write(str.split(" ") + " ") document.write(str.split("") + " ") document.write(str.split(" ",3)

js中call、apply、bind的用法

今天看博客时,看到了这样的一段js代码: var bind = Function.prototype.call.bind(Function.prototype.bind); 我想突然看到这样的一段代码,即使js能力再强的人,可能也需要花点时间去理解.像我这样的菜鸟就更不用说了.其实,原文已经对这端代码做出了解释,但我还是想用我的想法去解释这段代码. 上面那段代码涉及到了call.bind,所以我想先区别一下call.apply.bind的用法.这三个方法的用法非常相似,将函数绑定到上下文中,即用