什么是SQL Server 2008中的platform()

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了什么是SQL Server 2008中的platform()相关的知识,希望对你有一定的参考价值。

任何人都可以解释一下platform()在SQL Server 2008中的作用吗?

答案

基于2017年10月的this linkPLATFORM()仍在开发中,无论是否仍然如此,我在快速谷歌搜索中找不到任何相关内容。

似乎PLATFORM()类似于@@VERSION作为上述链接上的Erland引用

当我在我的Azure数据库(基本版)中测试它时,它返回1029,这与我尝试的任何64位实例上返回的值相同。在我的SQL 2000和SQL7实例上,这些实例是32位并且在64位虚拟硬件上运行32位操作系统(我认为),它返回1025.该功能在SQL 6.5中不可用。

这个值显然是某种掩饰。

另一答案

从MSDB存储过程中,它用于查找服务器使用的Windows SKU:

IF ((PLATFORM() & 0x1) = 0x1) -- NT

IF ((PLATFORM() & 0x2) = 0x2) -- Win9x

/* check that local server is not running a desktop SKU */
if( PLATFORM() & 0x100 = 0x100 ) -- Win9x, Office, or MSDE

请注意,这似乎是一个未记录的内部MS功能,因此不建议在用户代码中使用

以上是关于什么是SQL Server 2008中的platform()的主要内容,如果未能解决你的问题,请参考以下文章

SQL Server2008中的MERGE SQL语句中的MERGE的全称是什麼?代表什麼意思? 有没有

SQL Server 2008 中的 SQL Server 2008 R2 中的 dm_os_volume_stats 等效项是啥?

如何查看sql server 2008的SQL语句执行错误日志

sql server 2008语句中的go有什么用?

SQL Server 2008 MERGE 语法中的 USING 是啥?

排除 MS SQL Server 2008 中的“某些”重复行