持久对象原生数据库查询语言设计白皮书-huihoo.pdfVIP

持久对象原生数据库查询语言设计白皮书-huihoo.pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
持久对象原生数据库查询语言设计白皮书-huihoo

持久对象原生数据库查询语言 设计白皮书 William R. Cook Carl Rosenberger Department of Computer Sciences db4objects Inc. The University of Texas at Austin 1900 South Norfolk Street Austin, TX 78712-0233, U.S.A. San Mateo, CA, 94403, U.S.A. wcook@ carl@ 2005 年8 月23 日 摘要 大部分 Java 和 .NET 持久架构提供的接口在执行查询时必须以 架构特定的查询语言书写。这些接口是基于字符串的:查询语句 被定义在字符串中,并通过持久引擎进行解释。基于字符串的查 询接口对程序员的生产力有相当大的负面影响。对于像编译时的 类型检查、自动对齐、重构,这些开发环境特性,查询语言是不 可用的。程序员必须用两种语言开展工作:程序实现语言和数据 库查询语言。本文介绍原生数据库查询语言,以简练且类型安全 的方式直接使用 Java 和 C# 方法表达查询。探讨了原生数据库 查询语言设计并提供了概括性的实现和优化方面的议题。同时, 本文也探讨了目前原生数据库查询语言设计的优势和劣势。 1 介绍 当今的对象数据库和对象关系映射(ORM )工具在对象持久化做出了巨大的成就,让开发 者能很自然的进行对象持久化,而在面向对象程序中的查询语言看起来有些不协调。这些 查询语言用单一的字符串表达,或利用对象视图把分散的字符串组合起来。让我们看一小 段例子。 本文中所有例子,我们都使用下面的类: // Java public class Student { private String name; 1 private int age; public String getName(){ return name; } public int getAge(){ return age; } } // C# public class Student { private string name; private int age; public string Name { get { return name; } } public int Age { get{ return age; } } } 怎样利用现有的对象查询语言或 API 找到“年龄小于 20 岁的所有学生”? OQL [8, 1] String oql = select * from student in AllStudents where student.age 20; OQLQuery query = new OQLQuery(oql); Object students = query.execute(); JDOQL [7, 9] Query query = persistenceManager.newQuery(Student.class, age 20);

文档评论(0)

laolao123 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档