mybatis学习之路
MyBatis 是支持普通SQL查询、存储过程和高级映射的优秀持久层框架。
MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。
MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的domain映射成数据库中的记录。
快速入门:
1.添加jar包
mybatis-3.2.1.jar(jar包版本不能太低,太低的版本无法支持接口注解)
mysql-connector-java-5.1.8-bin.jar
2.创建表
在此使用的是mysql数据库来测试
create table user( id int primary key auto_increment, name ), age int );
3.创建configuration.xml文件,该文件用于配置数据库连接信息等...
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <properties resource="db.properties"></properties> <typeAliases> <typeAlias type="com.model.User" alias="User"/> </typeAliases> <environments default="development"> <environment id="development"> <transactionManager type="jdbc"/> <dataSource type="POOLED"> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <property name="url" value="${url}"/> <property name="driver" value="${driver}"/> </dataSource> </environment> </environments> <mappers> <!-- 首先使用接口注解的方式来映射 --> <mapper class="com.dao.UserDao"/> </mappers> </configuration>
4.定义实体类
package com.dao; public class User { private int id; private String name; private int age; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "User [id=" + id + ", name=" + name + ", age=" + age + "]"; } }
5.编写接口
public interface UserDao { @Select("select * from user where id=#{id}") public User selectById(int id); }
6.在已配置过的configuration.xml中配置接口映射,必须是接口的全类名
<mappers> <!-- 首先使用接口注解的方式来映射 --> <mapper class="com.dao.UserDao"/> </mappers>
7.编写测试文件
public class Main { public static void main(String[] args) throws IOException { // TODO Auto-generated method stub InputStream is = Main.class.getClassLoader().getResourceAsStream("configuration.xml"); /** * 另一种方式读取mybatis配置文件 * String resource="configuration.xml"; * Reader reader = Resources.getResourceAsReader(resource); */ SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is); SqlSession ss = sqlSessionFactory.openSession(); UserDao userDao = ss.getMapper(UserDao.class); User user = userDao.selectById(1); System.out.println(user); } }
以上是使用基于接口注解的方式来映射,当我们使用接口注解时,并不仅仅局限于以下配置:
<mappers> <!-- 首先使用接口注解的方式来映射 --> <mapper class="com.dao.UserDao"/> </mappers>
我们还可以创建该接口的实现--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.dao.UserDao"> </mapper>
然后将configuration.xml配置改为:
<mappers> <!-- 使用xml的方式来映射 --> <mapper resource="com/dao/UserMapper.xml"/> </mappers>
注意:当使用接口定义方法,而没有提供注解时,这时的UserMapper.xml就需要配置该接口所需要的信息了:
接口:
public interface UserDao { public User selectById(int id); }
<?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.dao.UserDao"> <select id="selectById" parameterType="int" resultType="User"> select * from user where id=#{id} </select> </mapper>
<mappers> <!-- 使用xml的方式来映射 --> <mapper resource="com/dao/UserMapper.xml"/> </mappers>
------------------------------------以上是使用接口方式来映射----以下使用xml方式来映射---------------------------------------------
在上面的步骤中,将第5步去掉,然后编写完整的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.dao.UserMapper"> <select id="selectById" parameterType="int" resultType="User"> select * from user where id=#{id} </select> </mapper>
然后将configuration.xml配置为:
<mappers> <!-- 使用xml的方式来映射 --> <mapper resource="com/dao/UserMapper.xml"/> </mappers>
测试:
public class Main { public static void main(String[] args) throws IOException { // TODO Auto-generated method stub InputStream is = Main.class.getClassLoader().getResourceAsStream("configuration.xml"); /** * 另一种方式读取mybatis配置文件 * String resource="configuration.xml"; * Reader reader = Resources.getResourceAsReader(resource); */ SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is); SqlSession ss = sqlSessionFactory.openSession(); User user = ss.selectOne("com.dao.UserDao.selectById", 1); System.out.println(user); } }
以上是快速入门情况,很多配置没有详细说,下面章节开始详细讲解MyBatis配置等!!
ps:该文章仅代码本人学习过程,希望能给想学习的或正在学习的朋友带来一定的领悟.
欢迎大家指正错误,小弟在此感激不尽!!!
mybatis学习之路的更多相关文章
- mybatis学习之路----批量更新数据两种方法效率对比
原文:https://blog.csdn.net/xu1916659422/article/details/77971696/ 上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方 ...
- MyBatis学习之路之configuration配置
1.首先讲解的是MyBatis核心配置文件configuration.xml的配置 一个完整的configuration.xml配置顺序如下: properties,settings,typeAlia ...
- myBatis学习之路1-基本功能实现
myBatis也是一个持久型框架,相较于hibernate来说,算是轻量级的. 1.配置mybatis环境 相关jar下载地址:mybatis+mysalJAR包 2.新建一个java project ...
- mybatis学习之路----mysql批量新增数据
原文:https://blog.csdn.net/xu1916659422/article/details/77971867 接下来两节要探讨的是批量插入和批量更新,因为这两种操作在企业中也经常用到. ...
- springboot 学习之路 3( 集成mybatis )
目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...
- 新篇章之我的java学习之路下
昨天写下了人生的第一篇博客,今天接着写我的java学习之路有关开发及框架的学习过程. 想要学好java语言,只学习一些java的基本语法对实际开发中的用处还是不大的,所以我们还要掌握一些有关javaW ...
- springboot 学习之路 8 (整合websocket(1))
目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...
- springboot 学习之路 1(简单入门)
目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...
- springboot 学习之路 2(注解介绍)
目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...
随机推荐
- Qlikview 图标控件实现动态分组
首先编辑一个组合字段,eg, TimeDimension, 内含2个字段(即为动态可以切换的分组字段) 将TimeDimension 作为分组字段.表达式字段 Sum(Sales),结果如图示 在图片 ...
- 网站搭建 so easy
服务器(国际购买):http://www.gigsgigscloud.com/ 域名(阿里云): 解析到服务器 服务器需要安装 1.putty 2.CuteFTP(自己感觉这个靠谱点) / ...
- LESS 学习记录(简单入门)
什么是 LESS LESS是一种动态样式语言,属于 CSS 预处理语言的一种.它使用类似 CSS 的语法,但是 赋予了动态语言的特性,比如变量.继承.运算.函数等,方便 CSS 的编写和维护. 使用 ...
- HDU 5183 Negative and Positive (NP) ——(后缀和+手写hash表)
根据奇偶开两个hash表来记录后缀和.注意set会被卡,要手写hash表. 具体见代码: #include <stdio.h> #include <algorithm> #in ...
- GUI开发者桌面搜索文件工具
# - *- coding:utf-8-*-from Tkinter import *import tkMessageBoximport tkFileDialogimport osimport fnm ...
- ASP.NET MVC应用程序执行过程分析
ASP.NET MVC应用程序执行过程分析 2009-08-14 17:57 朱先忠 朱先忠的博客 字号:T | T ASP.NET MVC框架提供了支持Visual Studio的工程模板.本文 ...
- 跨进程(同一app不同进程之间通信)——Android自动化测试学习历程
视频地址:http://study.163.com/course/courseLearn.htm?courseId=712011#/learn/video?lessonId=877122&co ...
- Arduino 报错总结
Arduino出现avrdude: stk500_getsync(): not in sync: resp=0x00 )首先检查是否选择了合适的板子,选错主板型号也会造成上述错误 )重新安装驱动,换个 ...
- 我为什么选择使用Go语言?
谢孟军:EGO会员.GopherChina组织者.<Go Web编程>一书的作者,专注Golang技术架构.本文来自EGO会员群分享,入群方式见文末 在这里我主要想和大家分享一些Go和我个 ...
- RabbitMQ 学习记录
rabbit mq知识点:1.消费时可以通过acknowledge设定消费是否成功,消费不成功时在server端requeue2.需要注意两个持久化:queue持久化和消息持久化(通过代码设定,默认即 ...