详解SQL Server STUFF的用法

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 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

posted on 2022-04-10 22:27  森大科技  阅读(303)  评论(0编辑  收藏  举报

导航