




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Tapestry4.1.2入门| 转帖小英的作文(超级爆笑)2008-07-14iBATIS框架理论学习篇关键字: ibatis iBATIS框架学习20070409作者:kimsoft自己整理的对iBATIS框架的一些简单理论知识,有助于进一步了解和深入学习iBATIS框架,错误或不当之处,在所难免。1、什么是iBATIS1.1作者 Clinton Begin,很牛X的名字1.2背景故事 Clinton Begin于2001年启动iBATIS项目,最先的焦点是发展密码软件解决方案。第一个iBATIS产品是Secrets,是一个象PGP的个人数据加密器和签名工具。Secrets完全用Java编写并在一个开源许可下发布。 在发布Secrets Java版后不久,iBATIS项目陷入困境转而关注Web和其它internet相关的技术,在接下来的一年中,两个有趣的软件开发完成,包括Axle web 框架,一个JSP可选工具。Lookout邮件客户端差不多完成90%在 being set on the back burner之前,同时更多有趣的挑战接踵而来1.3加入Pet Store“基准” 在2002年早些时候,Microsoft发布一个纸面文档声称.NET有10倍于J2EE的速度和4倍多的生产效率。事实是这只是简单的而不是典型的。iBATIS项目在2002年7月1日快速回应,JPetStore 1.0发布了。基于相同的Pet Store需求,JPetStore证明了Java不仅比.NET更有生产效率,同时比Microsoft的实现拥有更好的架构。 JPetStore利用有趣的持久层迅速地引起了开源社区的关注。在JPetStore发布不久,对SQL Maps和DAO框架的问题和要求使大家知道的iBATIS Database Layer产生了。iBATIS Database Layer包含两个被打包在一起的框架:SQL Maps和DAO。 如今iBATIS项目重点关注持久层框架并以SQL Maps 和 Data Access Objects (DAO)著称。JPetStore继续作为这些框架典型应用的官方示例程序。1. 4“iBATIS”是什么意思 现在,单词“ibatis”和SQL Maps与 DAO框架同义就象“xerox”施乐复印机(商标名称),译者著和“photocopy” 影印,译者著同义。 回想起iBATIS来源于密码系统软件。iBATIS实际上用两个单词的组合来命名:“internet” 和 “abatis”。R 如此定义 abatis:ab-a-tisn. pl. ab-a-tis (-tz) or ab-a-tis-es (-t-sz)将伐倒的树木树枝相互交叉,放置,有时削尖,面对敌人一种防御障碍物。将“Internet”中象征性的“i”和abatis中的“batis”组合所以暗示了抵御Internet的意思。-in the case of iBATIS它是Secrets提供的关于密码防御的东西。所以iBATIS正确的写法应该是:iBATIS1.5 iBATIS怎么念? 因为我们发明了这个单词,我们以自己喜欢的读音念它 我们这样读:eye-BAT-iss但是按照传统,它可能应该被读作:eye-BATE-iss,但就象我们说的,我们创造了它。1.6许可(License)iBATIS的源码和文档在Apache License 2.0许可下发布。 以上部分文字翻译自,不妥之处,请指正。1.7版本情况iBATIS有for Java,for .NET,for Ruby三个语言的版本,以下主要讨论for Java版,也是最重要的版本。 关于版本,看下面一段英文:/confluence/oss/display/IBATIS/iBATIS+3.0+Whiteboard iBATIS 3.0 Whiteboard January 11th, 2007 marks the 3rd Anniversary(周年纪念) of the iBATIS 2.0. It has served the community well for three years, but times change. The year 2006 was full of innovation(改革、创新) and shifts in technology and mindset. The impact(冲击,碰撞) of frameworks like Ruby on Rails cannot be ignored. The industry has noticed and finally invested in lightweight frameworks, agile principles and simple solutions first. 最新版本:iBATIS2.3.0 build667,非常稳定。 1.8 典型用户 MyS - A place for friends 2、当前Java平台下的一些DAO框架2.1Hibernate 应该是最好的ORM框架,ORM:Object Relation Mapping,即对象关系映射。了解不是很多,不多作评价。不过应该是很好的框架,EJB3里的JPA所说差不多就是简化版的Hibernate,侧重于对象模型设计,系统设计中数据库设计让位于对象模型设计。2.2 Apache JDO Apache组织的一个比较早的开源框架,影响力不大。2.3 Spring DAO(Template) Spring DAO对JDBC进行了封装 用得最多的还是各种Template:JdbcTemplate HibernateTemplate SqlMapTemplate JdoTemplate JpaTemplate2.4 JDBC 对数据库操作最原始的办法,也是根本,无所不能的。2.5 iBATIS 又称为SQL Map或 Data Map(2.0以后) SQL Mapping framework更准确地说是 SQL Mapping tool,是一个SQL语句映射的框架(工具)2.5.1介绍(Introduction)The iBATIS Data Mapper framework will help you to significantly(意味深长地,值得注目地) reduce the amount of Java code that you normally need to access a relational database. iBATIS simply maps(此处应译作映射) JavaBeans to SQL statements using a very simple XML descriptor. Simplicity(简单) is the key advantage(优势,有利条件) of iBATIS over other frameworks and object relational mapping tools. To use the iBATIS Data Mapper you need only be familiar with JavaBeans, XML and SQL. There is very little else to learn. There is no complex scheme required to join tables or execute complex queries. Using Data Mapper you have the full power of real SQL at your fingertips.2.5.2 概念(Concept)The iBATIS Data Mapper API allows programmers to easily map JavaBeans objects to PreparedStatement parameters and ResultSets. The philosophy behind Data Mapper is simple: provide a simple framework to provide 80% of JDBC functionality using only 20% of the code. 3、学习iBATIS3.1 一个简单的iBATIS原型 SELECT COUNT(*) FORM USER 讨论:一、用JDBC直接在页面中如何写程序二、多个JSP文件同时出现此功能时三、出现不同的版本,SELECT COUNT(*) FORM USER WHERE USER_TYPE=1 AND IS_DEL=0四、讨论各个版本的输入输出参数3.2 iBATIS 藏宝图讨论:iBATIS各种输入输出参数3.3 iBATIS API(Spring SqlMapClientTemplate API)第一个参数statementName都是必须的,其它参数都是可选的增、删、改public Object insert(String statementName, Object parameterObject)public int update(String statementName, Object parameterObject)public int delete(String statementName, Object parameterObject) 查询public Object queryForObject(String statementName, Object parameterObject)public List queryForList(String statementName, Object parameterObject)void queryWithRowHandler (String statementName, Object parameterObject, RowHandler rowHandler) 不常用public PaginatedList queryForPaginatedList(String statementName, Object parameterObject, int pageSize) 性能问题,已经被废弃(deprecated)public Map queryForMap (String statementName, Object parameterObject, String keyProperty, String valueProperty)没有了 4.使用iBATIS的好处 4.1简单,学习曲线低 4.2使用公司投资回报率提高,一般是5到8倍 4.3喝着Java(咖啡)写Java代码,节省大量编码维护时间 4.4提高员工土气 4.5性能好,灵活性强 4.6集中管理后,DAO的实现简单,使用开发人员更专心于业务逻辑的处理。修改时不用修改Java代码。 4.7使用preparedStatement,性能,安全性提高,代码简洁。 4.8配置log4j在调试时输出SQL语句和返回记录集,漫天飞舞的System.out.print不见了。 4.9不用担心,连接、记录集的关闭 4.10缓存,讨论:很小变动的基础数据。 4.11写程序时很自然地优化SQL,减少数据库的连接次数和操作次数 讨论: 一级分类1 二级分类1.1 二级分类1.2 一级分类2 二级分类2.1 二级分类2.2 一级分类3 二级分类3.1 二级分类3.2 讨论遗漏的好处。 讨论缺点5.iBATIS的配置文件有两种:5.1 sqlMapConfig文件 只有一个,集中管理配置文件的“中央文件” 5.1 各个SQL Map 文件 and boardname like #map.boardname# and islogo=#islogo# select id, boardname, readme, url, logo, islogo from dv_bbslink where id = #id:INTEGER# select id, boardname, readme, url, logo, islogo from dv_bbslink where 1=1limit 0, #row.count# select count(*) from dv_bbslink where 1=1 select id, boardname, readme, url, logo, islogo from dv_bbslink where 1=1limit #row.first#, #row.count# insert into dv_bbslink (boardname, readme, url, logo, islogo) values (#boardname#,#readme#,#url#,#logo#,#islogo#)SELECT LAST_INSERT_ID() update dv_bbslink setboardname = #boardname#,readme = #readme#,url = #url#,logo =#logo#,islogo = #islogo#where id = #id:INTEGER# delete from dv_bbslink where id = #id# delete from dv_bbslink 6、实例(MySQL)一个论坛链接的表,分为LOGO链接,文字链接,有如下字段6.1 数据库表(dv_bbslink)Id 自增ID(INTEGER)Boardname 论坛名称(VARCHAR)Readme 说明(VARCHAR)url 链接地址(VARCHAR)logo LOGO图片地址(VARCHAR)islogo 是否是LOGO链接(INTEGER) 6.2 写一个Domain(POJO,Model)Link.java private Integerid; private Stringboardname; private Stringreadme; private Stringurl; private Stringlogo; private Integerislogo; /getters and setters 6.3 写接口(LinkDao) 常用接口 根据业务逻辑生成特定的接口 LinkDao.javapublicinterface LinkDao Integer insertLink(Link link); int updateLinkByPrimaryKey(Link link); int updateLinkByPrimaryKeySelective(Link link); int deleteLink(Link link); int deleteLinkByPrimaryKey(Integer id); List selectLinkList(Link link); List selectLinkPaginatedList(Link link); Link selectLinkByPrimaryKey(Integer id); Integer selectLinkCount(Link link);6.4 写实现(LinkDaoSqlMapImpl)public class LinkDaoSqlMapImpl extends SqlMapClientDaoSupport implements LinkDao public int deleteLink(Link link) int rows = super.getSqlMapClientTemplate().delete(deleteLink, link);return rows; public Integer insertLink(Link link) Object newKey = super.getSqlMapClientTemplate().insert(insertLink, link);return (Integer) newKey; public Link selectLinkByPrimaryKey(Integer id) Link key = new Link();key.setId(id);Link record = (Link) super.getSqlMapClientTemplate().queryForObject(selectLinkByPrimaryKey, key);return record; public Integer selectLinkCount(Link link) return (Integer) super.getSqlMapClientTemplate().queryForObject(selectLinkCount, link); public List selectLinkList(Link link) return (List) super.getSqlMapClientTemplate().queryForList(selectLinkList, link); public List selectLinkPaginatedList(Link link) return (List) super.getSqlMapClientTemplate().queryForList(selectLinkPaginatedList, link); public int updateLinkByPrimaryKey(Link link) int rows = getSqlMapClientTemplate().update(updateLinkByPrimaryKey, link);return rows; public int updateLinkByPrimaryKeySelective(Link link) int rows = getSqlMapClientTemplate().update(updateLinkByPrimaryKeySelective, link);return rows; public int deleteLinkByPrimaryKey(Integer id) int rows = super.getSqlMapClientTemplate().delete(deleteLinkByPrimaryKey, id);return rows; 6.5配置SQL Map 分析SQL Map 文件6.7 配置 Spring Stru
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 社区治安应急知识培训课件
- 可爱情侣合同范本
- 光纤铺设合同范本简报
- 保洁合同范本清扫垃圾
- 废纸销售维修合同范本
- 迈瑞保修合同范本
- 绿化栽植承揽合同范本
- 社区应急知识培训课件
- 车辆销售代购合同范本
- 个人车位销售合同范本
- 2024-2025学年人教版数学七年级下册期末测试卷 (含答案)
- 篮球-传切配合 教学设计-2023-2024学年高三上学期体育与健康人教版必修第一册
- 抗诉申请书范本
- 《室上性心动过速》课件
- 传感器概述课件
- 2025年国家电网公司招聘笔试参考题库含答案解析
- “医养结合嵌入式”养老模式的必要性、困境与对策研究
- 叉车操作人员培训课件
- 《培训电气基础知识》课件
- 《高血压精准化诊疗中国专家共识(2024)》解读
- 有关化工厂设备培训内容
评论
0/150
提交评论