Mybatis入门

Mybatis

mybatis是一款优秀的持久层框架,用于简化JDBC的开发。(控制层 controller)(业务层service)(持久层dao)(数据库)

快速创建springboot-mybatis工程

jdk选11 ,依赖Mybatis Framework 和 MySql driver---- 删除乱七八糟的文件夹 只留下src和pom.xml

创建数据库表

登录mysql,创建mybatis数据库

create database mybatis;
create table user(id int unsigned primary key auto_increment,name varchar(100),age tinyint unsigned,gender tinyint unsigned,phone varchar(11));//创建个user表 随表插几条数据
insert into user (name, age, gender, phone) VALUES ('朱元璋',22,1,'12345678900');
insert into user (name, age, gender, phone) VALUES ('马皇后',18,2,'12345678901');

项目生成user类

 package com.example.springbootmybatis.pojo;

public class User {
    private Integer id;
    private String name;
    private Short age;
    private Short gender;
    private String phone;

    public User() {
    }

    public User(Integer id, String name, Short age, Short gender, String phone) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.gender = gender;
        this.phone = phone;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Short getAge() {
        return age;
    }

    public void setAge(Short age) {
        this.age = age;
    }

    public Short getGender() {
        return gender;
    }

    public void setGender(Short gender) {
        this.gender = gender;
    }

    public String getPhone() {
        return phone;
    }

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

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

引入Mybatis的相关依赖,配置mybatis数据库连接信息

application.properties
#配置数据库连接信息
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis?useSSL=false&characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=1234

UserMapper接口

@Mapper //运行时。会自动生成该接口的实现对象(代理对象),并且将对象交给IOC容器管理
public interface UserMapper {
    //定义方法
    //查询所哟
    @Select("select * from user")
    public List<User> list();
}

基本测试

@Autowired
private  UserMapper userMapper;
查询中文乱码
show variables like'%basedir%';//检查Mysql ini文件
检查IDEA配置
检查properties配置

配置SQL提示

在这里插入图片描述

JDBC快速入门

@Test
    public void jdbcTest() throws Exception {
        //1.注册驱动
        Class.forName("com.mysql.cj.jdbc.Driver");
        //2.获取连接对象
        String url ="jdbc:mysql://localhost:3306/mybatis";
        String userName = "root";
        String password = "1234";
        Connection connection = DriverManager.getConnection(url, userName, password);
        //3.获取statement对象执行sql
        String sql = "select * from user";
        Statement statement = connection.createStatement();
        ResultSet resultSet = statement.executeQuery(sql);
        //4.封装结果数据
        List<User> list = new ArrayList<>();
        while (resultSet.next()){
            Integer id = resultSet.getInt("id");
            String name = resultSet.getString("name");
            Short age = resultSet.getShort("age");
            Short gender = resultSet.getShort("gender");
            String phone = resultSet.getString("phone");
            User user = new User(id, name, age, gender, phone);
            list.add(user);
        }
        //5.释放资源
        statement.cancel();
        connection.close();

        list.stream().forEach(user -> {
            System.out.println(user);
        });

    }

数据库连接池

数据库连接池是个容器,负责分配、管理数据库连接(connection)。
允许应用程序使用同一个现有的数据库连接,而不需要新建立。
释放空间时间超过最大空闲时间的连接,来避免因没有释放连接而引起的数据库连接遗漏。

优势:资源重用、提升系统响应速度、避免数据库连接遗漏。

Druid连接池

pom.xml

<dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.2.8</version>
 </dependency>

lombok工具包

在这里插入图片描述

 <dependency>
       <groupId>org.projectlombok</groupId>
       <artifactId>lombok</artifactId>
 </dependency>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值