创建一个函数来计算任何表中的行数

sou*_*zer 2 sql sql-server function dynamic

我有这个用户定义的函数:

 CREATE FUNCTION [dbo].[COUNT_ROWS_TABLE]()
 RETURNS TINYINT
 AS
 BEGIN
      DECLARE @ROW_COUNT TINYINT
      SELECT @ROW_COUNT = COUNT(*) FROM EMPLOYEE
      RETURN @ROW_COUNT
 END
 GO
Run Code Online (Sandbox Code Playgroud)

问题是它仅适用于表[dbo].[EMPLOYEE],我不想为数据库中的每个表复制粘贴此函数。

到目前为止我的尝试:

 CREATE FUNCTION [dbo].[COUNT_ROWS_TABLE](@TABLE_NAME VARCHAR(50))
 RETURNS TINYINT
 AS
 BEGIN
      DECLARE @SQL_COMMAND NVARCHAR(100)
      DECLARE @PARAM NVARCHAR(50)
      DECLARE @ROW_COUNT TINYINT
      SET @SQL_COMMAND = N'SELECT @RESULT = COUNT(*) FROM ' + @TABLE_NAME
      SET @PARAM = N'@RESULT TINYINT OUTPUT'
      EXEC SP_EXECUTESQL @SQL_COMMAND, @PARAM, @RESULT = @ROW_COUNT OUTPUT
      RETURN @ROW_COUNT
 END
 GO
Run Code Online (Sandbox Code Playgroud)

该代码不起作用,因为它不允许在函数内使用这些语句。不过,它在存储过程中工作,但前提是我是PRINT变量而不是变量RETURN

我需要它是一个函数,因为我需要在IF语句上调用它。

关于如何实现这一目标有什么想法吗?谢谢。

Pra*_*las 5

你可以像下面这样使用

ALTER FUNCTION [dbo].[COUNT_ROWS_TABLE](@TABLE_NAME VARCHAR(50))
 RETURNS TINYINT
AS
BEGIN
DECLARE @ROW_COUNT TINYINT
SELECT @ROW_COUNT = SUM(b.rows) 
FROM SYS.TABLES a INNER JOIN sys.partitions b ON b.OBJECT_ID = a.OBJECT_ID
WHERE a.is_ms_shipped = 0 AND b.index_id IN (1,0)
        and a.name=@TABLE_NAME
GROUP BY a.name

RETURN @ROW_COUNT
END
GO
Run Code Online (Sandbox Code Playgroud)