当前位置:  开发笔记 > 数据库 > 正文

如何确定SQL结果的数据类型?

如何解决《如何确定SQL结果的数据类型?》经验,为你挑选了2个好方法。

我们有一个SQL查询,它从数据库中的许多表/视图中提取大量字段.我们需要将规范放在一起以便与第三方集成,编译结果集的数据类型的最快方法是什么?

澄清:

涉及25个表/视图,因此表级的功能仍然很麻烦.

目前,所有工作都在Microsoft SQL Server Management Studio中完成.

Dennis C.. 10

您可以使用几个快速SQL语句来查看结果列类型,方法是使用临时表.

临时表比视图稍好一些,因为它们是连接本地范围,一旦断开连接就会被清除.

您只需要输入几个关键字,如下所示

SELECT
TOP 0 -- to speed up without access data
your,original,columns
INTO #T -- temp table magic
FROM originalTablesJoins
Order by anything
exec tempdb.sys.sp_columns #T
drop table #T

要么;

SELECT TOP 0 *
INTO #T
FROM (
  select your,original,columns from originalTablesJoins -- remove order by if any
) x
exec tempdb.sys.sp_columns #T
drop table #T

注意:受SQL Server Management Studio中结果集的View架构的启发



1> Dennis C..:

您可以使用几个快速SQL语句来查看结果列类型,方法是使用临时表.

临时表比视图稍好一些,因为它们是连接本地范围,一旦断开连接就会被清除.

您只需要输入几个关键字,如下所示

SELECT
TOP 0 -- to speed up without access data
your,original,columns
INTO #T -- temp table magic
FROM originalTablesJoins
Order by anything
exec tempdb.sys.sp_columns #T
drop table #T

要么;

SELECT TOP 0 *
INTO #T
FROM (
  select your,original,columns from originalTablesJoins -- remove order by if any
) x
exec tempdb.sys.sp_columns #T
drop table #T

注意:受SQL Server Management Studio中结果集的View架构的启发



2> Dave Cludera..:

您可以使用SET FMTONLY ON运行查询,但这可能无法帮助您轻松确定返回的数据类型,因为您只在管理工作室中工作.如果是我,我想我会使用与存储过程相同的主体临时创建一个视图(您可能必须为任何参数声明变量).然后,您可以使用已讨论过的INFORMATION_SCHEMA查询查看视图返回的列.

推荐阅读
ifx0448363
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有