原文:SQL Server系统函数:类型转换函数


1.基本的转化


  1. SELECT CAST(2008 as varchar(4)) + ' year!'
  2. SELECT CONVERT(varchar(4),2008) + ' year!'

2、 把日期转化为文本


  1. SELECT CONVERT(VARCHAR(30),GETDATE(),120) --年-月-日 时:分:秒(24h)
  2. SELECT CONVERT(VARCHAR(10),GETDATE(),120) --年-月-日 时:分:秒(24h)
  3. SELECT CONVERT(VARCHAR(8),GETDATE(),108) -- 时:分:秒(24h)
  4. select CONVERT(varchar(30),getdate(),121) --年-月-日 时:分:秒 时:分:秒.毫秒(24h)

3、使用不同样式转换二进制和字符数据的结果


  1. SELECT CONVERT(varbinary,
  2. 'SQL Server 2008 T-SQL Recipes',
  3. 0 --表示把字符串转化为二进制
  4. )
  5. select CONVERT(char(29),
  6. 0x53514C20536572766572203230303820542D53514C2052656369706573,
  7. 0 --把二进制转化为ASCII格式的字符串
  8. )
  9. --下面两个都是转化为字面量
  10. SELECT CONVERT(CHAR(60),
  11. 0x53514C20536572766572203230303820542D53514C2052656369706573,
  12. 1 --转化为16进制字面量格式,带0x前缀
  13. )
  14. SELECT CONVERT(CHAR(60),
  15. 0x53514C20536572766572203230303820542D53514C2052656369706573,
  16. 2
  17. ) --转化为16进制字面量格式,不带0x前缀

4、计算表达式返回的类型


  1. select ISDATE('20000-01-01')
  2. select ISDATE('2000-01-01')
  3. --字符会返回0
  4. SELECT ISNUMERIC('ABC')
  5. --如果数字之间有空格,也会返回0
  6. SELECT ISNUMERIC('12 3')
  7. --如果数字之间有其他符号,也会返回0
  8. SELECT ISNUMERIC('12,3')
  9. --如果数据末尾,开头有空格,不会有影响,还是返回1
  10. SELECT ISNUMERIC(' 12,3 ')

5、 这里需要特别提到的是,在原来的公司,曾经遇到过日期转换的问题,由于把日期数据存储在了varchar类型中,导致转换报错,那么这种情况,如何处理呢?

下面通过一个简单的例子来说明处理方法:


  1. if object_id('a') is not null
  2. drop table a
  3. go
  4. create table A(Id int, date varchar(30))
  5. insert into A
  6. select 1, '2013-10-40 00:00:00' union all
  7. select 2, '2013-10-01 12:00:00' union all
  8. select 3, '2014-01-01 12:09:34'
  9. --报错了
  10. select * from A
  11. where Isdate(date) = 1
  12. and Convert(datetime,date) >= '2014-01-01 00:00:00'
  13. /*
  14. Id date
  15. ----------- ------------------------------
  16. 消息 242,级别 16,状态 3,第 10 行
  17. 从 varchar 数据类型到 datetime 数据类型的转换产生一个超出范围的值。
  18. */
  19. --找到有问题的数据
  20. select *,
  21. case when isdate(date) = 1 then '是日期'
  22. when isdate(date) = 0 then '不是日期'
  23. end
  24. from A
  25. --where Isdate(date) = 1
  26. --and Convert(datetime,date) >= '2014-01-01 00:00:00'
  27. /*
  28. Id date
  29. ----------- ------------------------------ --------
  30. 1 2013-10-40 00:00:00 不是日期
  31. 2 2013-10-01 12:00:00 是日期
  32. 3 2014-01-01 12:09:34 是日期
  33. (3 行受影响)
  34. */
  35. --这里通过convert函数,把字符串格式化为日期格式的字符串
  36. --然后与右边的字符串进行比较,就不会报错了
  37. select * from A
  38. where Isdate(date) = 1 --是日期
  39. and Convert(VARCHAR(20),[date],121) >='2013-11-01 00:00:00'

6、把负数转化为16进制数


  1. --1.一开始这么转化,但是有问题,关键在于你的这个数太大,超出了int的范围
  2. select cast(-2161622263693857431 as varbinary)
  3. /*
  4. 0x1300000097520CFEFE9FFF1D
  5. */
  6. --2.这样就行了,转化为bigint,在转为varbianry,但是这个不是字符串,所以还是不行
  7. select cast(cast(-2161622263693857431 as bigint) as varbinary)
  8. /*
  9. 0xE200600101F3AD69
  10. */

要转为文本,需要创建自定义函数:


  1. use 你的数据库
  2. go
  3. IF OBJECT_ID ('dbo.varbin2hexstr') IS NOT NULL
  4. DROP FUNCTION dbo.varbin2hexstr
  5. GO
  6. --这个函数实现了把varbinary类型数据转化为varchar类型的数据
  7. CREATE function varbin2hexstr(
  8. @bin varbinary(max)
  9. )returns varchar(max)
  10. as
  11. begin
  12. declare @re varchar(max),@i int
  13. select @re='',@i=datalength(@bin)
  14. while @i>0
  15. select @re=substring('0123456789ABCDEF',substring(@bin,@i,1)/16+1,1)
  16. +substring('0123456789ABCDEF',substring(@bin,@i,1)%16+1,1)
  17. +@re
  18. ,@i=@i-1
  19. -- return('0x'+@re)
  20. return @re
  21. end
  22. GO
  23. --3.调用函数dbo.varbin2hexstr,把varbinary转为字符串,这样才行
  24. select dbo.varbin2hexstr(cast(cast(-2161622263693857431 as bigint) as varbinary))
  25. /*
  26. E200600101F3AD69
  27. */
