Java - 框架之 MyBites
一. 开发步骤:
1. 创建 PO (model) 类,根据需求创建。
2. 创建全局配置文件 sqlMapConfig.xml。
3. 编写映射文件。
4. 加载映射文件, 在 SqlMapConfig.xml 中进行加载。
5. 编写测试程序,连接并操纵数据库。
- 读取配置文件。
- 通过 SqlSessionFactoryBuilder 创建 SqlSessionFactory 会话工厂。
- 通过 SqlSessionFactory 创建 SqlSession
- 通过 SqlSession 的操作数据库方法。
- 关闭 SqlSession。
二. 创建项目
1. Dao创建
2. Dao创建并整合到 Spring
4. mapper创建并整合到 Spring
三. 参数信息
parameterType : 指定输入参数䣌 java 类型。
resultType : 指定输出结果的 java 类型。
#{} : 相当于预处理中的占位符 -> ? ,可以接收 HashMap, POJO 类型参数,简单类型时参数可以是 value 或其它。(可防止 sql 注入)
${} : 相当于拼接 SQL 串,对传入的值不做任何解释,原样输出,可接受 HashMap, POJO 类型参数,接收简单类型参数时只能时 value。(有sql注入)
selectOne : 只能查询 0 或 1 条记录,大于一条记录会报错。
selectList : 可以查询 0 或 n 条记录
四. mybatis 的 Dao 编写 【通过 mapper 代理方式实现】
1. 创建 接口类 (UserMapper)
package com.q.mybatis.mapper;
import com.q.mybatis.model.User;
public interface UserMapper {
public int save(User user);
public User getUserById(int id);
}
2. 创建 UserMapper.xml 文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.q.mybatis.mapper.UserMapper"> <insert id="save" parameterType="user">
insert into user(username, sex, birthday, address)
values (#{username}, #{sex}, #{birthday}, #{address})
</insert> <!--
namespace : 接口映射地址
id : 方法名
parameterType : 方法参数类型 (如果是一个类,可直接放上类的路径, 可在 SqlMapConfig.xml 文件中设置别名)
resultType : 模型地址 ( 可以在 SqlMapConfig.xml 文件中设置别名 )
--> <select id="getUserById" parameterType="int" resultType="user">
select * from user where id = #{id}
</select> </mapper>
3. 加载映射文件
<!-- 加载映射文件 -->
<mappers>
<mapper resource="com/q/mybatis/mapper/UserMapper.xml"></mapper>
</mappers>
4. 编写测试代码
import com.q.mybatis.mapper.UserMapper;
import com.q.mybatis.model.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test; import java.io.IOException;
import java.io.InputStream;
import java.util.Date; public class t4 { SqlSession session; @Before
public void before() throws IOException { System.out.println("insert Before"); // 1. 读取配置文件
InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml"); // 2. 通过 SqlSessionFactoryBuilder 创建 SqlSessionFactory 会话工厂
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is); session = sessionFactory.openSession();
} @After
public void after(){
session.close();
} @Test
public void test1(){
UserMapper userMapper = session.getMapper(UserMapper.class); // 获取数据
System.out.println(userMapper.getUserById(16)); // 添加数据
User user1 = new User("t4_5","1",new Date(), "addr");
userMapper.save(user1);
session.commit();
} }
五. resultType / resultMap
1. resultType (表字段必须和类属性对应,如果不对应则返回 Null):
模型地址 ( 可以在 SqlMapConfig.xml 文件中设置别名 )
<select id="getUserById" parameterType="int" resultType="com.q.mybatis.model.User">
select * from user where id = #{id}
</select>
2. resultMap: 当类属性字段和数据库字段不对应时,可以使用这个方法查询
<resultMap id="userResultMap" type="user">
<id property="id" column="id_"></id> <result property="username" column="username_"></result>
<result property="sex" column="sex_"></result>
<result property="birthday" column="birthday_"></result>
<result property="address" column="address_"></result>
</resultMap> <select id="getUserById" parameterType="int" resultMap="userResultMap">
select
id id_, username username_, sex sex_, birthday birthday_ , address address_
from user where id = #{id}
</select>
六. if where 使用
1. 配置文件 XML
<select id="findUserList" parameterType="com.q.mybatis.vo.UserQueryVO" resultType="user">
select * from user
<where>
<if test="user.sex != null and user.sex != ''">
sex = #{user.sex}
</if>
<if test="user.username != null and user.username != ''">
and username like '%${user.username}%'
</if>
</where>
</select>
2. 测试方法
@Test
public void test2(){
UserMapper userMapper = session.getMapper(UserMapper.class);
UserQueryVO query = new UserQueryVO(); User user = new User();
user.setSex("1"); query.setUser(user); List<User> users = userMapper.findUserList(query);
System.out.println(users);
}
七. 一对一
1. XML 配置
<!-- 如果一个表中关联着其它表,就使用 resultMap -->
<resultMap id="orderRslMap" type="orders">
<!-- 往 orders 的模型匹配数据 -->
<id column="id" property="id"/>
<id column="note" property="note"/>
<id column="number" property="number"/>
<id column="createtime" property="createtime"/> <!-- 往 orders 的关联表 user 匹配数据 -->
<!-- 注意: 这里使用 javaType -->
<association property="user" javaType="user">
<id column="user_id" property="id" />
<id column="username" property="username" />
<id column="address" property="address" />
</association> </resultMap> <select id="findOrderById" parameterType="int" resultType="orderRslMap">
select a.username, b.* from user a, orders b where a.id = b.id
</select>
2. 查询
orderMapper mapper = session.getMapper(OrderMapper.class); Orders order = mapper.findOrderById(3); System.out.println(order);
System.out.println(order.getUser());
八. 一对多
<resultMap id="orderRslMap" type="orders">
<!-- 往 orders 的模型匹配数据 -->
<id column="id" property="id"/>
<id column="note" property="note"/>
<id column="number" property="number"/>
<id column="createtime" property="createtime"/> <!-- 往 orders 的 orderdetail 匹配数据 一对多 -->
<!-- 注意:集合中的类型使用 ofType -->
<collection property="orderDetails" ofType="orderDetail">
<id column="detail_id" property="id"/>
<id column="item_id" property="itemsId"/>
<id column="item_num" property="itemsNum"/>
</collection> </resultMap>
九. 多对多 : 上面的 <collection> 中继续嵌套 <collection> ..文档。。。
十. 设置允许懒加载
<settings>
<setting name="lazyLoadingEnabled" value="true" />
</settings>
十一. 开启二级缓存
1. SqlMapCOnfig.xml 文件中
<settings>
<setting name="cacheEnabled" value="true" />
</settings>
2. UserMapper.xml 文件中
// type 默认不写用的是 mybatis 自带的缓存( perpetualCache )
<cache></cache>
3. 注意:当 session 关闭后,才会提交到 二级缓存 : session.close();
当执行 update, delete, save 等操作时会清空缓存。
Java - 框架之 MyBites的更多相关文章
- 如何在Eclipse中查看JDK以及JAVA框架的源码(转载)
原文链接:http://www.cnblogs.com/outlooking/p/5243415.html 设置步骤如下: 1.点 “window”-> "Preferences&qu ...
- Java框架介绍-13个不容错过的框架项目
本文转自互联网,个人收藏所用. 下面,我们将一同分享各有趣且颇为实用的Java库,大家请任取所需.不用客气~ 1.极致精简的Java Bootique是一项用于构建无容器可运行Java应用的极简技术. ...
- 如何查看JDK以及JAVA框架的源码
如何查看JDK以及JAVA框架的源码 设置步骤如下: 1.点 “window”-> "Preferences" -> "Java" -> &q ...
- 对java框架的几点认识
java框架实在是太多了,网上一抄一大段,根本就了解不到什么.我还是以我的经验来说一下j2ee的框架.1.首先力推struts2框架,这是最经典的框架(可以说没有“之一”).可以帮你快速搭建出一个MV ...
- 最简单的Java框架
框架framework的目的是定义骨架式方案,处理各种相同的底层细节:而开发人员使用框架时,能够依照自己的需求实现自己的功能--仅仅须要填入自己的东西/flesh. 最简单的框架,类似于JUnit,它 ...
- 2016年7款最流行的Java框架
虽然Java一直被唱衰,但是直到现在Java也坚持霸主地位不动摇,毫无疑问,Java是目前最热门的编程语言之一,所以我们为大家搜集了一些目前比较受欢迎的Java框架的消息. 根据RebelLabs对在 ...
- Java框架spring Boot学习笔记(六):Spring Boot事务管理
SpringBoot和Java框架spring 学习笔记(十九):事务管理(注解管理)所讲的类似,使用@Transactional注解便可以轻松实现事务管理.
- Java框架spring 学习笔记(十八):事务管理(xml配置文件管理)
在Java框架spring 学习笔记(十八):事务操作中,有一个问题: package cn.service; import cn.dao.OrderDao; public class OrderSe ...
- Java框架spring 学习笔记(十四):注解aop操作
回见Java框架spring Boot学习笔记(十三):aop实例操作,这里介绍注解aop操作 首先编写一个切入点HelloWorld.java package com.example.spring; ...
随机推荐
- 使用命令进行Apache Kafka操作
1.目标 我们可以在Kafka集群上执行几个Apache Kafka Operations .因此,在本文中,我们将详细讨论所有Apache Kafka操作.它还包括有助于实现这些Kafka操作的命令 ...
- Spring的并发问题——有状态Bean和无状态Bean
一.有状态和无状态 有状态会话bean :每个用户有自己特有的一个实例,在用户的生存期内,bean保持了用户的信息,即“有状态”:一旦用户灭亡(调用结束或实例结束),bean的生命期也告结束.即每 ...
- Python-09-文件处理
一.文件操作流程 打开文件,得到文件句柄并赋值给一个变量 通过句柄对文件进行操作 关闭文件 #1. 打开文件,得到文件句柄并赋值给一个变量 f=open('a.txt','r',encoding='u ...
- 15 IO流(十二)——数据流Data InputStream/OutputStream 未学会
数据流的引入 Data流的父类是Filter抽象基类,也就是说Data流是装饰流. 数据流可以将数据的类型也一起传输. 数据流的读取写入顺序(数据类型的读写顺序)需要一致. 未完成代码 /** *Da ...
- python3的 基础
]print(list(set(lst))) # 面试题: # a = 10 # b = 20 # a,b = b,a # 10000% # print(b) # 10 # print(a ...
- gorm 批量插入数据
使用gorm 插入数据的时候,根据官方文档可以使用Create或者FirstOrCreate(). 但是官方没有提供批量插入数据的方法. 根据github的 issue得知,我们可以通过自己拼接sql ...
- AS3灰色图像
一开始觉得AS3的滤镜很难使用,尤其是那些矩阵,让人望而生畏.最近写一个聊天模块,要用到离线状态下的灰色头像,于是认真研究了ColorMatrixFilter,发现其实也没有那么难.所谓的矩阵其实就是 ...
- c# 操作xml文件(读写)
根据项目需求,我们需要记录用户的操作痕迹,当用户下次登录操作同一个文件时,页面显示为用户上一次执行的用户轨迹,我们考虑把用户的历史记录写进xml文件中. 存储的xml数据结构: XML操作类: usi ...
- 第一个.NET小程序
一.用户需求 做一个简单的网页版销售合同签核系统 1.业务员需要在手机或者电脑上操作,Key入销售合同 2.业务员填入相应的合同信息,对应主管签核 3.最终签核完,生成PDF版的销售合同,且上面自动加 ...
- JAVA基础之ServletContext应用
创建一个登陆的界面,并且统计次数! 导入jar包; 1. driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/java0603?u ...