ibatis(1)ibatis的理念

【0】README
1)本文部分内容转自 “ibatis in action”,旨在 review “ibatis的理念” 的相关知识;

【1】结合所有优秀思想的混合型解决方案
在现实世界中,混合型解决方案随处可见。将两个看上去相悖的思想在中间处巧妙结合,被证明是一种有效的方法,它往往能够恰到好处地解决问题,在某些case下甚至会导致一些新兴行业的诞生;

汽车工业就是一个最典型的荔枝: 运输工具大部分的设计革新都来自于对不同思想的混合。将小轿车与大蓬货车结合最终形成了我们现在的家用房车。把卡车和越野车相结合,于是就有了现代城市人身份的象征——运动型多功能车(sport utility vehicle,SUV);将高速汽车与旅行汽车相结合,于是就有了驾驶起来很舒服的家用轿车。在汽油引擎旁边安装一个电力引擎,于是目前北美很多环境问题就都可以迎刃而解了;

ibatis 就是这样一种混合型解决方案;

【1.1】探索ibatis的根源
1)ibatis从目前最流行的关系数据库访问方法中吸收了大量的优秀idea,并找出其中的协同增效作用;

【1.2】理解 ibatis的优势
1)下表总结了 ibatis 所吸取的idea;

Attention)ibatis持久层所具有的两个最重要的特性: 外部化sql 和 封装 sql;(干货——ibatis最重要的两个特性——外部化sql 和 封装 sql;)

【1.2.1】外部化的SQL
1)problem+solution:
1.1)problem: 看如下sql,
SELECT
PRODUCTID,
NAME,
DESCRIPTION,
CATEGORY
FROM PRODUCT
WHERE CATEGORY = ?
-- 再看 sql 的字符串拼接,使得原本很简单的sql 变得难以管理;
String s = "SELECT"
+ " PRODUCTID,"
+ " NAME,"
+ " DESCRIPTION,"
+ " CATEGORY"
+ " FROM PRODUCT"
+ " WHERE CATEGORY = ?";
1.2)solution:使用ibatis你就可以按照最自然的方式书写sql,如下:
SELECTPRODUCTID,NAME,DESCRIPTION,CATEGORY
FROM PRODUCT
WHERE CATEGORY = #categoryId#

【1.2.2】封装SQL
1)intro:ibatis 使用 XML 来封装 SQL,选择XML 是因为它有很好的跨平台性,得到行业内广泛使用;
2)ibatis 允许你将输入输出参数映射为某些对象的特性,如下所示:
<select id="categoryById"parameterClass="string" resultClass="category">SELECT CATEGORYID, NAME, DESCRIPTIONFROM CATEGORYWHERE CATEGORYID = #categoryId#
</select>
Attention)注意包围在 SQL 语句周围的xml 元素这就是对 SQL 的封装;

【2】ibatis 适合用在何处
1)下图给出了一个典型的分层策略的高级视图:(箭头读作依赖或使用)

对上图的分析(Analysis):
A1)这种分层设计:来源于 德米特法则,该法则的另一种表达方式是:每一层都应该只对那些与自己紧密相关的层有优先的了解;
A2)每一层都与自己 的直接下层打交道:这就保证了依赖流只有一个方向,从而避免了 那种在没有分层设计的应用程序中非常普遍的 意大利面 式的代码;

【2.4】持久层
1)intro:持久层是 使用ibatis的地方;
2)持久层要关注: 对象的存取 + 抽象;
3)持久层分为三层:抽象层, 持久化框架, 驱动程序/接口层, 如下图所示;

3.1)抽象层:目的在于为持久层提供一致且有意义的接口;
3.2)持久化框架:负责与数据库驱动程序(或接口)的交互;且持久化框架通常只针对一类存储设施,如你可能会找到专用于处理 XML 文件的数据存储的持久化 API;
3.3)驱动程序/接口层: 在底层与 存储设施通信以交互数据;数据库驱动程序总是非常  complicated,所以就需要由持久化框架来与 这些驱动程序通信,从而将它们之间的不同简化并降低到最低点;