发布了416 篇原创文章 · 获赞 135 · 访问量 94万+

SQL Server系统函数:类型转换函数的更多相关文章

  1. SQL Server系统函数简介[转]

    一.字符转换函数1.ASCII()返回字符表达式最左端字符的ASCII 码值.在ASCII()函数中,纯数字的字符串可不用‘’括起来,但含其它字符的字符串必须用‘’括起来使用,否则会出错.2.CHAR ...

  2. sql server 系统常用函数:聚合函数 数学函数 字符串函数 日期和时间函数和自定义函数

    一.系统函数 1.聚合函数 聚合函数常用于GROUP BY子句,在SQL Server 2008提供的所有聚合函数中,除了COUNT函数以外,聚合函数都会忽略空值AVG.COUNT.COUNT_BIG ...

  3. SQL Server系统函数:系统信息函数

    原文:SQL Server系统函数:系统信息函数 1.会话id,服务器信息.用户信息 select @@SPID, --返回当前连接的会话ID:SPID @@servername, --SQL Ser ...

  4. SQL Server系统函数:字符串函数

    原文:SQL Server系统函数:字符串函数 1.字符转化为ASCII,把ASCII转化为字符,注意返回的值是十进制数 select ASCII('A'),ASCII('B'),ASCII('a') ...

  5. SQL Server系统函数:日期函数

    原文:SQL Server系统函数:日期函数 1.返回当前日期和时间 select GETDATE() '当前日期-精确到33毫秒' select GETUTCDATE() 'UTC日期和时间-精确到 ...

  6. SQL Server系统函数:元数据函数

    原文:SQL Server系统函数:元数据函数 1.列的长度.列名 --列的长度 select COL_LENGTH('dbo.wct', --表名 'wcid') --列名 --列名 select ...

  7. sql server 2012 自定义聚合函数(MAX_O3_8HOUR_ND) 计算最大的臭氧8小时滑动平均值

    采用c#开发dll,并添加到sql server 中. 具体代码,可以用visual studio的向导生成模板. using System; using System.Collections; us ...

  8. ylb:SQL Server中的时间函数

    ylbtech-SQL Server:SQL Server-SQL Server中的时间函数 SQL Server中的时间函数. 1,SQL Server中的时间函数 返回顶部 1.   当前系统日期 ...

  9. SQL Server中的CLR编程——用.NET为SQL Server编写存储过程和函数

    原文:SQL Server中的CLR编程--用.NET为SQL Server编写存储过程和函数 很早就知道可以用.NET为SQL Server2005及以上版本编写存储过程.触发器和存储过程的,不过之 ...

随机推荐

  1. php的IP转换成整型函数ip2long()易出现负数

    php中将IP转换成整型的函数ip2long()容易出现问题,在IP比较大的情况下,会变成负数.如下<?php$ip = "192.168.1.2";$ip_n = ip2l ...

  2. React拾遗(上)

    JSX代表Objects Babel转义器会把JSX转换成一个名为React.createElement()的方法调用. 下面两种代码的作用是完全相同的: const element = ( < ...

  3. TensorFlow Object Detection API —— 测试自己的模型

    (flappbird) luo@luo-All-Series:~/MyFile/TensorflowProject/Mask_RCNN/mask_rcnn_20190518/Mask_RCNN/mod ...

  4. Java环境中,word文档转PDF直接打开浏览而非下载

    在平台上,需要把文档直接浏览而非下载,实现方法是先把文档转为PDF文件, 但在linux系统中确实汉字字库,所以转换失败,以下是解决方法 后面正式服务器也要添加字库,不然会转换出乱码文件,处理步骤如下 ...

  5. LODOP打印超文本字符串拼接1 固定表格填充数值

    前面的博文:Lodop打印控件传入css样式.看是否传入正确样式.Lodop打印如何隐藏table某一列,Lodop传入的样式可以不是页面本身的css样式,传入什么打印什么,此外,数据也是,超文本打印 ...

  6. git 平时遇到的问题记录

    1.git warning: LF will be replaced by CRLF in 解决办法 git config core.autocrlf false 2.git提交时如何忽略一些文件 h ...

  7. Python之汉诺塔递归运算

    汉诺塔问题是一个经典的问题.汉诺塔(Hanoi Tower),又称河内塔,源于印度一个古老传说.大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘.大梵天命令婆 ...

  8. iOS面试经历(个人)

    1.OC的runtime运行机制1> runtime,运行时机制,它是一套C语言库2> 实际上我们编写的所有OC代码,最终都是转成了runtime库的东西,比如类转成了runtime库里面 ...

  9. Docker storage driver(十四)

    目录 一.storage driver 作用 1.Images and layers 2.Container and layers Copy-on-Write 3.Data volumes and t ...

  10. windows服务器入门 使用FileZilla搭建FTP服务

    下载FileZilla Server(注意:我搭建ftp的时候,有一个fz的版本会报错,百度了老半天都没有解决这个问题,回来我换了一个版本就可以.如果你们也出现了不知道怎么搞定的问题的话   可以考虑 ...