没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|其它|编辑:郝浩|2009-06-16 17:09:30.000|阅读 412 次
概述:虽然说SQL Server 2008到目前为止已经算是新版本的数据库系统了。但是其以后还会不断的更新换代。为此在部署SQL Server 2008的时候,数据库管理员仍然需要考虑到向后兼容性的问题。为了减少以后升级的麻烦,数据库管理员有必要了解这个话题。具体来说,就是要了解 SQLServer2008的数据库版本中,哪些功能可能在以后的数据库版本中会被抛弃。然后数据库管理员在部署这些功能时,要慎重。能够不用就不用,或者用其他功能来代替。免得在以后数据库升级过程中,再来进行调整。笔者现在就以数据复制功能为例,谈谈如何做好这个向后的兼容性
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
虽然说SQL Server 2008到目前为止已经算是新版本的数据库系统了。但是其以后还会不断的更新换代。为此在部署SQL Server 2008的时候,数据库管理员仍然需要考虑到向后兼容性的问题。为了减少以后升级的麻烦,数据库管理员有必要了解这个话题。具体来说,就是要了解 SQLServer2008的数据库版本中,哪些功能可能在以后的数据库版本中会被抛弃。然后数据库管理员在部署这些功能时,要慎重。能够不用就不用,或 者用其他功能来代替。免得在以后数据库升级过程中,再来进行调整。笔者现在就以数据复制功能为例,谈谈如何做好这个向后的兼容性。
一、 在SQL Server 2008中不推荐使用事务复制的订阅过期。
其实这个订阅保持期就好像是一个“有效期”或者叫做“质保期”。如果数据库系统未能够在有效的“质保期”内完成同步订阅工作,则这订约作业就会停用 或者过期。如假设最大的分发保持期为72小时(这是SQLServer数据库的默认设置,管理员可以根据实际情况来调整),如果订阅未能够在72小时内同 步的话,而且分发数据库中还存在尚未传递到订阅服务器的更改,则订阅作业将会被分发服务器上运行的“清除分发”作业标记为停用。此时数据库管理员如果要重 新启用这个订阅功能的话,那么就必须重新初始化订阅。
而在数据库中,主要是这个sp_addpublication过程来控制这个订阅周期。在这个存储过程中,有一个@retention 属性。这个属性主要用来设置订阅活动的保持期。默认情况下这个属性的值为336小时。如果订阅活动在保持期内不活动的话,则过期后系统就会将其自动删除。 一般来说,这个值可以大于发布服务期使用的分发数据库的最大保持期。也就是说,他们具有一定的独立性。如果数据库管理员想让订阅永远不过期的话,则只需要 将这个参数设置为0即可。不过根据微软的官方资料可以知道,这个参数的话在以后的版本中可能会被逐渐的淘汰。因为这个属性如果设置不当的话,会给合并复制 造成一系列的不利影响,影响合并复制作业的稳定性。为此数据库管理员在部署复制作业时,最好不要使用这个参数,以免跟后续的数据库版本不兼容。
如果一定要使用这个参数的话,那么最好能够遵循下面的一些建议。
一是如果采用合并复制,那么合并发布的保持期最好给一个宽限期。因为可能数据库部署在不同的时区,如果没有宽限期的话,那么这些分布在不同时区中的 订阅服务器,运行起来就可能会出现问题。为此笔者建议,通常情况下需要给其一个24小时的宽限期。即使现在企业用不到,但是随着后续规模的扩大,很有可能 要在不同的国家设置数据库服务器。如美国的企业,可能会在国内的办事处设置一台订阅服务器,以提高办公的效率。此时就应该为其设置24小时的宽限期。
二是尽量不要将这个参数设置为0。如果把这个参数设置为0,就表示没有保持期的限制。虽然这从某个程度来讲,可以简化数据库管理员的维护工作。但是将这个参数的值设置为0,可能会产生一系列的负面效应。如此时数据库系统将无法删除元数据等等。
为此,笔者的建议时,在实现复制服务时,最好不要采用这个参数。如果一定要用的话,那么要给其设置一个合理的宽限期;并且最好不要将这个参数设置为0。虽然这不是强制性的规定,但是为了复制服务能够稳定运行,各位数据库管理员最好还是好好考虑笔者的这个建议。
二、 非SQL Server订阅服务器的处理。
SQL Server数据库在横向的兼容性上表现还是不错的。其不但可以支持SQL Server订阅服务器,还能够支持非SQLServer的订阅服务器。如果企业需要采用非SQLServer的订阅服务器,那么有两个实现的渠道,分别 为ODBC与OLE DB。不过由于ODBC其在性能、安全上都不如OLE DB接口,为此在后续的版本中,微软数据库可能不会再支持ODBC接口。所以在2008版本中实现订阅服务器的话,那么最好不要再使用这个ODBC接口, 而改用OLE DB接口。
到目前为止,SQL Server数据库支持Oracle与IBMDB2两 个产品的订阅服务期。如果要支持者两个数据库服务器的话,SQL Server现在已经提供了比较完备的OLE DB访问接口。为此数据库管理员也不用再担心接口不兼容的问题。不过采用这个非微软的订阅服务器,有比较多的限制条件。作为数据库管理员要了解这些限制条 件,并且在实际工作中一丝不苟的遵守它。类似的限制条件主要有以下几个方面。
如果订阅服务器即有SQL Server定于服务器,也有Oracle订阅服务器或者其他非微软的订阅服务器,那么必须先为Oracle等非微软的订阅服务期启用发布,然后再创建 SQLServer订阅服务器。数据库管理员只要用四个字就可以记住这个规则,即客人优先。另外,如果在这种混合型的订阅服务器,则必须要使用OLE DB访问接口,而不能够采用ODBC访问接口。而且运行分发代理时所使用的帐户必须对OLE DB访问接口的安装目录具有读取的权限。这也是为什么笔者强烈推荐使用OLE DB访问接口的原因。因为采用了这个接口之后,则以后如果要兼容其它订阅服务器,就是一个水到渠成的事情。不需要经过额外的调整与配置,就可以在对现有架 构影响不大的情况下部署非SQL Server的订阅服务器。
另外需要注意的是,不同的数据库处理NULL值的方式不同。为此采用不同牌子的订阅服务器,可能会影响到空值、空字符串和NULL值的显示方式,而 且这个显示方式又会影响在定义了唯一约束的列中插入值的行为。如在Oracle数据库中,如果在某一列中设置为了唯一行约束,那么这个列仍然可以具有多个 NULL值。但是在SQL Servre数据库中则不同。只要这个列设置了唯一行约束,那么这个列就职能够有一个Null值。所以,在混合型的订阅服务器中,有时候还需要通过应用程 序或者其他手段来消除这种差异。或者在数据库设计时,要有意识的避免这种情况,如禁用NULL值等等。或者可以跟Oracle或者IBM DB2的数据库管理员联系。往往这些大牌的数据库为了相互之间实现兼容,都会在数据库中预先实现了一些措施,来防止各个操作系统处理机制不同所导致的兼容问题。
三、 合并复制过程中同时更新多列。
在合并复制到过程中,可能需要对目标列同时进行更新。合并复制是支持这个功能的。在合并复制执行更新时,数据库会更新一个Update语句中指定的 所有列,并将没有更改的列重置为原先的值。不过合并复制更新往往涉及到比较多的记录,为此其执行速度会比较慢。为了提高这个执行的速度,在2008以前的 数据库系统汇总,为此专门设置了一个fase_multicol_updateproc。如需要合并复制时,会建议数据库管理员将这个选项设置为 false,以提高合并复制更新的执行效率。
不过在SQL Server 2008中,通过优化器数据库系统会自动对相关的合并复制更新语句进行优化。而且这个优化的效果比这个选贤设置为False还要明显。虽然在2008数据 库中,为了向前兼容还存在这个参数,不过其存在的实际意义已经不大。为此数据库管理员在需要各并复制更新时,不用为了提高其操作性能而再单独的去设置这个 参数。在以后的版本中,即使数据库管理员设置了这个参数,数据库系统也会忽略掉。
可见无论是在对数据库进行升级又或者部署最新版本的数据库时,管理员不仅需要考虑到向前兼容的问题(原有的设计要能够在新版数据库中实现),同时也 要考虑到数据库系统的向后兼容(尽量避免使用过时的功能或者即将不用的参数)。毕竟企业使用数据库是一个长久的过程,如往往一用就是几十年。在这么大的事 件跨度内,不知道会出现多少个数据库的版本。所以,数据库的向后兼容与数据库向前兼容一样的重要。不过相对来说,向后兼容可能实现起来相对容易一点。只要 数据库管理员了解哪些参数或者功能可能在后续版本中被淘汰,就可以做好这个向后兼容性的工作。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:自互联网面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号