MyBatis框架
来源:互联网 发布:58 程序员兼职 编辑:程序博客网 时间:2024/05/18 11:15
平时我们都用JDBC访问数据库,除了需要自己写SQL外,还必须操作Connection,Statment,ResultSet这些只是手段的辅助类。不仅如此,访问不同的表,还会写很多雷同的代码,显得繁琐和枯燥。
那么用了MyBatis之后,只需自己提供SQL语句,其他工作,例如建立连接,Statment,JDBC相关异常处理等等都交给MyBatis去做了,那些重复性的工作MyBatis也给做了,我们只需要关注在增删改查等操作层面上,而把技术细节都封装在了我们看不见的地方。
步骤一:学习之前先看效果
步骤二:创建数据库
步骤三:创建表
步骤四:导入数据
步骤五:创建项目
步骤六:导入jar包
步骤七:创建实体类
步骤八:配置文件:mybatis-config.xml
步骤九:配置文件:Category.xml
步骤十:测试类:TestMybatis
步骤十一:基本原理图
步骤十二:可运行的项目
步骤一:学习之前先看效果
这两条数据是通过mybatis从数据库中查出来的
步骤二:创建数据库
首先创建数据库how2java
create database how2java
步骤三:创建表
USE how2java; CREATE TABLE category_ ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(32) DEFAULT NULL, PRIMARY KEY (id)) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;步骤四:导入数据USE how2java;INSERT INTO category_ VALUES (null,'category1');INSERT INTO category_ VALUES (null,'category2');步骤五:创建项目
步骤六:导入jar包
步骤七:创建实体类
准备实体类Category,用于映射表category
package com.how2java.pojo; public class Category { private int id; private String name; 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; } }
步骤八:配置文件:mybatis-config.xml在src目录下创建mybatis的主配置文件mybatis-config.xml。其作用主要是提供连接数据库用的驱动,数据库名称,编码方式,账号密码
<property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/how2java?characterEncoding=UTF-8"/><property name="username" value="root"/><property name="password" value="admin"/>以及别名,自动扫描com.how2java.pojo下的类型,使得在后续配置文件Category.xml中使用resultType的时候,可以直接使用Category,而不必写全com.how2java.pojo.Category<typeAliases><package name="com.how2java.pojo"/></typeAliases>映射Category.xml<mappers><mapper resource="com/how2java/pojo/Category.xml"/></mappers><?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration> <typeAliases> <package name="com.how2java.pojo"/> </typeAliases> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/how2java?characterEncoding=UTF-8"/> <property name="username" value="root"/> <property name="password" value="admin"/> </dataSource> </environment> </environments> <mappers> <mapper resource="com/how2java/pojo/Category.xml"/> </mappers></configuration>
步骤九:配置文件:Category.xml在包com.how2java.pojo下,新建文件Category.xml
namespace="com.how2java.pojo"
表示命名空间是com.how2java.pojo,在后续调用sql语句时,会用到它。
里面定义了一条sql语句
select * from category_
这条sql语句用id:listCategory进行标示以供后续代码调用。resultType="Category"表示返回的数据和Category关联起来,这里本应该使用的是com.how2java.pojo.Category,但是因为上一步配置了别名,所以直接使用Category就行了
<?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.how2java.pojo"> <select id="listCategory" resultType="Category"> select * from category_ </select> </mapper>
步骤十:测试类:TestMybatis运行并观察到如图所示的结果。
根据配置文件mybatis-config.xml得到sqlSessionFactory。
String resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);然后再根据sqlSessionFactory得到sessionSqlSession session=sqlSessionFactory.openSession();
最后通过session的selectList方法,调用sql语句listCategory。listCategory这个就是在配置文件Category.xml中那条sql语句设置的id.
执行完毕之后,得到一个Category集合,便利即可看到数据。
List<Category> cs = session.selectList("listCategory");for (Category c : cs) {System.out.println(c.getName());}注: session.selectList("listCategory");也可以写成session.selectList("com.how2java.pojo.listCategory");效果一样。
package com.how2java; import java.io.IOException;import java.io.InputStream;import java.util.List; 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 com.how2java.pojo.Category; public class TestMybatis { public static void main(String[] args) throws IOException { String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession session=sqlSessionFactory.openSession(); List<Category> cs=session.selectList("listCategory"); for (Category c : cs) { System.out.println(c.getName()); } }}
步骤十一:基本原理图1.应用程序找Mybatis要数据
2.mybatis 从数据库中找来数据
2.1 通过mybatis-config.xml定位哪个数据库
2.2 通过Category.xml执行对应的select语句
2.3 基于Category.xml把返回的数据库记录封装在Category对象中
2.4 把多个Category对象装在一个Category集合中
3 返回一个Category集合
- mybatis框架
- MyBatis框架
- Mybatis框架
- Mybatis框架
- Mybatis框架
- MyBatis框架
- MyBatis框架
- Mybatis框架
- MyBatis框架
- Mybatis框架
- myBatis框架
- mybatis框架
- myBatis框架
- MyBatis框架
- MyBatis框架
- Mybatis框架
- 框架:Mybatis
- MyBatis框架
- duble计算
- centOS下 jedis连接redis失败 redis.clients.jedis.exceptions.JedisConnectionException: java.net.ConnectExce
- 跨域通信的几种方式
- Linux设备树的用法
- iOS-git回滚到指定版本
- MyBatis框架
- select count(1) from user where id=2
- hibernate事务管理
- 树状数组讲解(转载)_清晰详细版
- 链表倒数第k个节点
- matplotlib.plot显示中文有问题
- 给初学者的RxJava2.0教程(二)
- 基于GPUImage的多滤镜rtmp直播推流
- makefile须知