我爱Aspx >> 数据库 >> 关键数据库安全保护中的最快最可靠方法
快照复制
这个解决方案有效,但是也有几项例外。例如,如果表中有用户自定义数据类型,并且必须在表被创建之前创建,那么由于在SQL Server2000没有CREATE TYPE这个命令,就会失败。
SQL 追踪
用SQL Server Profiler 或者SQL Trace可以捕捉到工作量,并且导出到 SQL 脚本中。脚本可以在从数据库中再次运行。
这个解决方案存在的问题包括:
1、执行的命令是有一定顺序的。如果一个事务在一个单独的执行中被打开或者关闭了,而这个操作不是这一系列命令中的一个,那么脚本就无法使其发生关系,因为“会话”无法被Traces识别了。
2、如果在两个版本之间,命令语法有区别,那么在从数据库中的执行一定会失败。
编程
如果你有一小批数据库要移植,那么你可能会考虑编写一个数据库组件来传输数据的修改。
示例:
· 使用触发器——这可能会影响性能,因为触发器是事务的一部分。
· 使用DTS或者BCP来传输数据——这种方法在很大程度上依赖数据量的大小。
第三方工具
你可以使用第三方工具,例如Log Readers来从事务日志、脚本中读取SQL 命令,然后在从数据库中执行它们。还有,虽然我无法自己找到这样的一个工具,但是在SQL Server 2005中肯定会有一个工具能够备份事务日志,并且在SQL Server2000中顺利地重新存储它们。
其它
你还可以创新……
例如,在某些情况下,你可以将日志传送到从SQL Server 2005数据库中,把它的兼容级别改为80,然后备份并重新存储到第三个数据库中去。
结论
对于关键的数据库,保留要升级的数据库的旧的版本,以及最新的数据修改,以便在需要回滚的时候用到,确实是个好主意。
但是……任何事物都没有“最好的解决方法”。你必须分析你的数据库特点和结构,然后决定针对你的需求的最佳解决方法。就我个人来说,我倾向于认为复制是最快最可靠的解决方法。
主流数据库集群技术深入探讨[04-21]
Oracle履行对嵌入式数据库的承诺[04-21]
原生XML数据库(NXD)为什么如此受..[04-21]
XML+SQL=数据库的未来?[04-21]
优化数据库大幅度提高Oracle的性..[04-21]
使用Oracle9i全索引扫描快速访问..[04-21]
如何从优化SQL入手提高数据仓库的..[04-21]
Oracle数据库系统性能优化[04-21]
透视MySQL数据库之更新语句[04-21]
ETL学习心得:探求数据仓库关键环..[04-21]
主流数据库集群技术深入探讨[04-21]
Oracle履行对嵌入式数据库的承诺[04-21]
英特尔多核平台编程优化大赛最新..[04-21]
原生XML数据库(NXD)为什么如此受..[04-21]
XML+SQL=数据库的未来?[04-21]
优化数据库大幅度提高Oracle的性..[04-21]
使用Oracle9i全索引扫描快速访问..[04-21]
英特尔多核平台编程优化大赛最新..[04-21]
英特尔多核平台编程优化大赛最新..[04-21]
如何从优化SQL入手提高数据仓库的..[04-21]