转自:http://www.maomao365.com/?p=6864

转自: http://www.maomao365.com/?p=5277
摘要:
下文首要呈报,怎么样对”已上线的系统”中的表,扩展新的字段。

Oracle 数据水库蓄水容量易合作

摘要:


 

下文汇报接受sql脚本批量刨除全部存款和储蓄进程的办法,如下所示:
实验景况:sqlserver
2010 Lacrosse2

系统布局脚本,扩充列的措施:
在系统脚本发表中,如何是积攒进度 自定义函数
视图的改动和新添,大家日常使用以下步骤来编排此类脚本
1 判别指标(存款和储蓄进度 自定义函数
视图卡塔 尔(英语:State of Qatar)是或不是留存,如何存在大家就删除对象(存储进程 自定义函数 视图卡塔 尔(英语:State of Qatar)
2 新建对象
<hr />
可是扩展系统字段(列)时,大家无法运用删除表,然后重新的主意举办脚本管理,
那么我们平常选择先推断列是不是留存,要是不设有就创造列,假如存在就矫正列属性<span
style=”color:red;font-weight:bold;”>(修正列属性–请留意是还是不是会影响历史数据)</span>
例:

前提:


IF NOT EXISTS(SELECT * FROM SYS.COLUMNS 
WHERE OBJECT_ID = OBJECT_ID(N'表名') 
AND NAME = '列名') ---判断列是否存在
begin
---增加列
alter table [表名] 
add column [列名] [列类型]
end
else
begin
---修改列属性
alter table [表名] 
add column [列名] [列类型]
end
  1. 不保证实时性,只是通过job的议程准期同步
  2. 只同步表中的数据,不保留别的数据
  3. 在用脚本开头化后,不可能再扩展表或删除表,或转移表结果,假诺产生则需求再行开始化表。
  4. 在初阶化的时候,最佳把数据库改为非归档情势,不然会发生多量的存档日志,假设归档

平凡使用sql脚本,删除存款和储蓄进度,我们只好选用删除命令一条一条的删减存储进程,下文介绍风流罗曼蒂克种方便人民群众方法,能够对系统中具备的仓库储存进度举行删除,
<span style=”color:red;”>
得以实现思路:
1 接纳有的时候表将储存进度名称缓存
2 通过轮回有的时候表,输出删除存款和储蓄进度脚本
3 履行脚本

运用上述办法编写sql安排脚本的帮助和益处为,sql脚本得以实施数十次,不会自然则然报错新闻,能够制止已经手动扩张列的数据库发生计划错误提醒信息

 

declare @t table(keyId int identity(1,1),tableName varchar(256))
----生成临时表
insert into @t(tableName) 
select [name] from sysobjects where type='P'

declare @i int @iMax int ,@info varchar(256)
set @i =1 
select @imax=max(keyId) from @t as t

while @i <@imax
begin
select @info = t.tableName from @t as t where t.keyId =@i

if @info is not null 
begin
exec ('drop proc '+@info) ---遍历删除存储过程
end 

set @i = @i+1 
set @info =null 
end

* *

方式:

 

  1. 利用数据链的主意将数据从源复制到备份库。
  2. 行使触发器跟踪表中多少的转换,富含insert,update,delete
  3. 使用job的方法按期同步

 

步骤:

  1. 在源数据库中按梯次试行四个剧本:s1.source_create_sync-trigger.sql,s2.source_sync_update_sync_id.sql,s3.source_init.sql.
  2. 在备份库上成立数据库链连接到源库,数据库链名称为remote
  3. 在备份库上按梯次施行三个剧本:d1.destination_sync_table_data.sql,d2.destination_sync_all_data.sql,d3.destination_inin_tables.sql.
  4. 调用存款和储蓄进程sync_all_data就能够生龙活虎并数据

下载文件:backscript.rar

相关文章