国际教育在线 eduworld.com.cn  主页>IT计算机>数据库培训>>正文

[Sql server]CLR自定义类型存储对象

  问:我可以在SQL Server 2005中用CLR用户自定义类型来存储我的业务对象吗?

  答:实现SQL CLR用户自定义类型(UDT)非常简单,就像给.NET类或者结构添加一些额外的片断。其中就包括属性(SqlUserDefinedTypeAttribute),和接口(INullable),以及一些额外的方法(Null() and Parse())。这个简单性带来的后果就是,一个有经验的开发人员可以在不到5分钟的时间里把一个业务对象转换为SQL CLR 用户自定义类型。

  SQL Server 2005的设计目标并不是用于面向对象的数据库管理系统。它还是一个标准的SQL 数据库管理系统,并且用户自定义类型的能力也应该被当作是一种系统扩展的类型,而不是一个对象。开发人员在决定是否将现有的业务对象用作CLR UDT的时候,应该仔细权衡他们的选择。

  每次访问一个类型的实例的方法或者属性的时候,这个实例都应该在这个方法被访问之前串行化。因此,这最好是依靠那些基于他们的串行化字节的可比较的类型。开发人员应该尝试仅仅使用那些可以自动回答问题的用户自定义类型。例如,以下的C#类就不如用户自定义类型:

class Product
{
   public string Name;
   public string Description;
   public decimal price;
}

  如果一个查询是针对这样类型的字段,每个行都必须被反串行化以回答如下的问题,“什么产品价值10美元?”这是因为我们不能假设所有的10美元的产品都具有同样的二进制表示。对一个大表(例如一个有上百万产品的表)中的每个行都进行反串行化将会给性能带来严重的考验。

  除了性能挑战之外,还有标准化的问题。例如,假设这个类型,一个公司怎么能为同样的产品存储两种描述,并且还要确保产品只有一个有效的价格?

  最好是坚持使用那些可以回答问题,并且不会带来反串行化负担的类型。


【联系方式】

电 话:010-51260583 81616847 86325812
传 真:010-81616847
联系人:宋老师 杨老师
MSN:iamssnow@hotmail.com, yangminglee@hotmail.com
QQ:240632201, 675388743
E-mail:eduworld@163.com

【填写报名表】

请按要求填写下面的内容:咨询热线:010-81616847
所报课程
姓名 * 填写真实姓名(中文),以便与您联系。
联系电话 * 请留下在工作时间能联络到您的电话。
手 机 * 确保能及时与您取得联系。
电子邮箱 * 有助于您查询评估结果。
 
*如果您有特别要求,如帮别人咨询等,请在这里填写相关信息;
*国际教育在线网保证不将此信息透露于您申报院校外任何第三方。

【相关课程】

· [Sql server]两个SQL Server维护技巧      (2007-01-05)
· [Sql server]传给语句的输入数据验证      (2007-01-05)
· SQL Server 2005 SP1的新特性      (2007-01-05)

【信息提示】

英国诺森比亚大学法学院商法.. 美国林肯大学 MBA英文班       美国斯特福大学IMBA学位班    
加拿大皇家大学MBA学分转移学. 美国华盛顿理工大学工商管理硕 美国北弗吉尼亚大学工商管理硕
美国高登大学国际工商管理硕士 新加坡南洋理工大学南洋商学院 詹姆斯·库克大学MBA硕士学位.
网站介绍 | 经销渠道 | 招贤纳士 | 联系我们 | 友情链接
北京联盟创业网络技术有限公司版权所有 ICP京05059882
电话:(010) 51260583 81616847 86325812 传真:(010) 81616847
网址:www.Eduworld.com.cn
联盟创业广告(北京)有限公司设计制作