适用于: SQL Server 
Azure SQL 数据库 
Azure SQL 托管实例 
Azure Synapse Analytics 
分析平台系统 (PDW) 
Microsoft Fabric 中的 SQL 分析端点 
Microsoft Fabric 中的仓库
只将元数据返回给客户端。 可以用于测试响应的格式,而不必实际执行查询。
注意
请勿使用此功能。 此功能已由以下项替代:
语法
SET FMTONLY { ON | OFF }   
备注
当 FMTONLY 为 ON 时,返回包含列名称但不含任何数据行的行集。
分析 Transact-SQL 批时,SET FMTONLY ON 无效。 在执行运行时期间生效。
默认值是 OFF。
权限
要求具有 public 角色的成员身份。
示例
以下 Transact-SQL 代码示例将 FMTONLY 设置为 ON。 此设置使 SQL Server 仅返回有关所选列的元数据信息。 具体来说,返回列名称。 不返回任何数据行。
在该示例中,存储过程 prc_gm29 的测试执行返回以下内容:
- 多个行集。
- 来自多个表的列,位于其某个 SELECT语句中。
SET NOCOUNT ON;
GO
DROP PROCEDURE IF EXISTS prc_gm29;
DROP TABLE IF EXISTS #tabTemp41;
DROP TABLE IF EXISTS #tabTemp42;
GO
CREATE TABLE #tabTemp41
(
   KeyInt41        INT           NOT NULL,
   Name41          NVARCHAR(16)  NOT NULL,
   TargetDateTime  DATETIME      NOT NULL  DEFAULT GetDate()
);
CREATE TABLE #tabTemp42
(
   KeyInt42 INT          NOT NULL,   -- JOIN-able to KeyInt41.
   Name42   NVARCHAR(16) NOT NULL
);
GO
INSERT INTO #tabTemp41 (KeyInt41, Name41) VALUES (10, 't41-c');
INSERT INTO #tabTemp42 (KeyInt42, Name42) VALUES (10, 't42-p');
GO
CREATE PROCEDURE prc_gm29
AS
BEGIN
SELECT * FROM #tabTemp41;
SELECT * FROM #tabTemp42;
SELECT t41.KeyInt41, t41.TargetDateTime, t41.Name41, t42.Name42
   FROM
                 #tabTemp41 AS t41
      INNER JOIN #tabTemp42 AS t42 on t42.KeyInt42 = t41.KeyInt41
END;
GO
SET DATEFORMAT mdy;
SET FMTONLY ON;
EXECUTE prc_gm29;   -- Returns multiple tables.
SET FMTONLY OFF;
GO
DROP PROCEDURE IF EXISTS prc_gm29;
DROP TABLE IF EXISTS #tabTemp41;
DROP TABLE IF EXISTS #tabTemp42;
GO
/****  Actual Output:
[C:\JunkM\]
>> osql.exe -S myazuresqldb.database.windows.net -U somebody -P secret -d MyDatabase -i C:\JunkM\Issue-2246-a.SQL 
 KeyInt41    Name41           TargetDateTime
 ----------- ---------------- -----------------------
 KeyInt42    Name42
 ----------- ----------------
 KeyInt41    TargetDateTime          Name41           Name42
 ----------- ----------------------- ---------------- ----------------
[C:\JunkM\]
>>
****/