当前位置: 代码迷 >> Sql Server >> insert into select怎么插入变量
  详细解决方案

insert into select怎么插入变量

热度:92   发布时间:2016-04-27 10:51:54.0
insert into select如何插入变量?
我想写一个遍历数据库并统计出所有表及其包含的记录数,代码如下,但是在插入时遇到了问题,insert [email protected],而我的本意是一个变量。我该怎么做呢?静候各位大侠的回音!谢啦!
SQL code
use Tfs_Test DECLARE @TableName varchar(255); CREATE TABLE #TempTable([id] [INT] IDENTITY(1,1) NOT NULL, [TableName] varchar(255) NOT NULL, [RecordingCount] INT);DECLARE Table_Cursor CURSOR FOR SELECT [name] FROM sysobjects WHERE xtype='U'; OPEN Table_Cursor; FETCH NEXT FROM Table_Cursor INTO @TableName;  WHILE(@@FETCH_STATUS=0)BEGINEXEC('INSERT INTO #TempTable ([TableName],[RecordingCount]) SELECT [email protected]+', COUNT(0) FROM [[email protected]+'];'); FETCH NEXT FROM   Table_Cursor INTO @TableName;ENDCLOSE Table_Cursor; DEALLOCATE Table_Cursor;SELECT [TableName] AS [表名称],[RecordingCount] AS [总记录数] FROM #GetRecordingTempTable ORDER BY [RecordingCount] DESC;DROP TABLE #TempTable; GO


------解决方案--------------------
你那个exec的改成这样看看:
SQL code
INSERT INTO #TempTable ([TableName],[RecordingCount])EXEC(' SELECT [email protected]+', COUNT(0) FROM [[email protected]+'];');
------解决方案--------------------
这样
SQL code
EXEC('INSERT INTO #TempTable ([TableName],[RecordingCount]) SELECT [email protected]+''', COUNT(0) FROM [[email protected]+'];');
  相关解决方案