01、Mybatis快速入门

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

1.3 添加jar包

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

 1 <dependencies>
 2     <dependency>
 3         <groupId>org.mybatis</groupId>
 4         <artifactId>mybatis</artifactId>
 5         <version>3.4.5</version>
 6     </dependency>
 7 
 8     <dependency>
 9         <groupId>log4j</groupId>
10         <artifactId>log4j</artifactId>
11         <version>1.2.17</version>
12     </dependency>
13 
14     <dependency>
15         <groupId>mysql</groupId>
16         <artifactId>mysql-connector-java</artifactId>
17         <version>5.1.43</version>
18     </dependency>
19         
20     <dependency>
21         <groupId>junit</groupId>
22         <artifactId>junit</artifactId>
23         <version>4.12</version>
24         <scope>test</scope>
25     </dependency>
26 </dependencies>

1.4 创建数据库

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

 1 /*Table structure for table user */
 2 CREATE TABLE USER (
 3   id INT(11) NOT NULL AUTO_INCREMENT,
 4   username VARCHAR(32) NOT NULL COMMENT '用户名称',
 5   birthday DATE DEFAULT NULL COMMENT '生日',
 6   sex CHAR(1) DEFAULT NULL COMMENT '性别',
 7   address VARCHAR(256) DEFAULT NULL COMMENT '地址',
 8   PRIMARY KEY (id)
 9 );
10 
11 /*Table structure for table items */
12 CREATE TABLE items (
13   id INT(11) NOT NULL AUTO_INCREMENT,
14   NAME VARCHAR(32) NOT NULL COMMENT '商品名称',
15   price FLOAT(10,1) NOT NULL COMMENT '商品定价',
16   detail TEXT COMMENT '商品描述',
17   pic VARCHAR(64) DEFAULT NULL COMMENT '商品图片',
18   createtime DATETIME NOT NULL COMMENT '生产日期',
19   PRIMARY KEY (id)
20 );
21 
22 /*Table structure for table orders */
23 CREATE TABLE orders (
24   id INT(11) NOT NULL AUTO_INCREMENT,
25   user_id INT(11) NOT NULL COMMENT '下单用户id',
26   number VARCHAR(32) NOT NULL COMMENT '订单号',
27   createtime DATETIME NOT NULL COMMENT '创建订单时间',
28   note VARCHAR(100) DEFAULT NULL COMMENT '备注',
29   PRIMARY KEY (id),
30   KEY FK_orders_1 (user_id),
31   CONSTRAINT FK_orders_id FOREIGN KEY (user_id) REFERENCES USER (id) ON DELETE NO ACTION ON UPDATE NO ACTION
32 );
33 
34 /*Table structure for table orderdetail */
35 CREATE TABLE orderdetail (
36   id INT(11) NOT NULL AUTO_INCREMENT,
37   orders_id INT(11) NOT NULL COMMENT '订单id',
38   items_id INT(11) NOT NULL COMMENT '商品id',
39   items_num INT(11) DEFAULT NULL COMMENT '商品购买数量',
40   PRIMARY KEY (id),
41   KEY FK_orderdetail_1 (orders_id),
42   KEY FK_orderdetail_2 (items_id),
43   CONSTRAINT FK_orderdetail_1 FOREIGN KEY (orders_id) REFERENCES orders (id) ON DELETE NO ACTION ON UPDATE NO ACTION,
44   CONSTRAINT FK_orderdetail_2 FOREIGN KEY (items_id) REFERENCES items (id) ON DELETE NO ACTION ON UPDATE NO ACTION
45 );

1.5 导入数据

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

 1 /*Data for the table user*/
 2 INSERT  INTO USER(id,username,birthday,sex,address) VALUES 
 3     (1,'王五',NULL,'2',NULL),(10,'张三','2014-07-10','1','北京市'),
 4     (16,'张小明',NULL,'1','河南郑州'),(22,'陈小明',NULL,'1','河南郑州'),
 5     (24,'张三丰',NULL,'1','河南郑州'),(25,'陈小明',NULL,'1','河南郑州'),
 6     (26,'王五',NULL,NULL,NULL);
 7 
 8 /*Data for the table items*/
 9 INSERT  INTO items(id,NAME,price,detail,pic,createtime) VALUES 
