加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

关于SQL Server中将数值类型转换为字符串的问题

发布时间:2020-12-12 09:02:18 所属栏目:MsSql教程 来源:网络整理
导读:今天在把一些数据导入到SQL Server的时候遇到有个列被导入成float类型,而我实际需要的是varchar类型,所以要进行类型转换,转换时遇到了一点问题,所以写这篇博客记录一下。 SQL Server中的数值类型分为两种,一种是精确的数值类型,具体的数据类型有:bit

今天在把一些数据导入到SQL Server的时候遇到有个列被导入成float类型,而我实际需要的是varchar类型,所以要进行类型转换,转换时遇到了一点问题,所以写这篇博客记录一下。

SQL Server中的数值类型分为两种,一种是精确的数值类型,具体的数据类型有:bit、tinyint、smallint、int、bigint、smallmoney、money和decimal,这些数据类型能够精确的表明某以数值;另一种是近似的数值类型,具体就是float和real。浮点数据为近似值,因此,并非数据类型范围内的所有值都能精确地表示。

有些时候我们需要将这些数值类型转换为字符串类型,用到的转换函数就是cast和convert,这两个函数的作用都是进行类型转换,只不过语法格式不同。据说在转换时还是有一定的区别的,不过我个人更习惯于使用convert函数,应该这个函数一方面更像是个函数的语法,另一方面在做时间和数值转换成字符串时还可以指定转换的格式。

对于精确数值的数据类型,转换出来的字符串就是我们存储的数值。比如:

 @i 
 @i=123456789 +((20),@i)输出就是:test:123456789

而如果对于近似数值的数据类型,那么可就没有那么简单了。

<pre class="csharpcode"><span class="kwrd">declare @i <span class="kwrd">float
<span class="kwrd">set @i=123456789<span class="kwrd">print <span class="str">'test:'+<span class="kwrd">convert(<span class="kwrd">varchar(20),@i)输出结果:test:1.23457e+008

输出的结果是使用科学计数法来表示的,再看看可否通过指定转换样式来指定不使用科学计数法呢?帮助文档中说到floatreal 转换为字符数据时的 style 值:

0(默认值)最大为 6 位数。根据需要使用科学记数法。

1 始终为 8 位值。始终使用科学记数法。

2 始终为 16 位值。始终使用科学记数法。

我们的值是123456789,超过了6位数.所以不管是0还是1,2结果都会使用科学计数法来表示。那么要怎么样才能将我们的数据不转换成科学计数法而输出呢?比较简单的办法就是将近似数据转换为精确数据,然后再将精确数据转换成字符串。

同样以上面的例子为例, 进行两次数据类型的转换如下:

<pre class="csharpcode"><span class="kwrd">declare @i <span class="kwrd">float
<span class="kwrd">set @i=123456789<span class="kwrd">print <span class="str">'test:'+<span class="kwrd">convert(<span class="kwrd">varchar(20),<span class="kwrd">convert(<span class="kwrd">int,@i))输出:test:123456789

<pre class="csharpcode">如果是有小数,那么我们要转换出小数位的话,可以转换成decimal,转换出的小数位数在定义decimal时指定。比如要输出4位小数,那么转换代码是:

<pre class="csharpcode"><span class="kwrd">declare @i <span class="kwrd">float
<span class="kwrd">set @i=123456789.12<span class="kwrd">print <span class="str">'test:'+<span class="kwrd">convert(<span class="kwrd">varchar(20),<span class="kwrd">convert(<span class="kwrd">decimal(18,4),@i))输出:test:123456789.1200

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读