zoukankan      html  css  js  c++  java
  • SQL Server字符串函数STUFF的使用

    前言:

    最近有个实践练习是将学生报名数据表student中的[st_id]字段的第二个和第三个字符删除,然后在此位置插入新的字符串“200900”,其实就是替换的意思,生成新的字符串。

    STUFF 函数将字符串插入到另一个字符串中。 它从第一个字符串的开始位置删除指定长度的字符;然后将第二个字符串插入到第一个字符串的开始位置。

    语法:

    STUFF ( character_expression , start , length , replaceWith_expression )

    参数说明:

    character_expression
    字符数据的表达式。 character_expression 可以是常量、变量,也可以是字符列或二进制数据列 。
    start
    一个整数值,指定删除和插入的开始位置。 如果 start 为负或为零,则返回空字符串 。 如果 start 的长度大于第一个 character_expression,则返回空字符串 。 start 的类型可以是 bigint 。
    length
    一个整数,指定要删除的字符数。 如果 length 为负,则返回空字符串 。 如果 length 的长度大于第一个 character_expression,则最多可以删除到最后一个 character_expression 中的最后一个字符 。 如果 length 为零,则在字符串中第一个字符之前插入内容 。 length 的类型可以是 bigint 。
    replaceWith_expression
    字符数据的表达式。 character_expression 可以是常量、变量,也可以是字符列或二进制数据列 。 此表达式从 start 开始替换 length 个字符的 character_expression 。 如果 replaceWith_expression 为 NULL,则在不插入任何内容的情况下删除字符 。

    返回类型:

    如果 character_expression 是支持的字符数据类型之一,则返回字符数据 。 如果 character_expression 是支持的二进制数据类型之一,则返回二进制数据 。

    Remarks:

    如果开始位置或长度值是负数,或者开始位置大于第一个字符串的长度,则返回 Null 字符串。 如果开始位置为 0,则返回 Null 值。如果要删除的长度大于第一个字符串的长度,则删除到第一个字符串中的第一个字符。

    如果结果值大于返回类型支持的最大值,则会引发错误。

     

    示例1:

    以下示例从第一个字符串 Sungeek的第 2 个位置 (u) 开始删除三个字符,然后在删除位置插入第二个字符串,从而创建并返回一个字符串。

    SELECT STUFF('SUNGEEK', 2, 3, '20190814');  
    GO

    示例2:

    将学生报名数据表student中的[st_id]字段的第二个和第三个字符删除,然后在此位置插入新的字符串“200900”,其实就是替换的意思,生成新的字符串。

    select [st_id],[st_nm],
    stuff([st_id],2,2,200900) as 新学号
    from [dbo].[student]

  • 相关阅读:
    Git在AndroidStudio中的使用(一)
    自定义SiidingMenu简单实现
    圆形ImageView的简单实现
    使用PullToRefresh实现下拉刷新和上拉加载
    XMLpull解析使用
    Xutils简单使用
    友盟第三方登录和分享的使用
    ImageLoader简单使用
    Android中利用LinearLayout动态添加控件
    数据库两大神器【索引和锁】
  • 原文地址:https://www.cnblogs.com/Sungeek/p/11352242.html
Copyright © 2011-2022 走看看