初识Mybatis

什么是Mybatis:

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。

MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。

MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。

Mybatis的特点:

简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。

灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。

解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。

提供映射标签,支持对象与数据库的orm字段关系映射

提供对象关系映射标签,支持对象关系组建维护

提供xml标签,支持编写动态sql。

 

Idea如何配置Mybatis:

 

1.创建工程

  这里为了方便直接用一个模板

 

 

 

创建完毕

 

2.引入mybatis所需jar包

复制代码
复制代码
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.4.1</version>
    </dependency>

    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>6.0.6</version>
    </dependency>

  //测试相关
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
    </dependency>
  //日志相关
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.17</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.25</version>
    </dependency>
复制代码
复制代码

3.创建一个实体类对应数据字段,并在数据库中创建对应的数据表

复制代码
复制代码
public class User implements Serializable {

    private static final long serialVersionUID = 8104961490512068314L;
    private int id;
    private String name;
    private String dept;
    private String phone;
    private String website;

    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 String getDept() {
        return dept;
    }

    public void setDept(String dept) {
        this.dept = dept;
    }

    public String getPhone() {
        return phone;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }

    public String getWebsite() {
        return website;
    }

    public void setWebsite(String website) {
        this.website = website;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", dept='" + dept + '\'' +
                ", phone='" + phone + '\'' +
                ", website='" + website + '\'' +
                '}';
    }

}  
复制代码
复制代码

4.添加mysql配置文件,mybatis配置文件

mybatis-config.xml

复制代码
复制代码
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<properties resource="mysql.properties"></properties>
<!-- 配置mybatis运行环境 -->
<environments default="development">
<environment id="development">
<!-- type="JDBC" 代表使用JDBC的提交和回滚来管理事务 -->
<transactionManager type="JDBC"/>

<!-- mybatis提供了3种数据源类型,分别是:POOLED,UNPOOLED,JNDI -->
<!-- POOLED 表示支持JDBC数据源连接池 -->
<!-- UNPOOLED 表示不支持数据源连接池 -->
<!-- JNDI 表示支持外部数据源连接池 -->
<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>
<!-- 映射文件方式1,一个一个的配置-->
<mapper resource="com/mybatis/demo/dao/UserDao.xml"/>
<mapper resource="com/mybatis/demo/dao/ProviderDao.xml"/>
<!-- 映射文件方式2,自动扫描包内的Mapper接口与配置文件 -->
<!--<package name="com.mybatis.demo"/>-->
</mappers>
</configuration>
复制代码
复制代码

mysql.properties:

复制代码
复制代码
jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/smbms?characterEncoding=utf-8&serverTimezone=GMT%2B8
jdbc.username=root
jdbc.password=123456
jdbc.maxActive=100
jdbc.maxWait=5000
jdbc.filters=wall,stat
复制代码
复制代码

5.添加mapper类接口以及对应mapper.xml

复制代码
复制代码
package com.mybatis.demo.dao;

import com.mybatis.demo.Entity.User;

import java.util.List;

public interface UserDao {
public List<User> getalluser();
}
复制代码
复制代码

6.在mapper.xml中填写sql语句和配置返回值类型

复制代码
复制代码
<?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需要指向接口全路径-->
<mapper namespace="com.mybatis.demo.dao.UserDao">
<select id="getalluser" resultType="com.mybatis.demo.Entity.User">
select * from smbms_user
</select>
</mapper>
复制代码
复制代码

7.在配置文件中注册该xml.

 

8.编写单元测试,通过sqlSession 操作数据库

复制代码
复制代码
package chapter1;
import com.mybatis.demo.Entity.Provider;
import com.mybatis.demo.Entity.User;
import com.mybatis.demo.utils.MyBatisUtil;
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 org.junit.*;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;


public class mytest {

SqlSession sqlSession;

   //在执行之前
@Before
public void before () throws IOException {
String source = "mybatis-config.xml";
SqlSessionFactory factory = MyBatisUtil.getSqlSessionFactory(source);
sqlSession = factory.openSession();
}
/**
* Rigorous Test :-)
*/
//所有人名
public void getalluser() throws IOException {

List<User> getalluser = sqlSession.selectList("getalluser");
for (User user: getalluser) {
System.out.println(user.getUserName());
}

}

     //在执行之后
@After
public void after (){
sqlSession.close();
}
}

复制代码
复制代码

 

 

posted @ 2019-09-27 16:19  琴昕LNS~  阅读(153)  评论(0编辑  收藏  举报