详解SQL Server STUFF的用法

SQL Server admin 1196℃ 0评论

GPS平台、网站建设、软件开发、系统运维,找森大网络科技!
https://cnsendnet.taobao.com
来自森大科技官方博客
http://www.cnsendblog.com/index.php/?p=2225

 

详解SQL Server STUFF的用法

STUFF ( character_expression , start , length ,character_expression )

  参数

character_expression

一个字符数据表达式。character_expression可以是常量、变量,也可以是字符列或二进制数据列。

start

一个整数值,指定删除和插入的开始位置。如果start或 length为负,则返回空字符串。如果start比第一个 character_expression长,则返回空字符串。start可以是 bigint 类型。

length

一个整数,指定要删除的字符数。如果length比第一个character_expression长,则最多删除到最后一个character_expression中的最后一个字符。length可以是bigint类型。

  返回类型

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

  备注

如果开始位置或长度值是负数,或者如果开始位置大于第一个字符串的长度,将返回空字符串。如果要删除的长度大于第一个字符串的长度,将删除到第一个字符串中的第一个字符。
如果结果值大于返回类型支持的最大值,则产生错误。

  示例

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

1SELECT STUFF(‘abcdef’, 2, 3, ‘ijklmn’);
2GO

下面是结果集:

aijklmnef
(1 row(s) affected)

 

 

SQL时间相关 – SQL日期,时间比较

SQL Server 中时间比较

例子:

select count(*) from table where DATEDIFF ([second], ‘2004-09-18 00:00:18′, ‘2004-09-18 00:00:19′) > 0

说明

select DATEDIFF(day, time1 , time2) 对应示例语句如下

select DATEDIFF(day, ‘2010-07-23 0:41:18′, ‘2010-07-23 23:41:18′)

time1 > time2 为负数;

time1 < time2 为正数;

[day] :只会比较 2010-07-23 忽略 0:41:18′ 其他同理

以下分别:

: SELECT DATEDIFF([year],time1 , time2) 返回值:-6 ,说明是后减前 与mysql相反的。

: SELECT DATEDIFF([month], time1 , time2)

: SELECT DATEDIFF([day], time1 , time2)

小时: SELECT DATEDIFF([hour], time1 , time2)

  秒: SELECT DATEDIFF([second], time1 , time2)

 

 

GPS平台、网站建设、软件开发、系统运维,找森大网络科技!
https://cnsendnet.taobao.com
来自森大科技官方博客
http://www.cnsendblog.com/index.php/?p=2225

转载请注明:森大科技官方博客 » 详解SQL Server STUFF的用法

喜欢 (154)
发表我的评论
取消评论
表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址