数据库自动抽取-SQL

背景:MSSQL 2012

功能:

1、新建B数据库

2、从A数据库 自动查询多个表中指定条件的数据,并保存到B数据库

3、自动将B数据库分离

代码如下:

 -- 创建数据库
CREATE DATABASE [SmallNozzleTest-Temp]
 CONTAINMENT = NONE
 ON  PRIMARY 
( NAME = N'SmallNozzleTest-Temp', FILENAME = N'D:\SmallNozzleTest-Temp.mdf' , SIZE = 20480KB , MAXSIZE = UNLIMITED, FILEGROWTH = 20480KB )
 LOG ON 
( NAME = N'SmallNozzleTest-Temp_log', FILENAME = N'D:\SmallNozzleTest-Temp_log.ldf' , SIZE = 20480KB , MAXSIZE = UNLIMITED, FILEGROWTH = 10%)
GO

--查询数据到并保存到此数据库 
 declare @i int;
 declare @max int;
 declare @table_run varchar(60);
 declare @table_save varchar(60);
 declare @str varchar(200);

 set @i=1;
 set @max=35;
 

 while @i <@max
 begin
 set @table_run=  '[SmallNozzleTest].[dbo].[loop_'+CONVERT(varchar(5),@i)+']'; 
 set @table_save= '[SmallNozzleTest-Temp].[dbo].[loop_'+CONVERT(varchar(5),@i)+']'; 
	  
	  IF EXISTS(SELECT * FROM sysobjects WHERE id=object_id(@table_save) AND OBJECTPROPERTY(id,'IsUserTable') = 1) --表是否存在
	  begin
	exec( ' drop table '+ @table_save);
	end

 set @str=' select * into '+ @table_save+'  from '+ @table_run +
        '  where collectTime like ''2018-08-2%'' or collectTime like ''2018-09-30'' ' ;
 
 exec(@str); 
 set @i=@i+1;
 end
 
 
--分离此数据库
 
use master
go 
exec sp_detach_db 'SmallNozzleTest-Temp'
go

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值