Attention)ibatis 支持将关系数据映射为 java 基本类型,map 实例,xml 还有用户定义类;
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/331104.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

究竟啥才是互联网架构“高并发”

转载自 究竟啥才是互联网架构“高并发”一、什么是高并发 高并发&#xff08;High Concurrency&#xff09;是互联网分布式系统架构设计中必须考虑的因素之一&#xff0c;它通常是指&#xff0c;通过设计保证系统能够同时并行处理很多请求。高并发相关常用的一些指标有响应时间…

ibatis(2)ibatis是什么

【0】README1&#xff09;本文部分内容转自 “ibatis in action”&#xff0c;旨在 review “ibatis是什么” 的相关知识&#xff1b;2&#xff09;intro to ibatis&#xff1a; ibatis 就是数据映射器&#xff0c;Martin Fowler在《企业应用架构模式》中&#xff0c;对 data m…

究竟啥才是互联网架构“高可用”

转载自 究竟啥才是互联网架构“高可用”一、什么是高可用 高可用HA&#xff08;High Availability&#xff09;是分布式系统架构设计中必须考虑的因素之一&#xff0c;它通常是指&#xff0c;通过设计减少系统不能提供服务的时间。 假设系统一直能够提供服务&#xff0c;我们说…

maven(3)maven3.3.9使用入门

【0】README1&#xff09;maven 安装step1&#xff09;检查 jdk 是否安装且 环境变量 JAVA_HOME 是否设置&#xff1b;step2&#xff09;download maven&#xff1a; https://maven.apache.org/download.cgi?Preferredftp://mirror.reverse.net/pub/apache/step3&#xff09;…

TCP接入层的负载均衡、高可用、扩展性架构

转载自 TCP接入层的负载均衡、高可用、扩展性架构 一、web-server的负载均衡 互联网架构中&#xff0c;web-server接入一般使用nginx来做反向代理&#xff0c;实施负载均衡。整个架构分三层&#xff1a; 上游调用层&#xff0c;一般是browser或者APP 中间反向代理层&#xff…

使用poi统计工作职责

1 创建一个新的sheet工作页 Sheet job workbook.createSheet("工作职责统计"); 2 查询工作职责问题选项列表&#xff0c;并设置第一行倒出时间 List<Syslistconfig> listconfigs syslistconfigDao.listConfig(29); //工作职责问题选项列表job.createRow(0)…

漫画:什么是字典序算法

转载自 漫画&#xff1a;什么是字典序算法&#xff1f;算法题目&#xff1a; 给定一个正整数&#xff0c;实现一个方法来求出离该整数最近的大于自身的“换位数”。 什么是换位数呢&#xff1f;就是把一个整数各个数位的数字进行全排列&#xff0c;从而得到新的整数。例如53241…

mybatis_user_guide(2)mybatis3.4.0快速入门

【0】README0&#xff09;以下部分内容转自&#xff1a;“mybatis v.3.4.0 User Guide”&#xff1b;1&#xff09;本文旨在梳理 如何 构建 mybatis 环境&#xff0c;与 db 连接&#xff0c;且采用 JUnit 搭建其测试用例&#xff1b;2&#xff09;本文的环境配置都是基于纯 my…

jQuery中的几个案例:隔行变色、复选框全选和全不选

1 表格隔行变色 1 技术分析&#xff1a; 1 &#xff09;基本过滤选择器&#xff1a; odd: even: 2 &#xff09;jq添加和移除样式&#xff1a; addClass(); removeClass(); 2 代码实现 <script src"js/jquery1.11.3/jquery.min.js" type"text/javasc…

从 Linux 源码看 Socket 的阻塞和非阻塞

