[英]Create a function for counting rows from any table
我有这个用户定义的功能:
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
问题是它仅适用于表[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
该代码不起作用,因为它不允许在函数中包含这些语句。 虽然它在存储过程中起作用,但是仅当我PRINT
变量而不是RETURN
变量时才起作用。
我需要将它作为一个函数,因为我需要在IF
语句上调用它。
关于如何实现这一点的任何想法? 谢谢。
您可以像下面这样使用
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
对于将对象名作为参数传递的这种查询,您将需要使用Dynamic Sql,但是由于您仅返回总行数,因此使用sys模式目录视图和Dynamic sql可以实现这一点,因此无法使用UDF定义内的动态Sql。
这是您需要做的.....
CREATE PROCEDURE [dbo].[COUNT_ROWS_TABLE]
@TABLE_NAME SYSNAME,
@Count INT OUTPUT
AS
BEGIN
SET NOCOUNT ON;
DECLARE @Sql NVARCHAR(MAX);
SET @Sql = N'SELECT @Count = COUNT(*) FROM ' + QUOTENAME(@TABLE_NAME)
EXECUTE sp_executesql @Sql
, N'@Count INT OUTPUT'
, @Count OUTPUT
END
GO
CREATE FUNCTION [dbo].[COUNT_ROWS_TABLE]
(
@TableName SYSNAME
)
RETURNS INT
AS
BEGIN
DECLARE @Row_Count INT;
SELECT @Row_Count = i.rowcnt
FROM sysindexes AS i
INNER JOIN sysobjects AS o ON i.id = o.id
WHERE i.indid < 2 AND OBJECTPROPERTY(o.id, 'IsMSShipped') = 0
AND o.NAME = @TableName
RETURN @Row_Count;
END
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.