Maven+mybatis

maven:使用java语言编写的基于项目对象模型的项目管理工具软件

maven的仓库:中央仓库,本地仓库,镜像仓库

maven的资源坐标:

GroupId:一般是逆向公司域名com.zrt

ArtifactId:一般是项目(jar)名mysql-connector-java.

Version:版本号8.0.28

框架:

重复基础代码封装,同时添加额外功能

Mybatis:

持久层框架(数据库连接框架),ORM框架(对象/关系 映射)

1.创建数据库表

2.创建maven项目

3.添加依赖

在pol.xml文件中配置

XML 复制代码
<dependencies>
    <!-- mysql驱动的依赖 -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.28</version>
    </dependency>

    <!-- Mybatis依赖 -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.6</version>
    </dependency>
</dependencies>

4.创建mybatis全局配置文件

在resources文件中配置xml文件

XML 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
//环境配置
    <environments default="mysql">//默认链接mysql
        <environment id="mysql">
            <transactionManager type="JBDC"></transactionManager>//事务处理jdbc/manager
            <dataSource type="POOLED">//数据源信息UNPOOLED/POOLED/JNDI(POOLED 数据库连接池,数据库连接请求频率高就要用到)
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/bookmanager?useSSL=false&amp;serverTimezone=UTC&amp;allowPublicKeyRetrieval=true"/>
                <property name="username" value="root"/>
                <property name="password" value="zrt20031002"/>
            </dataSource>
        </environment>
    </environments>
</configuration>

5.创建实体类

java 复制代码
//要和数据库中列明保持一致
public class Book {
    private int id;
    private String name;
    private String author;
    private double price;

    public int getId() {
        return id;
    }

    public String getName() {
        return name;
    }

    public String getAuthor() {
        return author;
    }

    public double getPrice() {
        return price;
    }

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

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

    public void setAuthor(String author) {
        this.author = author;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    public Book(int id, String name, String author, double price) {
        this.id = id;
        this.name = name;
        this.author = author;
        this.price = price;
    }
}

6.创建映射文件

XML 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper>
    <select id="selectAllBooks" resultType="com.zrt.pojo.Book">
        select * from t_book
    </select>
</mapper>

把映射文件放到mysatis配置文件中去,就能实现mysatis项目加载映射文件

XML 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <environments default="mysql">
        <environment id="mysql">
            <transactionManager type="JBDC"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/bookmanager?useSSL=false&amp;serverTimezone=UTC&amp;allowPublicKeyRetrieval=true"/>
                <property name="username" value="root"/>
                <property name="password" value="zrt20031002"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="mapper/BookMapper.xml"></mapper>
    </mappers>
</configuration>

7.编写测试类------自动项目

java 复制代码
package com.zrt.test;

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 java.io.IOException;
import java.io.InputStream;
import java.util.List;

public class Test {
    public static void main(String[] args) throws IOException {
        //指定核心配置文件的路径:
        String resource = "mybatis.xml";
        //获取加载配置文件的一个输入流:
        InputStream inputStream = Resources.getResourceAsStream(resource);
        //加载配置文件,创建工厂类
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        //通过工厂类获取一个会话:
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //执行查询语句
        List<com.zrt.pojo.Book> list = sqlSession.selectList("a.b.selectAllBooks");
        //遍历:
        for (com.zrt.pojo.Book book : list) {
            System.out.println(book.getId() + "---" + book.getName() + "---" + book.getAuthor() + "---" + book.getPrice());
        }
            //关闭会话
        sqlSession.close();
    }
}
相关推荐
一定要AK2 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao2 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
KevinCyao2 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
迷藏4942 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
不吃香菜学java3 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
wuxinyan1233 小时前
Java面试题47:一文深入了解Nginx
java·nginx·面试题
新知图书3 小时前
搭建Spring Boot开发环境
java·spring boot·后端
冰河团队3 小时前
一个拉胯的分库分表方案有多绝望?整个部门都在救火!
java·高并发·分布式数据库·分库分表·高性能
洛_尘3 小时前
Java EE进阶:Linux的基本使用
java·java-ee
宸津-代码粉碎机4 小时前
Spring Boot 4.0虚拟线程实战调优技巧,最大化发挥并发优势
java·人工智能·spring boot·后端·python