你的位置:首页 > 软件开发 > Java > mybatis实战教程(mybatis in action),mybatis入门到精通(转)

mybatis实战教程(mybatis in action),mybatis入门到精通(转)

发布时间:2015-06-05 00:00:20
转自:http://www.yihaomen.com/article/java/302.htm(读者注:其实这个应该叫做很基础的入门一下下,如果你看过Hibernate了那这个就非常的简单)(再加一条,其实大家可以看官方的教程更好些:http://mybatis.github.i ...

mybatis实战教程(mybatis in action),mybatis入门到精通(转)

转自:http://www.yihaomen.com/article/java/302.htm

(读者注:其实这个应该叫做很基础的入门一下下,如果你看过Hibernate了那这个就非常的简单)

(再加一条,其实大家可以看官方的教程更好些:http://mybatis.github.io/mybatis-3/,而且如果英文不是很好的那就看中文的:http://mybatis.github.io/mybatis-3/zh/sqlmap-

写在这个系列前面的话:

以前曾经用过ibatis,这是mybatis的前身,当时在做项目时,感觉很不错,比hibernate灵活。性能也比hibernate好。而且也比较轻量级,因为当时在项目中,没来的及做很很多笔记。后来项目结束了,我也没写总结文档。已经过去好久了。但最近突然又对这个ORM 工具感兴趣。因为接下来自己的项目中很有可能采用这个ORM工具。所以在此重新温习了一下 mybatis, 因此就有了这个系列的 mybatis 教程.什么是mybatis创建用户表,并插入一条测试数据Create TABLE `user` (<?<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"    <environments default="development">3. 建立与数据库对应的 java class,以及映射文件.package com.yihaomen.mybatis.model;public class User {}<?<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" <mapper namespace="com.yihaomen.mybatis.models.UserMapper">下面对这几个配置文件解释下:package com.yihaomen.test;import java.io.Reader;import org.apache.ibatis.io.Resources;import com.yihaomen.mybatis.model.User;public class Test {    static{    public static SqlSessionFactory getSession(){ 在src_user源码目录下建立 com.yihaomen.mybatis.inter 这个包,并建立接口类 IUserOperation , 内容如下:package com.yihaomen.mybatis.inter;public interface IUserOperation {    public static void main(String[] args) {这种方式,要注意的一个地方就是。在User.除非申明,文章均为一号门原创,转载请注明本文地址,谢谢! 查询数据,前面已经讲过简单的,主要看查询出列表的<!-- 为了返回list 类型而定义的returnMap --><!-- 返回list 的select 语句,注意 resultMap 的值是指向前面定义好的 -->在 IUserOperation 接口中增加方法:public List<User> selectUsers(String userName);    public void getUserList(String userName){public static void main(String[] args) {用mybatis 增加数据 <!--执行增加操作的SQL语句。id和parameterType  /**用mybatis 更新数据<update id="updateUser" parameterType="User" >public void updateUser(){用mybatis 删除数据 <delete id="deleteUser" parameterType="int">这样,所有增删改查都完成了,注意在增加,更改,删除的时候要调用session.commit(),这样才会真正对数据库进行操作,否则是没有提交的。到此为止,简单的单表操作,应该都会了,接下来的时间了,我会讲多表联合查询,以及结果集的选取。 

mybatis实战教程(mybatis in action)之四:实现关联数据的查询

Drop TABLE IF EXISTS `article`;-- ----------------------------package com.yihaomen.mybatis.model;public class Article {}多对一的实现<!-- User 联合文章进行查询 方法之一的配置 (多对一的方式)  -->    <select id="getUserArticles" parameterType="int" resultMap="resultUserArticleList">还有另外一种处理方式,可以复用我们前面已经定义好的 resultMap ,前面我们定义过一个 resultListUser ,看这第二种方法如何实现:<resultMap type="User" id="resultListUser">    <!-- User 联合文章进行查询 方法之二的配置 (多对一的方式) -->    好了,现在在Test 类中写测试代码:public void getUserArticles(int userid){漏掉了一点,我们一定要在 IUserOperation 接口中,加入 select 对应的id 名称相同的方法:然后运行就可以测试。整个程序下载:除非申明,文章均为一号门原创,转载请注明本文地址,谢谢!

mybatis实战教程(mybatis in action)之五:与spring3集成(附源码)

你可以下载源码后,对比着看,源代码没有带jar包,太大了,空间有限. 有截图,你可以看到用到哪些jar包,源码在本文最后.1. 首先对前面的工程结构做一点改变,在src_user源代码目录下建立文件夹config ,并将原来的 mybatis 配置文件 Configuration.mybatis实战教程(mybatis in action),mybatis入门到精通(转) 程序代码<!--本示例采用DBCP连接池,应预先把DBCP的jar包复制到工程的lib目录下。 -->   <bean id="dataSource" >  <bean id="sqlSessionFactory" >   <bean id="userMapper" > [b]这里面的重点就是 org.mybatis.spring.SqlSessionFactoryBean 与 org.mybatis.spring.mapper.MapperFactoryBean[b] 实现了 spring  的接口,并产生对象。详细可以查看 mybatis-spring 代码。(http://code.google.com/p/mybatis/),如果仅仅使用,固定模式,这样配置就好。然后写测试程序package com.yihaomen.test;import java.util.List;import org.springframework.context.ApplicationContext;    运行即可得到相应的结果.用到的jar包,如下图:除非申明,文章均为一号门原创,转载请注明本文地址,谢谢!

mybatis实战教程(mybatis in action)之六:与Spring MVC 的集成

<context-param><beans             xsi:schemaLocation="    <context:component-scan base-package="com.yihaomen.controller" /></beans><!--本示例采用DBCP连接池,应预先把DBCP的jar包复制到工程的lib目录下。 -->   不知道为什么,一旦我用了 MapperScannerConfigurer 去扫描所有的mapper 接口时,数据库配置datasource 就不能用读取database.properties文件了。报错: Cannot load JDBC driver class '${jdbc.driverClassName}',网上有人说在spring 3.1.1 下用 sqlSessionFactionBean 注入可以解决,但我用 spring 3.1.3 还是有问题,所以只好把数据库连接信息直接配置在了package com.yihaomen.controller;@Controller    @RequestMapping("/list")5. 页面文件:运行结果:mybatis实战教程(mybatis in action),mybatis入门到精通(转) mybatis spring3 MVC 程序下载数据库下载:mybatis实战教程(mybatis in action),mybatis入门到精通(转) spring mvc 数据库测试文件除非申明,文章均为一号门原创,转载请注明本文地址,谢谢!

mybatis实战教程(mybatis in action)之七:实现mybatis分页(源码下载)

实现mybatis 物理分页,一个最简单的方式是,是在你的mapper的SQL语句中直接写类似如下方式 :<select id="getUserArticles" parameterType="Your_params" resultMap="resultUserArticleList">mybatis实战教程(mybatis in action),mybatis入门到精通(转) 程序代码package com.yihaomen.util;import java.lang.reflect.Field;import javax.@Intercepts({ @Signature(type = StatementHandler.class, method = "prepare", args = { Connection.class }) })    private static String dialect = "";    @SuppressWarnings("unchecked")        if (ivk.getTarget() instanceof RoutingStatementHandler) {            if (mappedStatement.getId().matches(pageSqlId)) {                    PageInfo page = null;    private void setParameters(PreparedStatement ps,    public Object plugin(Object arg0) {    public void setProperties(Properties p) {}请注意,这个插件定义了一个规则,也就是在mapper中sql语句的id 必须包含ListPage才能被拦截。否则将不会分页处理.插件写好了,现在就可以在 spring mvc 中的controller 层中写一个方法来测试这个分页:@RequestMapping("/pagelist")        pageStr=String.format("<a href=\"%s\">上一页</a>    <a href=\"%s\">下一页</a>",然后运行程序,进入分页页面,你就可以看到结果了:另外,你还得在前面提到的数据库artilce表里面,多插入一些记录,分页效果就更好。 

mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句

1. mybaits if 语句处理     <select id="dynamicIfTest" parameterType="Blog" resultType="Blog">2.2. choose (when,otherwize) ,相当于java 语言中的 switch ,与 jstl 中的choose 很类似     <select id="dynamicChooseTest" parameterType="Blog" resultType="Blog">3.trim (对包含的内容加上 prefix,或者 suffix 等,前缀,后缀)     <select id="dynamicTrimTest" parameterType="Blog" resultType="Blog">4. where (主要是用来简化sql语句中where条件判断的,能智能的处理 and or 条件    <select id="dynamicWhereTest" parameterType="Blog" resultType="Blog">5.set (主要用于更新时)     <update id="dynamicSetTest" parameterType="Blog">6. foreach (在实现 mybatis in 语句查询时特别有用) 1.1.单参数List的类型    <select id="dynamicForeachTest" resultType="Blog">public List<Blog> dynamicForeachTest(List<Integer> ids);  测试代码    @Test2.数组类型的参数    <select id="dynamicForeach2Test" resultType="Blog">public List<Blog> dynamicForeach2Test(int[] ids);  3. Map 类型的参数    <select id="dynamicForeach3Test" resultType="Blog">mapper 应该是这样的接口:public List<Blog> dynamicForeach3Test(Map<String, Object> params); 通过以上方法,就能完成一般的mybatis 的 动态SQL 语句.最常用的就是  if where foreach这几个,一定要重点掌握.

mybatis实战教程(mybatis in action)之九:mybatis 代码生成工具的使用

下面介绍下详细过程1. 创建测试工程,并配置mybatis代码生成jar包用 eclipse 建立一个dynamic web project。2.在数据库中创建测试表 Drop TABLE IF EXISTS `category`;3. 配置mybatis 代码生成工具的配置文件  根据mybatis代码生成工具文档,需要一个配置文件,这里命名为:mbgConfiguration.mybatis实战教程(mybatis in action),mybatis入门到精通(转) 程序代码<?<!DOCTYPE generatorConfiguration<generatorConfiguration>  <context id="yihaomen_mysql_tables" targetRuntime="MyBatis3">    <javaTypeResolver >  </context>package com.yihaomen.test;import java.io.File;import org.mybatis.generator.api.MyBatisGenerator;public class GenMain {enableCountByExample="false" enableUpdateByExample="false"另外生成的sql mapper 等,只是对单表的增删改查,如果你有多表join操作,你就可以手动配置,如果调用存储过程,你也需要手工配置. 这时工作量已经少很多了。如果你想用命令行方式处理,也是可以的.比如:除非申明,文章均为一号门原创,转载请注明本文地址,谢谢!

mybatis SqlSessionDaoSupport的使用(附代码下载)

在此之前,请下载 上一篇文章提供的代码:http://www.yihaomen.com/article/java/326.htm 首先创建一个com.yihaomen.dao的package.然后在里面分别创建接口UserDAO,以及实现该接口的UserDAOImpl package com.yihaomen.dao;mybatis实战教程(mybatis in action),mybatis入门到精通(转) 程序代码package com.yihaomen.dao;@Repository执行的SQL 语句采用了命名空间+sql 语句id的方式,后面是参数.注意继承了 "SqlSessionDaoSupport" ,利用方法 getSqlSession() 可以得到 SqlSessionTemplate ,从而可以执行各种sql语句,类似于hibernatetemplate一样,至少思路一样.如果与spring 3 mvc 集成要用  autowire的话,在daoimpl 类上 加上注解 “@Repository” ,另外还需要在spring 配置文件中加入<context:component-scan base-package="com.yihaomen.dao" /> 这样在需要调用的地方,就可以使用autowire自动注入了。当然,你也可以按一般程序的思路,创建一个service 的package, 用service 去调用 dao层,我这里就没有做了,因为比较简单,用类似的方法,也机注意自动注入时,也要配置 <context:component-scan base-package="com.yihaomen.service" /> 等这样的。在controller层中测试,直接调用dao层方法        .......    @RequestMapping("/daolist")

原标题:mybatis实战教程(mybatis in action),mybatis入门到精通(转)

关键词:mybatis

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录