mybatis入门配置和调试
欢迎转载http://www.cnblogs.com/jianshuai520/p/8669177.html大家一起努力,如果看的时候有图片半边遮挡起来的话,右键查看图片,就可以观看完整的图片,具体怎么 回事也不知道,大概是排版的问题吧。
一:Mybatis简介
1.名称由来
Mybatis原名叫ibatis.Mybatis一开始属于Apache,2010年从Apache转移到了GoogleCode这个组织中.
2.Mybatis概念
Mybatis是一种基于ORM模式的,作用于Dao层的轻量级框架.和Hibernate类似,也支持各种SQL语句,也支持存储过程和高级映射等操作.
3.Mybatis优点
Mybatis比Hibernate更为轻量级;
Mybatis几乎消除了所有的JDBC代码和参数的手工设置.
4.Mybatis特点
Mybatis具有比较强大的动态语句功能.而且Mybatis在JavaBean和表之间的映射关系建立方面,也更加的便捷灵活.
5.Mybatis的核心API
①.SqlSessionFactoryBuilder:
SqlSessionFactoryBuilder是整个Mybatis框架的入口,提供了一个build()方法,用来创建SqlSessionFactory对象. SqlSessionFactoryBuilder对象一般是在xml文件中通过configuration节点来进行配置.
②.SqlSessionFactory:
用来创建SqlSession.注意:该对象一般只用创建一个对象就可以,也就是不要重复创建该对象!
③.SqlSession:
SqlSession用来实现数据库的各种增删改查操作.
注意:
因为SqlSession对象不是线程安全的,所以在使用该对象的时候,要确保该对象不能被多个方法所共享,当用完该对象之后,就要把该对象close()掉.
6.Mybatis和Hibernate对比
Hibernate相对来说较重,使用和配置起来较麻烦,内存占用和资源消耗较多;Hibernate的查询效率并不突出;Hibernate的入门门槛较高.Hibernate里面的API方法及功能较多.
Mybatis相对来说较轻,.......;Mybatis学习成本较低.
Mybatis相对于Hibernate来说API较少,比较单薄.
二:Mybatis的基本使用
1.利用maven工厂导入所需要的jar包
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.0.7</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.2.7</version>
</dependency>
2:创建db.properties.xml文件
该文件用来简化数据库的连接配置,以后数据库有更改,直接在这个文件里面修改即可,可以添加多种不同的数据库。我的如下
mysql.driver=com.mysql.jdbc.Driver
mysql.url=jdbc:mysql://localhost:3306/sql05
mysql.username=root
mysql.password=123 orcl.driver=oracle.jdbc.driver.OracleDriver
orcl.url=jdbc:oracle:thin:@localhost:1521:orcl
orcl.username=scott
orcl.password=123
3.创建mybatis.xml配置文件
首先引用db.properties.xml文件,
就可以引用db.properties的配置文件了。
如果是mysql的数据库的话,就加载mysql_conn
管理数据源的时候
<property name="driver" value="${mysql.driver}" />
<property name="url" value="${mysql.url}" />
<property name="username" value="${mysql.username}" />
<property name="password" value="${mysql.password}" />
mysql.driver一些分别对应着之前写db.properties配置文件。
接着加载映射文件,加载的映射文件用于配置数据库链接的一些操作
<!-- 加载映射文件 -->
<mappers>
<mapper resource="PersonMapper.xml"/>
</mappers>
4.创建PersonMapper.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">
<!-- namespace:这里的值,可以随便写!但是要保证它的值唯一.一般开发过程中,都是JavaBean的全路径. -->
<mapper namespace="com.syc.dao.domain.Person"> <!-- type:要操作的JavaBean的全路径 -->
<!-- resultMap:建立起JavaBean和表的映射关系 -->
<!-- 直接引用别名 -->
<resultMap type="person" id="personMap">
<!-- id:表示主键 -->
<id column="pid" property="pid" />
<!-- result:普通列 -->
<result column="name" property="name" />
<result column="nickname" property="nickname" />
</resultMap> <!-- insert:添加操作的标签,id:用来引用该标签 -->
<insert id="insertPerson">
insert into person (name,nickname)
values('王小二','店小二')
</insert> <!-- 带参数的标签 -->
<insert id="insertPersonWithParams" parameterType="person">
insert into
person (name,nickname)
values(#{name},#{nickname})
</insert> <!-- 查询标签 -->
<!-- resultMap:集合的泛型类 -->
<select id="findAll" resultMap="personMap">
select * from person
</select> <select id="findById" resultType="person" parameterType="int">
select *
from person
where pid=#{pid}
</select> <!-- 修改 -->
<update id="updateById" parameterType="person">
update person set
name=#{name},nickname=#{nickname}
where pid=#{pid}
</update> <!-- 删除 -->
<delete id="deleteById" parameterType="person">
delete from person
where pid=#{pid}
</delete> <!-- 注意:除了查询之外,其他的操作,增删改操作的,起始和标签名称没有关系! -->
<delete id="insertWithDeleteTag" parameterType="person">
insert into
person (name,nickname)
values(#{name},#{nickname})
</delete> </mapper>
5.创建MybatisUtil工具类,加载配置文件
package com.syc.dao.utils; import java.io.IOException;
import java.io.Reader; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MybatisUtil { private static SqlSessionFactory factory;
// 解决资源争抢问题.
private static ThreadLocal<SqlSession> localSessions = new ThreadLocal<SqlSession>(); static {
Reader reader = null;
try {
// 加载Mybatis的配置文件
reader = Resources.getResourceAsReader("mybatis.xml");
// 创建SqlSessionFactory对象.
factory = new SqlSessionFactoryBuilder().build(reader);
} catch (IOException e) {
e.printStackTrace();
} finally {
if (reader != null) {
try {
reader.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
} // 获取Session对象
public static SqlSession getSession() {
SqlSession session = localSessions.get();
if (session == null) {
session = factory.openSession();
localSessions.set(session);
}
return session;
} // 关闭session的方法
public static void closeSession() {
SqlSession session = localSessions.get();
if (session != null) {
session.close();
localSessions.remove();
}
}
}
创建session对象:
6.创建Person类。
private Integer pid; //id
private String name; //姓名
private String nickname; //称呼
7.创建PersonDao类,执行具体的CRUD操作
三: Mybatis配置简化改造
1. 简化数据库连接配置
前面提到了,就是创建一个db.properties.xml配置文件,因为做项目后东西太多,需要一个特定的配置文件去管理,而且数据库使用可能会运用到多个,修改项目时候,在特定的配置文件中修改会更加便捷。mysql和orcal的配置如下,如果当你要调用什么数据库的时候,就加载哪个
mysql.driver=com.mysql.jdbc.Driver
mysql.url=jdbc:mysql://localhost:3306/sql05
mysql.username=root
mysql.password=123 orcl.driver=oracle.jdbc.driver.OracleDriver
orcl.url=jdbc:oracle:thin:@localhost:1521:orcl
orcl.username=scott
orcl.password=123
2.设置类型别名
3.简化id的引用
因为做项目的时候,有时候包名过多,可能自己填写的时候难免字母会填写错误,给调试出问题带来不必要的麻烦。
四.Mybatis利用标签使用CRUD
1.动态添加
Normal
0
7.8 磅
0
2
false
false
false
EN-US
ZH-CN
X-NONE
/* Style Definitions */
table.MsoNormalTable
{mso-style-name:普通表格;
mso-tstyle-rowband-size:0;
mso-tstyle-colband-size:0;
mso-style-noshow:yes;
mso-style-priority:99;
mso-style-parent:"";
mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
mso-para-margin:0cm;
mso-para-margin-bottom:.0001pt;
mso-pagination:widow-orphan;
font-size:16.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-font-kerning:1.0pt;}
2. 查询操作
<!-- 查询标签 -->
<!-- resultMap:集合的泛型类 -->
<select id="findAll" resultMap="personMap">
select * from person
</select> <select id="findById" resultType="person" parameterType="int">
select *
from person
where pid=#{pid}
</select>
Normal
0
7.8 磅
0
2
false
false
false
EN-US
ZH-CN
X-NONE
/* Style Definitions */
table.MsoNormalTable
{mso-style-name:普通表格;
mso-tstyle-rowband-size:0;
mso-tstyle-colband-size:0;
mso-style-noshow:yes;
mso-style-priority:99;
mso-style-parent:"";
mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
mso-para-margin:0cm;
mso-para-margin-bottom:.0001pt;
mso-pagination:widow-orphan;
font-size:16.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-font-kerning:1.0pt;}
3.修改操作
<!-- 修改 -->
<update id="updateById" parameterType="person">
update person set
name=#{name},nickname=#{nickname}
where pid=#{pid}
</update>
Normal
0
7.8 磅
0
2
false
false
false
EN-US
ZH-CN
X-NONE
/* Style Definitions */
table.MsoNormalTable
{mso-style-name:普通表格;
mso-tstyle-rowband-size:0;
mso-tstyle-colband-size:0;
mso-style-noshow:yes;
mso-style-priority:99;
mso-style-parent:"";
mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
mso-para-margin:0cm;
mso-para-margin-bottom:.0001pt;
mso-pagination:widow-orphan;
font-size:16.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-font-kerning:1.0pt;}
4.删除操作
<!-- 删除 -->
<delete id="deleteById" parameterType="person">
delete from person
where pid=#{pid}
</delete>
Normal
0
7.8 磅
0
2
false
false
false
EN-US
ZH-CN
X-NONE
/* Style Definitions */
table.MsoNormalTable
{mso-style-name:普通表格;
mso-tstyle-rowband-size:0;
mso-tstyle-colband-size:0;
mso-style-noshow:yes;
mso-style-priority:99;
mso-style-parent:"";
mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
mso-para-margin:0cm;
mso-para-margin-bottom:.0001pt;
mso-pagination:widow-orphan;
font-size:16.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-font-kerning:1.0pt;}
5.注意:
真正的增删改和标签名没有关系!只和里面的sql语句有关!
<!-- 注意:除了查询之外,其他的操作,增删改操作的,起始和标签名称没有关系! -->
<delete id="insertWithDeleteTag" parameterType="person">
insert into
person (name,nickname)
values(#{name},#{nickname})
</delete>
五:运行测试结果
1.测试数据库链接成功与否
@Test
public void test1() {
SqlSession session = MybatisUtil.getSession();
Connection conn = session.getConnection();
// Mybatis中可以执行原生的SQL语句!
if (conn != null) {
System.out.println("数据库已建立连接!");
} else {
System.out.println("数据库未建立连接!");
}
}
2.添加数据
@Test
public void test2(){
PersonDao dao = new PersonDao();
int result = dao.insertPerson();
if (result>0) {
System.out.println("添加成功");
}
}
PersonMapper.xml对应配置:
<!-- insert:添加操作的标签,id:用来引用该标签 -->
<insert id="insertPerson">
insert into person (name,nickname)
values('王小二','店小二')
</insert>
查询数据库后多了这条数据:
还有一种带参数的标签添加数据
@Test
public void test3(){
PersonDao dao = new PersonDao();
Person p = new Person();
p.setName("林冲");
p.setNickname("豹子头");
int result = dao.insertPersonWithParams(p);
if (result>0) {
System.out.println("添加成功");
}
}
测试很多就不一一测试了,DaoTest源码如下
package com.syc.dao.test; import java.sql.Connection;
import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import com.syc.dao.dao.PersonDao;
import com.syc.dao.domain.Person;
import com.syc.dao.utils.MybatisUtil; public class DaoTest {
@Test
public void test1() {
SqlSession session = MybatisUtil.getSession();
Connection conn = session.getConnection();
// Mybatis中可以执行原生的SQL语句!
if (conn != null) {
System.out.println("数据库已建立连接!");
} else {
System.out.println("数据库未建立连接!");
}
}
@Test
public void test2(){
PersonDao dao = new PersonDao();
int result = dao.insertPerson();
if (result>0) {
System.out.println("添加成功");
}
}
@Test
public void test3() {
PersonDao dao = new PersonDao();
Person p = new Person();
p.setName("林冲");
p.setNickname("豹子头");
int result = dao.insertPersonWithParams(p);
if (result > 0) {
System.out.println("添加成功!");
}
}
@Test
public void test4(){
PersonDao dao = new PersonDao();
List<Person> persons =dao.findAll();
for (Person p : persons) {
System.out.println("name="+p.getName());
}
}
@Test
public void test5() {
PersonDao dao = new PersonDao();
Person person = dao.findById(2);
System.out.println("name=" + person.getName());
}
@Test
public void test6(){
PersonDao dao = new PersonDao();
Person person = new Person();
person.setPid(6);
person.setName("时迁");
person.setNickname("鼓上蚤");
int result = dao.updateById(person);
if (result>0) {
System.out.println("修改成功");
}
}
@Test
public void test7(){
PersonDao dao = new PersonDao();
Person p = new Person();
p.setPid(6);
int result= dao.deleteById(p);
if (result>0) {
System.out.println("删除成功");
}
}
@Test
public void test8(){
PersonDao dao = new PersonDao();
Person p = new Person();
p.setName("宋江");
p.setNickname("及时雨");
int result = dao.insertWithDeleteTag(p);
if (result>0) {
System.out.println("添加成功");
}
}
}
PersonDao的CURD操作的代码如下
package com.syc.dao.dao; import java.util.List; import org.apache.ibatis.session.SqlSession; import com.syc.dao.domain.Person;
import com.syc.dao.utils.MybatisUtil; public class PersonDao {
public int insertPerson(){
SqlSession session = null;
try {
session = MybatisUtil.getSession();
//Mybatis中默认自动开启了事务.
//命名空间+某个标签的id!
//return session.insert("com.syc.dao.domain.Person.insertPerson") //简化id的引用
return session.insert(Person.class.getName()+".insertPerson");
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally {
//提交事务
session.commit();
MybatisUtil.closeSession();
}
return 0;
} //带参数的添加操作
public int insertPersonWithParams(Person person){
SqlSession session =null;
try {
session =MybatisUtil.getSession();
//简化id的引用
return session.insert(Person.class.getName()+".insertPersonWithParams",person);
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally {
//提交事务
session.commit();
MybatisUtil.closeSession();
}
return 0;
}
//查询全部
public List<Person> findAll(){
SqlSession session =null;
try {
session = MybatisUtil.getSession();
//简化id的引用
return session.selectList(Person.class.getName()+".findAll");
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally {
//提交事务
session.commit();
MybatisUtil.closeSession();
}
return null;
}
public Person findById(int pid){
SqlSession session = null;
try {
session = MybatisUtil.getSession();
//简化id的引用
return session.selectOne(Person.class.getName()+".findById",pid);
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally {
//提交事务
session.commit();
MybatisUtil.closeSession();
}
return null; }
public int updateById(Person person){
SqlSession session =null;
try {
session = MybatisUtil.getSession();
//简化id的引用
return session.update(Person.class.getName()+".updateById",person); } catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally {
//提交事务
session.commit();
MybatisUtil.closeSession();
}
return 0;
}
public int deleteById(Person person){
SqlSession session =null;
try {
session = MybatisUtil.getSession(); //简化id的引用
return session.delete(Person.class.getName()+".deleteById",person); } catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally {
//提交事务
session.commit();
MybatisUtil.closeSession();
}
return 0; }
public int insertWithDeleteTag(Person person){
SqlSession session=null;
try {
session = MybatisUtil.getSession(); //简化id的引用
return session.insert(Person.class.getName()+"insertWithDeleteTag",person);
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally {
//提交事务
session.commit();
MybatisUtil.closeSession();
}
return 0;
}
}
这是Mybatis的入门配置和调试。希望能给刚接触mybatis的初学者一点帮助。
Normal
0
7.8 磅
0
2
false
false
false
EN-US
ZH-CN
X-NONE
/* Style Definitions */
table.MsoNormalTable
{mso-style-name:普通表格;
mso-tstyle-rowband-size:0;
mso-tstyle-colband-size:0;
mso-style-noshow:yes;
mso-style-priority:99;
mso-style-parent:"";
mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
mso-para-margin:0cm;
mso-para-margin-bottom:.0001pt;
mso-pagination:widow-orphan;
font-size:16.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-font-kerning:1.0pt;}
mybatis入门配置和调试的更多相关文章
- mybatis入门--配置
1.导入jar包 mybatis-x.x.x.jar 导入到lib目录下, 如果使用 Maven 来构建项目,则需将下面的 dependency 代码置于 pom.xml 文件中: <depen ...
- Mybatis入门配置
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .20 ...
- Mybatis入门配置及第一个Mybatis程序
目的:使用mybatis来进行对数据库表的操作 第一步:引入jar包 我这里是创建的maven工程 第二步:创建数据表user 第三步:创建实体类 实体类放在包 com.xxx.pojo 下,包名可自 ...
- MyBatis入门程序(基于XML配置)
创建一个简单的MyBatis入门程序,实现对学生信息的增删改查功能(基于XML配置) 一.新建一个Java工程,导入MyBatis核心jar包.日志相关的jar包以及连接Oracle数据库所需驱动包, ...
- Mybatis入门(四)配置别名(二)
这一章我们练习一下Mybatis的别名,这大大的提高了我们的开发效率 类型别名(typeAliases) 类型别名是为 Java 类型设置一个短的名字. 它只和 XML 配置有关,作用在于用来减少类完 ...
- Mybatis入门(四)配置优化(一)
这一章主要实验Mybatis的引入外部配置文件,属性(properties)这个属性都是可外部配置且可动态替换的,既可以在典型的 Java 属性文件中配置,亦可通过 properties 元素的子元素 ...
- Java Persistence with MyBatis 3(中文版) 第一章 MyBatis入门
本章将涵盖以下话题: ž MyBatis是什么? ž 为什么选择MyBatis? ž MyBatis安装配置 ž 域模型样例 1.1 MyBatis是什么 MyBatis是一个简化和实现了Ja ...
- Mybatis 入门到理解篇
MyBatis MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code, ...
- MyBatis项目配置案例详解与Web下的增删改查实现[附项目源码]
MyBatis项目案例 项目图示: 项目源码地址:https://github.com/JluTiger/mybatispro 1.项目功能 项目案例:后台管理系统用户数据维护平台 所有用户数据查询 ...
随机推荐
- vue-cli笔记
总是忘,留个笔记. vue-cli A simple CLI for scaffolding Vue.js projects. Installation Prerequisites: Node.js ...
- Teradata全面转型
大数据时代 Teradata全面转型 [关键点]:数据分析相关技术和方案==>帮助企业实现数据价值变现 1.所有企业达成共识 数据已经成为企业的资产,甚至是核心资产. 2.Teradata转型 ...
- 一、tars简单介绍 二、tars 安装部署资料准备
1.github地址https://github.com/Tencent/Tars/ 2.tars是RPC开发框架,目前支持c++,java,nodejs,php 3.tars 在腾讯内部已经使用了快 ...
- vue-cli3安装创建项目以及目录结构
安装脚手架cli3.0 全局安装 npm install -g @vue/cli 或 yarn global add @vue/cli 查看版本/是否安装成功 vue -V 如果你仍然需要使用旧版本的 ...
- 使用c#封装海康SDK出现无法加载 DLL“..\bin\HCNetSDK.dll”: 找不到指定的模块
最近在研究网络摄像头的二次开发,测试了一款海康威视的网络摄像头,程序调试的时候,出现如题的报错. 调试随机自带的demo时,程序运行正常,但当把该程序引入到我自己的程序中时,就开始报错.根据开发软件包 ...
- arduino json 解析
#include <ArduinoJson.h> void setup() { Serial.begin(9600); DynamicJsonDocument jsonBuffer(200 ...
- 缓存表 内存表(将表keep到内存)
缓存表 内存表(将表keep到内存) 一.引言: 有时候一些基础表需要非常的频繁访问,尤其是在一些循环中,对该表中的访问速度将变的非常重要.为了提高系统的处理性能,可以考虑将一些表及索引读取并 ...
- 开源版本PowerShell Core 6.2 发布
导读 PowerShell Core 6.2 GA 已发布,PowerShell Core 是 PowerShell 的开源版本,适用于 Linux,macOS 和 Windows. 有关 Power ...
- 2018-2019-2 20175310实验一《Java开发环境的熟悉》实验报告
2018-2019-2 20175310实验一<Java开发环境的熟悉>实验报告 一.实验步骤及内容 (一).Java开发环境的熟悉-1 1.建立20175310exp1的目录 2.在20 ...
- Linux VNC安装
cat /etc/centos-release CentOS Linux release 7.4.1708 (Core) uname -r 3.10.0-693.el7.x86_64 VNC下载:ht ...