多分库多分表(结构相同)脚本创建联合视图

简介:
-- 今天有需要写了一个  
  
  
-- 测试测下:  
CREATE   DATABASE   [ db1 ]    
CREATE   DATABASE   [ db2 ]    
  
USE   [ db1 ]   
CREATE   TABLE   [ dbo ] . [ table1 ] ( [ id ]   [ int ] , [ name ]   [ varchar ] ( 20 ))   
CREATE   TABLE   [ dbo ] . [ table2 ] ( [ id ]   [ int ] , [ name ]   [ varchar ] ( 20 ))   
CREATE   TABLE   [ dbo ] . [ table3 ] ( [ id ]   [ int ] , [ name ]   [ varchar ] ( 20 ))   
  
USE   [ db2 ]   
CREATE   TABLE   [ dbo ] . [ table4 ] ( [ id ]   [ int ] , [ name ]   [ varchar ] ( 20 ))   
CREATE   TABLE   [ dbo ] . [ table5 ] ( [ id ]   [ int ] , [ name ]   [ varchar ] ( 20 ))   
CREATE   TABLE   [ dbo ] . [ table6 ] ( [ id ]   [ int ] , [ name ]   [ varchar ] ( 20 ))   
  
  
  
-- 格式如下(比较规律!):  
select   *   from  db1.dbo.table1  
select   *   from  db1.dbo.table2  
select   *   from  db1.dbo.table3  
  
select   *   from  db2.dbo.table4  
select   *   from  db2.dbo.table5  
select   *   from  db2.dbo.table6  
  
  
select  name  from  master.sys.databases  where  name  like   ' db[0-9]% '   -- 数据库名称格式  
select  name  from  sys.tables  where  name  like   ' table[0-9]% '     -- 表名称格式  
  
  
-- 不是动态创建,需手动指定:数据库格式名。表格式名,视图名称  
  
  
  
  
-- 将数据库名和表名关联  
--
  drop table #db_table  
create   table  #db_table(dbname  varchar ( 50 ),tabname  varchar ( 50 ),mk  bit )   
  
declare   @dbname   varchar ( 50 )  
declare   @exec   varchar ( max )  
set   @exec   =   ''   
declare  cur_db  cursor   for   
select  name  from  master.sys.databases  where  name  like   ' db[0-9]% '   order   by  name  -- 更改数据库名  
open  cur_db  
fetch   next   from  cur_db  into   @dbname   
while   @@FETCH_STATUS   =   0   
begin   
     set   @exec   =   ' select  ''' + @dbname + ''' ,name,0 from [ ' + @dbname + ' ].sys.tables where name like  '' table[0-9]% ''  order by name  ' -- 更改表名  
     insert   into  #db_table  exec ( @exec )  
fetch   next   from  cur_db  into   @dbname   
end   
close  cur_db  
deallocate  cur_db  
  
  
--   select * from #db_table  
--
  update #db_table set mk = 0  
  
  
  
-- 将各表创建合并视图  
set  nocount  on   
declare   @db_name   Nvarchar ( 50 )  
declare   @tab_name   Nvarchar ( 50 )  
declare   @col_name   Nvarchar ( 4000 )  
declare   @sql   Nvarchar ( max )  
declare   @sql1   Nvarchar ( max )  
set   @sql1   =  N ''   
set   @col_name   =  N ''   
set   @sql   =  N '  create view v_table_all  ' + CHAR ( 10 ) + '  as  ' + CHAR ( 10 -- 更改视图名称  
  
while   exists ( select   *   from  #db_table  where  mk = 0 )  
begin   
     select   top   1   @db_name = dbname, @tab_name = tabname  from  #db_table  where  mk = 0    
     set   @col_name   =   ''   
      
     set   @sql1   =  N ' select @col_name = @col_name + name+ '' , ''  from [ ' + @db_name + ' ].sys.columns where object_id=object_id( '' [ ' + @db_name + ' ].dbo.[ ' + @tab_name + ' ] '' ) '   
     exec  sp_executesql  @sql1 ,N ' @col_name varchar(4000) output ' , @col_name   = @col_name  output  
      
     set   @col_name   =   left ( @col_name , LEN ( @col_name ) - 1 )  
  
     set   @sql   =   @sql   +   '  select  ' + @col_name + '  from [ ' + @db_name + ' ].dbo.[ ' + @tab_name + ' ] union all ' + CHAR ( 10 )  
      
     update  #db_table  set  mk  =   1   where  dbname = @db_name   and  tabname = @tab_name   
end   
set   @sql   =   left ( @sql , LEN ( @sql ) - 10 )  
set  nocount  off   
print ( @sql )  
-- exec(@sql)  
  
  
/* --输出结果:  
 create view v_table_all   
 as   
 select id,name from [db1].dbo.[table1] union all  
 select id,name from [db1].dbo.[table2] union all  
 select id,name from [db1].dbo.[table3] union all  
 select id,name from [db2].dbo.[table4] union all  
 select id,name from [db2].dbo.[table5] union all  
 select id,name from [db2].dbo.[table6]   
*/   
目录
相关文章
|
8月前
|
存储 算法 关系型数据库
Mycat【Mycat分片技术(水平拆分-分表、ER表、全局表)】(五)-全面详解(学习总结---从入门到深化)
Mycat【Mycat分片技术(水平拆分-分表、ER表、全局表)】(五)-全面详解(学习总结---从入门到深化)
182 0
|
3月前
|
中间件 数据库连接 API
C#数据分表核心代码
C#数据分表核心代码
50 0
|
SQL 中间件 关系型数据库
MyCat - 分片 - 垂直拆分 - 全局表配置 | 学习笔记
快速学习 MyCat - 分片 - 垂直拆分 - 全局表配置
MyCat - 分片 - 垂直拆分 - 全局表配置 | 学习笔记
|
Web App开发 API 数据库
零代码实现一对一表关系和无限主子表级联保存
本文主要介绍一对一关系和无限主子表在crudapi系统中的应用。一对一关系是指关系数据库中两个表之间的一种关系。关系数据库中第一个表中的单个行只可以与第二个表中的一个行相关,且第二个表中的一个行也只可以与第一个表中的一个行相关。
317 0
零代码实现一对一表关系和无限主子表级联保存
|
数据库
【自然框架】元数据的数据库结构的详细说明和示例(三):项目与数据库字段的关联
【自然框架】PowerDesigner 格式的元数据的表结构 【自然框架】元数据的数据库结构的详细说明和示例(一):项目描述部分 【自然框架】元数据的数据库结构的详细说明和示例(二):数据库描述部分     1、Manage_FunListCol(列表用字段) 字段名...
980 0
|
存储 索引 数据安全/隐私保护