转载自 从 Linux 源码看 Socket 的阻塞和非阻塞笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码&#xff0c;是一件Exciting的事情。大部分高性能网络框架采用的是非阻塞模式。笔者这次就从linux源码的角度来阐述socket阻塞(block)和非阻塞(non_block)的区别。 本…

pojo和javabean的区别

【0】README 1&#xff09;本文转自&#xff1a; http://wenku.baidu.com/view/eba89bbcf121dd36a32d828a.html 【1】正文如下&#xff1a; POJO 和JavaBean是我们常见的两个关键字&#xff0c;一般容易混淆&#xff0c;POJO全称是Plain Ordinary Java Object / Pure Old Jav…

使用poi调整字体格式、添加单元格注释、自动调整列宽

1 创建新的工作铺 import java.io.FileOutputStream;import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFCellStyle; import org.apache.poi.hssf.usermodel.HSSFFont; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apa…

MySQL 的索引是什么?怎么优化?

转载自 MySQL 的索引是什么&#xff1f;怎么优化&#xff1f; 摘要: 索引对大数据的查询速度的提升是非常大的&#xff0c;Explain可以帮你分析SQL语句是否用到相关索引。 索引类似大学图书馆建书目索引&#xff0c;可以提高数据检索的效率&#xff0c;降低数据库的IO成本。My…

maven(5)坐标和依赖

【0】README1&#xff09;本文部分文字转自 “maven实战”&#xff0c;旨在 review “maven(5)坐标和依赖” 的相关知识&#xff1b;【2】坐标详解 1&#xff09;intro&#xff1a;坐标用于定位 类库&#xff0c;而一组maven 坐标通过一些元素来进行定义的&#xff1a;groupId…

poi中文api文档

POI中文API文档 一、 POI简介 Apache POI是Apache软件基金会的开放源码函式库&#xff0c;POI提供API给Java程序对Microsoft Office格式档案读和写的功能。二、 HSSF概况 HSSF 是Horrible SpreadSheet Format的缩写&#xff0c;通过HSSF&#xff0c;你可以用纯Java代码来读取、…

聊聊MyBatis缓存机制

转载自 聊聊MyBatis缓存机制前言MyBatis是常见的Java数据库访问层框架。在日常工作中&#xff0c;开发人员多数情况下是使用MyBatis的默认缓存配置&#xff0c;但是MyBatis缓存机制有一些不足之处&#xff0c;在使用中容易引起脏数据&#xff0c;形成一些潜在的隐患。个人在业务…

maven(6)仓库

【0】README1&#xff09;本文部分文字转自 “maven实战”&#xff0c;旨在 review “maven(6)仓库” 的相关知识&#xff1b; 【1】何为 Maven仓库1&#xff09;intro to 构件&#xff1a;在maven中&#xff0c;任何一个依赖&#xff0c;插件或者项目构建的输出&#xff0c;都…

防止用户重复提交表单数据,session方式,js方式

1. 使用session的方式创建Token令牌解决 创建一个生成令牌的工具类&#xff0c;在该类中有返回类的对象&#xff0c;生成token的方法public class TokenUtil {/**单例设计模式&#xff08;保证类的对象在内存中只有一个&#xff09;*1、把类的构造函数私有*2、自己创建一个类的…

mybatis_user_guide(3)XML配置

【-1】README1&#xff09;本文全文总结于 http://www.mybatis.org/mybatis-3/zh/configuration.html#environments【0】MyBatis 的配置文件包含了影响 MyBatis 行为甚深的设置&#xff08;settings&#xff09;和属性&#xff08;properties&#xff09;信息。文档的顶层结构如…

easyUI 运用窗口和form表单制作导出功能

这里运用到easyUI的窗口模式和form表单的提交制作一个有条件的导出excel数据统计的功能&#xff0c;主要是知道了怎么运用easyUI的窗口和表单 jsp中&#xff1a;<!-- 导出数据来源条件窗口 --><div id"exportSign" ><form id"condition" me…