用光标或循环创建视图

时间:2012-06-29 14:44:27

标签: sql sql-server tsql sql-server-2005

我设法从游标创建一个表,该表从我的数据库中的类似命名的表中插入行。它成功地工作,但我想创建一个视图,以便我不需要更新我的原始查询。我可能使用游标走错路线,但我当前的查询是:

use LaganPDM
set nocount on 
declare @table varchar(128)
declare @cmd varchar(500) 
create table SPECIAL_CASE_FORMS_2 (table_name varchar(128), flods_id numeric(22,0) PRIMARY KEY, lgncc_id numeric(22,0), case_enquiry_id numeric(22,0),amount varchar(4000), costcode varchar(4000), jobcompletedate varchar(4000), jobreleasedate varchar(4000),paymentstatus varchar(4000))
declare tables cursor for
select table_name
from information_schema.tables
   where table_name like '%SPECIAL_UP_C00%'
and left(right(table_name, 24),9) > '101000363'
and not left(right(table_name, 24),9) in('101000487', '101000507', '101000510')
open tables
fetch next from tables into @table
while @@fetch_status = 0
begin
  set @cmd = 'select ''' + @table + ''', * from ' + @table 
insert into SPECIAL_CASE_FORMS_2 exec (@cmd)
  fetch next from tables into @table
END
CLOSE tables 
DEALLOCATE tables
select  * from SPECIAL_CASE_FORMS_2

我试图改变它并创建一个视图,但我没有运气。任何建议都会被感激,即使这意味着走另一条路。

谢谢!

2 个答案:

答案 0 :(得分:0)

正如评论中已经说过的那样,您不能在视图中使用游标,只能在存储过程中使用游标。

要将查询结果放入每次将新表添加到数据库时自动更新的表中,您可以执行以下操作:

首先,您已经在数据库中创建了一个名为SPECIAL_CASE_FORMS_2的永久表 您可以将此表用于现有报告,因此您需要确保所有报告都经常更新 您甚至不需要在每次执行查询时都创建表...只需在数据库中手动创建一次,并使用以下代码替换查询开头的create table行:

delete from SPECIAL_CASE_FORMS_2

另外,你可以在最后删除这一行:

select  * from SPECIAL_CASE_FORMS_2

现在create a SQL Server Agent job执行您的查询 您可以将完整的查询粘贴到the "Command" field,也可以将查询保存为存储过程,只需在作业中执行存储过程。
(我更喜欢后者,因为这样,实际代码与表在同一个数据库中 - SQL Server代理作业保存在msdb系统数据库中)

安排作业,使其每天运行一次。

就是这样!

现在,作业将每天删除并重新填充SPECIAL_CASE_FORMS_2表格一次,您可以在所有报告中使用该表格。
如果将新表添加到数据库,则其中的数据也会在第SPECIAL_CASE_FORMS_2表中显示在第二天。
(如果您在第二天之前需要它,只需安排SQL Server代理作业,使其每天运行几次)

另外,您的报告将以这种方式运行得更快,因为它们只是从预先填充的表中获取数据 上面的查询循环遍历几个表并将数据插入到新表中,因此对每个报表再次执行此操作会更慢并导致数据库负载更大。

答案 1 :(得分:0)

我认为CTE比光标更合适,所以也许试试这个

use LaganPDM 

Create view as [dbo].[test]
With cteTables as (
select
*
from 
information_schema.tables 
where table_name like '%SPECIAL_UP_C00%' and left(right(table_name, 24),9) > '101000363' and not left(right(table_name, 24),9) in('101000487', '101000507', '101000510'))
Select
* -- because it's a view, you'll have to list all the columns instead of just using select *
From
CteTables

关于CTE的警告,但如果你经历了大量的记录,它可能会出现性能问题,所以请记住这一点。