10     (1,'台式机',3000.0,'该电脑质量非常好!!!!',NULL,'2015-02-03 13:22:53'),
11     (2,'笔记本',6000.0,'笔记本性能好,质量好!!!!!',NULL,'2015-02-09 13:22:57'),
12     (3,'背包',200.0,'名牌背包,容量大质量好!!!!',NULL,'2015-02-06 13:23:02');
13 
14 /*Data for the table `orders` */
15 INSERT  INTO orders(id,user_id,number,createtime,note) VALUES 
16     (3,1,'1000010','2015-02-04 13:22:35',NULL),
17     (4,1,'1000011','2015-02-03 13:22:41',NULL),
18     (5,10,'1000012','2015-02-12 16:13:23',NULL);
19 
20 /*Data for the table `orderdetail` */
21 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的内容如下:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE configuration
 3     PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
 4     "http://mybatis.org/dtd/mybatis-3-config.dtd">
 5 <configuration>
 6     <!-- 加载属性文件 -->
 7     <properties resource="jdbc.properties"></properties>
 8     
 9     <environments default="development">
10         <environment id="development">
11             <!-- 使用jdbc事务管理,事务控制由mybatis-->
12             <transactionManager type="JDBC"/>
13             <!-- 数据库连接池,由mybatis管理-->
14             <dataSource type="POOLED">
15                 <property name="driver" value="${jdbc.driver}"/>
16                 <property name="url" value="${jdbc.url}"/>
17                 <property name="username" value="${jdbc.username}"/>
18                 <property name="password" value="${jdbc.password}"/>
19             </dataSource>
20         </environment>    
21     </environments>
22 </configuration>

2.2 创建实体类和映射文件

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

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

  • User.java:
     1 package com.sunny.mybatis.domain;
     2 
     3 import java.io.Serializable;
     4 import java.util.Date;
     5 
     6 public class User implements Serializable {
     7     private static final long serialVersionUID = 6856509574533500731L;
     8 
     9     private int id;
    10     private String username;
    11     private String sex;
    12     private Date birthday;
    13     private String address;
    14 
    15     public int getId() {
    16         return id;
    17     }
    18 
    19     public void setId(int id) {
    20         this.id = id;
    21     }
    22 
    23     public String getUsername() {
    24         return username;
    25     }
    26 
    27     public void setUsername(String username) {
    28         this.username = username;
    29     }
    30 
    31     public String getSex() {
    32         return sex;
    33     }
    34 
    35     public void setSex(String sex) {
    36         this.sex = sex;
    37     }
    38 
    39     public Date getBirthday() {
    40         return birthday;
    41     }
    42 
    43     public void setBirthday(Date birthday) {
    44         this.birthday = birthday;
    45     }
    46 
    47     public String getAddress() {
    48         return address;
    49     }
    50 
    51     public void setAddress(String address) {
    52         this.address = address;
    53     }
    54 
    55 }
  • 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:

     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <!DOCTYPE configuration
     3     PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
     4     "http://mybatis.org/dtd/mybatis-3-config.dtd">
     5 <configuration>
     6     <!-- 加载属性文件 -->
     7     <properties resource="jdbc.properties"></properties>
     8     
     9     <environments default="development">
    10         <environment id="development">
    11             <!-- 使用jdbc事务管理,事务控制由mybatis-->
    12             <transactionManager type="JDBC"/>
    13             <!-- 数据库连接池,由mybatis管理-->
    14             <dataSource type="POOLED">
    15                 <property name="driver" value="${jdbc.driver}"/>
    16                 <property name="url" value="${jdbc.url}"/>
    17                 <property name="username" value="${jdbc.username}"/>
    18                 <property name="password" value="${jdbc.password}"/>
    19             </dataSource>
    20         </environment>    
    21     </environments>
    22     
    23     <!-- 加载映射文件 -->
    24     <mappers>
    25         <mapper resource="com/sunny/mybatis/mapper/UserMapper.xml"/>
    26     </mappers>
    27 </configuration>

2.3 测试

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

posted @ 2017-08-26 20:14  小龙Sunny  阅读(527)  评论(0编辑  收藏  举报