MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。

1.搭建开发环境

1.1 创建项目

创建Maven普通java项目或者是JavaWeb项目均可,如下图所示:

1.2 配置文件

在src/main/resource目录下新建log4j.properties和jdbc.properties配置文件:

log4j.properties和jdbc.properties配置文件的内容如下:

  • log4j.properties:

     # Console output...
    log4j.appender.stdout=org.apache.log4j.ConsoleAppender
    log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
    log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n log4j.rootLogger=DEBUG, stdout
  • jdbc.properties:
     jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf8&useSSL=true
    jdbc.username=root
    jdbc.password=root123

1.3 添加jar包

在pom.xml文件的<dependencies>下添加依赖的jar包:

 <dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency> <dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency> <dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.43</version>
</dependency> <dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
</dependencies>

1.4 创建数据库

在MySQL中创建数据库mybatis和表,其中建表语句如下:

 /*Table structure for table user */
CREATE TABLE USER (
id INT(11) NOT NULL AUTO_INCREMENT,
username VARCHAR(32) NOT NULL COMMENT '用户名称',
birthday DATE DEFAULT NULL COMMENT '生日',
sex CHAR(1) DEFAULT NULL COMMENT '性别',
address VARCHAR(256) DEFAULT NULL COMMENT '地址',
PRIMARY KEY (id)
); /*Table structure for table items */
CREATE TABLE items (
id INT(11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR(32) NOT NULL COMMENT '商品名称',
price FLOAT(10,1) NOT NULL COMMENT '商品定价',
detail TEXT COMMENT '商品描述',
pic VARCHAR(64) DEFAULT NULL COMMENT '商品图片',
createtime DATETIME NOT NULL COMMENT '生产日期',
PRIMARY KEY (id)
); /*Table structure for table orders */
CREATE TABLE orders (
id INT(11) NOT NULL AUTO_INCREMENT,
user_id INT(11) NOT NULL COMMENT '下单用户id',
number VARCHAR(32) NOT NULL COMMENT '订单号',
createtime DATETIME NOT NULL COMMENT '创建订单时间',
note VARCHAR(100) DEFAULT NULL COMMENT '备注',
PRIMARY KEY (id),
KEY FK_orders_1 (user_id),
CONSTRAINT FK_orders_id FOREIGN KEY (user_id) REFERENCES USER (id) ON DELETE NO ACTION ON UPDATE NO ACTION
); /*Table structure for table orderdetail */
CREATE TABLE orderdetail (
id INT(11) NOT NULL AUTO_INCREMENT,
orders_id INT(11) NOT NULL COMMENT '订单id',
items_id INT(11) NOT NULL COMMENT '商品id',
items_num INT(11) DEFAULT NULL COMMENT '商品购买数量',
PRIMARY KEY (id),
KEY FK_orderdetail_1 (orders_id),
KEY FK_orderdetail_2 (items_id),
CONSTRAINT FK_orderdetail_1 FOREIGN KEY (orders_id) REFERENCES orders (id) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT FK_orderdetail_2 FOREIGN KEY (items_id) REFERENCES items (id) ON DELETE NO ACTION ON UPDATE NO ACTION
);

1.5 导入数据

向表中插入项目需要的数据:

 /*Data for the table user*/
INSERT INTO USER(id,username,birthday,sex,address) VALUES
(1,'王五',NULL,'',NULL),(10,'张三','2014-07-10','','北京市'),
(16,'张小明',NULL,'','河南郑州'),(22,'陈小明',NULL,'','河南郑州'),
(24,'张三丰',NULL,'','河南郑州'),(25,'陈小明',NULL,'','河南郑州'),
(26,'王五',NULL,NULL,NULL); /*Data for the table items*/
INSERT INTO items(id,NAME,price,detail,pic,createtime) VALUES
(1,'台式机',3000.0,'该电脑质量非常好!!!!',NULL,'2015-02-03 13:22:53'),
(2,'笔记本',6000.0,'笔记本性能好,质量好!!!!!',NULL,'2015-02-09 13:22:57'),
(3,'背包',200.0,'名牌背包,容量大质量好!!!!',NULL,'2015-02-06 13:23:02'); /*Data for the table `orders` */
INSERT INTO orders(id,user_id,number,createtime,note) VALUES
(3,1,'','2015-02-04 13:22:35',NULL),
(4,1,'','2015-02-03 13:22:41',NULL),
(5,10,'','2015-02-12 16:13:23',NULL); /*Data for the table `orderdetail` */
INSERT INTO orderdetail(id,orders_id,items_id,items_num) VALUES (1,3,1,1),(2,3,2,3),(3,4,3,4),(4,4,2,3);

2.使用MyBatis查询数据

2.1 创建MyBatis配置文件

在src/main/resource目录下新建mybatis文件夹,并添加Mybatis的配置文件SqlMapConfig.xml(文件名可以随便):

SqlMapConfig.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="jdbc.properties"></properties> <environments default="development">
<environment id="development">
<!-- 使用jdbc事务管理,事务控制由mybatis-->
<transactionManager type="JDBC"/>
<!-- 数据库连接池,由mybatis管理-->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
</configuration>

2.2 创建实体类和映射文件

创建实体类User.java,在com.sunny.mybatis包下新建mapper包,在mapper包下创建User的映射文件UserMapper.xml(名字和位置可以随意):

User.java和UserMapper.xml文件的内容如下:

  • User.java:

     package com.sunny.mybatis.domain;
    
     import java.io.Serializable;
    import java.util.Date; public class User implements Serializable {
    private static final long serialVersionUID = 6856509574533500731L; private int id;
    private String username;
    private String sex;
    private Date birthday;
    private String address; public int getId() {
    return id;
    } public void setId(int id) {
    this.id = id;
    } public String getUsername() {
    return username;
    } public void setUsername(String username) {
    this.username = username;
    } public String getSex() {
    return sex;
    } public void setSex(String sex) {
    this.sex = sex;
    } public Date getBirthday() {
    return birthday;
    } public void setBirthday(Date birthday) {
    this.birthday = birthday;
    } public String getAddress() {
    return address;
    } public void setAddress(String address) {
    this.address = address;
    } }
  • 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">
    <!-- namespace命名空间,对sql进行分类化管理,注意:使用mapper代理方法开发,namespace有特殊重要的作用-->
    <mapper namespace="user">
    <!-- 通过 select执行数据库查询
    id:标识映射文件中的sql,将sql语句封装到mappedStatement对象中,所以将id称为statement的id
    parameterType:指定输入 参数的类型,这里指定int型
    #{}表示一个占位符号
    #{id}:其中的id表示接收输入 的参数,参数名称就是id,如果输入 参数是简单类型,#{}中的参数名可以任意,可以value或其它名称
    resultType:指定sql输出结果 的所映射的java对象类型,select指定resultType表示将单条记录映射成的java对象。
    -->
    <select id="selectById" parameterType="int" resultType="com.sunny.mybatis.domain.User">
    SELECT * FROM tuser WHERE id=#{id}
    </select>
    </mapper>
  • 在SqlMapConfig.xml中注册UserMapper.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="jdbc.properties"></properties> <environments default="development">
    <environment id="development">
    <!-- 使用jdbc事务管理,事务控制由mybatis-->
    <transactionManager type="JDBC"/>
    <!-- 数据库连接池,由mybatis管理-->
    <dataSource type="POOLED">
    <property name="driver" value="${jdbc.driver}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
    </dataSource>
    </environment>
    </environments> <!-- 加载映射文件 -->
    <mappers>
    <mapper resource="com/sunny/mybatis/mapper/UserMapper.xml"/>
    </mappers>
    </configuration>

2.3 测试

  • 新建测试方法:

     @Test
    public void selectById() throws Exception {
    //mybatis配置文件是以流的方式读取的Resource是mybatis包下的类
    InputStream config = Resources.getResourceAsStream("mybatis/SqlMapConfig.xml");
    //创建mybatis的会话工厂
    SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(config);
    //通过会话工厂得到SqlSession
    SqlSession session = sessionFactory.openSession();
    /*执行查询,selectOne表示查询的结果为单条记录,
    *user.selectById:
    user表示映射文件中的namespace
    selectById表示映射文件中的select标签中的id属性值
    *参数中的1表示参入的值,和select标签中的parameterType类型匹配
    */
    User user = session.selectOne("user.selectById", 1);
    System.out.println(user.getId() + "-->" + user.getUsername() + "-->" + user.getBirthday());
    //关闭session
    session.close();
    }
  • 运行结果:

01、Mybatis快速入门的更多相关文章

  1. 01.MyBatis快速入门

    1.下载jar包 Mybatis包+数据库驱动包 https://github.com/mybatis/mybatis-3/releases 2.新建Java工程并导入jar包 3.创建数据库与表 C ...

  2. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  3. MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  4. MyBatis学习总结(一)——MyBatis快速入门(转载)

    本文转载自http://www.cnblogs.com/jpf-java/p/6013537.html MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了 ...

  5. MyBatis入门学习教程-MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  6. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  7. 【转】MyBatis学习总结(一)——MyBatis快速入门

    [转]MyBatis学习总结(一)——MyBatis快速入门 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC ...

  8. MyBatis学习总结-MyBatis快速入门的系列教程

    MyBatis学习总结-MyBatis快速入门的系列教程 [MyBatis]MyBatis 使用教程 [MyBatis]MyBatis XML配置 [MyBatis]MyBatis XML映射文件 [ ...

  9. MyBatis学习笔记(一)——MyBatis快速入门

    转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4261895.html 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优 ...

  10. Java基础-SSM之mybatis快速入门篇

    Java基础-SSM之mybatis快速入门篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 其实你可能会问什么是SSM,简单的说就是spring mvc + Spring + m ...

随机推荐

  1. Android事件分发理解

    Android事件分发机制是个难点和重点,结合下各家,写点自己的理解.. 首先抛出一个小问题,写一个button的点击事件 button.setOnClickListener(new OnClickL ...

  2. zookeeper的集群介绍、搭建、环境、安装

    zookeeper是本身是一种分布式协调服务(英文意思动物园园长因为Hadoop就是一个动物园,storm.hadoop.kafkaka.hbaser都是基于zookeeper开发的) 原理:Zook ...

  3. request.setcharacterencoding()和request.setcontenttype(“html/css;charset”)的格式区别

    1.request.setCharacterEncoding()是设置从request中取得的值或从数据库中取出的值 指定后可以通过getParameter()则直接获得正确的字符串,如果不指定,则默 ...

  4. 初学angular

    1.angular   表达式 2.ng-app   ng-init  ng-model  ng-repeat ng-model是用于表单元素的,支持双向绑定.对普通元素无效: ng-bind用于普通 ...

  5. 第2章 rsync算法原理和工作流程分析

    本文通过示例详细分析rsync算法原理和rsync的工作流程,是对rsync官方技术报告和官方推荐文章的解释. 以下是本文的姊妹篇: 1.rsync(一):基本命令和用法 2.rsync(二):ino ...

  6. oracle分组-神奇的cube和rollup

    先看代码: 表结构如下: emp表 EMPNO                                     NOT NULL NUMBER(4) ENAME                 ...

  7. (转)eclipse安装jetty

    背景:在项目开发的过程中,一个老的项目使用的是jetty启动,在用tomcat启动的过程中出现了启动不了的异常,浪费了好多时间.因为项目一直是用jetty启动的,为了不浪费时间,也只好改变思路选择je ...

  8. css 过渡和 变形

    一.过渡(transition) transition-property: 指定具有过渡效果的CSS样式属性名 1.默认值: all 2.仅具有中间值(CSS样式值是数值的)的CSS样式具有过渡效果 ...

  9. OVS故障处理一例

    OVS下无法访问内部网站 遇到朋友求助的一个客户问题,环境是这样的,客户在自己的iaas平台(不是openstack)上使用ovs,物理交换机上配置vlan和dhcp service,计算节点的ovs ...

  10. Android文件上传与下载

    文件上传与下载 文件上传 -- 服务端 以Tomcat为服务器,Android客服端访问Servlet,经Servlet处理逻辑,最终将文件上传,这里就是简单模拟该功能,就将文件上传到本机的D:\\u ...