SQL Server 2008 R2 nvarchar binary数据类型转换

davidzeng15 2013-02-27 04:30:39
Hi 各位

有个小问题想请教:
在SQL Server中,由nvarchar向binary类型进行转换,如下的MSDN语句:
SELECT CONVERT(binary(4), '0x4E616D65',1) AS 'Style 1, character to binary'


在SQL Server 2012里 运行之后得到的结果是:
0x4E616D65

但在SQL Server 2008R2例,同样 的语句得到的结果却是:
0x30007080

很奇怪的结果。照理说,SQL Server版本升级,相同函数的功能应该是大致相同的。
我希望得到的结果是:0x4E616D65

各位大侠,能帮忙看下吗? 或者copy到各位的机器里,试试看在SQL server各个版本里运行的情况是怎么样的。

多谢各位!!
...全文
333 点赞 收藏 17
写回复
17 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
forcyever 2013-03-01
引用 16 楼 davidzeng15 的回复:
引用 15 楼 forcyever 的回复:没问题啊,我这得2008R2和2012得出的都是0x4E616D65啊我是说在2005版本里和2012里运行结果不一样。 2005里是:0x30783445 2012里是:0x4E616D65
你自己写2008和2012。。。
回复
davidzeng15 2013-02-28
引用 15 楼 forcyever 的回复:
没问题啊,我这得2008R2和2012得出的都是0x4E616D65啊
我是说在2005版本里和2012里运行结果不一样。 2005里是:0x30783445 2012里是:0x4E616D65
回复
forcyever 2013-02-28
没问题啊,我这得2008R2和2012得出的都是0x4E616D65啊
回复
davidzeng15 2013-02-27
引用 13 楼 DBA_Huangzj 的回复:
引用 12 楼 davidzeng15 的回复:引用 11 楼 DBA_Huangzj 的回复: 2008R2的联机丛书上写到:如果两次转换都是在相同的 SQL Server 版本上进行的,将始终生成相同的值。值的二进制表示形式在不同 SQL Server 版本之间可能会有所不同。 可能是这个原因 这段话我也看过,现在我是想知道为什么在2005版本上运行不出正确的……
呵呵 我只是感觉奇怪:一个相同的语句在SQL server 不同版本里运行结果不一样,也许跟版本升级导致函数定义什么的发生变化了吧。在2012里通过这个语句能实现我想要的功能,但在2005版本里用这个语句就不能实现。唉。
回复
發糞塗牆 2013-02-27
引用 12 楼 davidzeng15 的回复:
引用 11 楼 DBA_Huangzj 的回复: 2008R2的联机丛书上写到:如果两次转换都是在相同的 SQL Server 版本上进行的,将始终生成相同的值。值的二进制表示形式在不同 SQL Server 版本之间可能会有所不同。 可能是这个原因 这段话我也看过,现在我是想知道为什么在2005版本上运行不出正确的结果?0x4E616D65 谢谢DBA_HuangzJ,还为此去查找资料……
这个没有很权威的解释,但是我在看日期转换的时候也说过2005以后日期转换可能会和2000的不一样。可能在微软改版的过程中改变了一些算法或者存储方式而导致的。
回复
davidzeng15 2013-02-27
引用 11 楼 DBA_Huangzj 的回复:
2008R2的联机丛书上写到:如果两次转换都是在相同的 SQL Server 版本上进行的,将始终生成相同的值。值的二进制表示形式在不同 SQL Server 版本之间可能会有所不同。 可能是这个原因
这段话我也看过,现在我是想知道为什么在2005版本上运行不出正确的结果?0x4E616D65 谢谢DBA_HuangzJ,还为此去查找资料!
回复
發糞塗牆 2013-02-27
2008R2的联机丛书上写到:如果两次转换都是在相同的 SQL Server 版本上进行的,将始终生成相同的值。值的二进制表示形式在不同 SQL Server 版本之间可能会有所不同。 可能是这个原因
回复
davidzeng15 2013-02-27
引用 8 楼 Haiwer 的回复:
08,08r2,2012都是3楼的结果 05两个都返回0x30783445
貌似就是2005版本里,用Style为“1” 显示不出0x4E616D65。但现在我就是要用2005的版本,我试了下,Style,为其他的0、2什么的,好像都不行,显示不出0x4E616D65。
回复
Microsoft SQL Server 2005 - 9.00.5000.00 (Intel X86) Dec 10 2010 10:56:29 这是05
回复
08,08r2,2012都是3楼的结果 05两个都返回0x30783445
回复
davidzeng15 2013-02-27
SELECT CONVERT(binary(4), '0x4E616D65',1) AS 'Style 1, character to binary'
select @@version
0x30783445 Microsoft SQL Server 2005 - 9.00.5000.00 (Intel X86) Dec 10 2010 10:56:29
SELECT CONVERT(binary(4), '0x4E616D65',1) AS 'Style 1, character to binary'
select @@version
0x4E616D65 Microsoft SQL Server 2012 - 11.0.2218.0 (X64) Sorry,貌似是05和2012的结果有出入.
回复
davidzeng15 2013-02-27
引用 4 楼 DBA_Huangzj 的回复:
不会有问题啊SQL code?1234567891011121314151617181920212223242526272829303132333435363738394041424344SELECT CONVERT(binary(4), '0x4E616D65',1) AS 'Style 1, character to binary'SELECT @@version ……
这就奇了怪了, 我再在我机器上试试看。
回复
davidzeng15 2013-02-27
引用 1 楼 yangsh0722 的回复:
0x30783445 2005上的
不好意思,我打错了,在08上也是0x30783445 。 貌似是convert函数指定的Style的影响。上述语句在2012版本中可以得到我想要的结果。去掉最后的Style“1” 貌似结果也是0x30783445。 所以,我想应该跟convert函数指定的Style有关。
回复
發糞塗牆 2013-02-27
不会有问题啊
SELECT CONVERT(binary(4), '0x4E616D65',1) AS 'Style 1, character to binary'
SELECT @@version 

/*
Style 1, character to binary
----------------------------
0x4E616D65

(1 行受影响)


----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Microsoft SQL Server 2008 R2 (SP1) - 10.50.2500.0 (X64) 
	Jun 17 2011 00:54:03 
	Copyright (c) Microsoft Corporation
	Enterprise Edition (64-bit) on Windows NT 6.1 <X64> (Build 7601: Service Pack 1, v.721)


(1 行受影响)


*/

SELECT CONVERT(binary(4), '0x4E616D65',1) AS 'Style 1, character to binary'
SELECT @@version 
/*
Style 1, character to binary
----------------------------
0x4E616D65

(1 行受影响)


----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Microsoft SQL Server 2012 - 11.0.2100.60 (X64) 
	Feb 10 2012 19:39:15 
	Copyright (c) Microsoft Corporation
	Enterprise Edition: Core-based Licensing (64-bit) on Windows NT 6.2 <X64> (Build 9200: ) (Hypervisor)


(1 行受影响)


*/
回复
SELECT CONVERT(binary(4), '0x4E616D65',1) AS 'Style 1, character to binary' , CONVERT(binary(4), '0x4E616D65') AS 'Style default, character to binary' --结果 Style 1, character to binary Style default, character to binary 0x4E616D65 0x30783445
回复
-Tracy-McGrady- 2013-02-27
08跟05一样
回复
-Tracy-McGrady- 2013-02-27
0x30783445 2005上的
回复
相关推荐
发帖
MS-SQL Server
创建于2007-09-28

3.3w+

社区成员

MS-SQL Server相关内容讨论专区
申请成为版主
帖子事件
创建了帖子
2013-02-27 04:30
社区公告
暂无公告