maven+mybatis—实现数据库中图书信息的增删改查

导读:本篇文章讲解 maven+mybatis—实现数据库中图书信息的增删改查,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

主要参考代码:

mybatis_config.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="db.properties"></properties>
    <!--引入mybatis特定配置-->
    <settings>
        <!--日志-->
        <setting name="logImpl" value="STDOUT_LOGGING"/>
        <!--下划线列名映射为小驼峰属性-->
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
    <!--配置类型别名-->
    <typeAliases>
        <package name="com.yzh7.entity"/>
    </typeAliases>

    <!--数据库环境-->
    <environments default="development">
        <environment id="development">
            <!--jdbc事务-->
            <transactionManager type="JDBC"/>
            <!--配置数据源连接池-->
            <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接口,通过三一致的规则自动与mapper文件关联-->
        <mapper class="com.yzh7.mapper.BookMapper"/>
    </mappers>
</configuration>

mybatis官网规则参考:

mybatis官网
https://mybatis.org/mybatis-3/zh/configuration.html#typeAliases
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

运行结果展示:

创建数据库/数据表:

在这里插入图片描述

运行testInsert():

在这里插入图片描述
在这里插入图片描述

为了方便删改查操作,这里插入两次数据
在这里插入图片描述
在这里插入图片描述

运行testQuery():

在这里插入图片描述

在这里插入图片描述

运行testUpdate():

在这里插入图片描述
在这里插入图片描述

运行testDelete():

在这里插入图片描述
在这里插入图片描述

项目实现思路:

在这里插入图片描述

代码整体布局:

在这里插入图片描述
注意:
在这里插入图片描述

代码:

pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>mybatis_0815_KTLX</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <!--引入jar包-->
    <dependencies>
        <!-- mybatis -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.6</version>
        </dependency>

        <!-- mysql驱动类 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.11</version>
        </dependency>
        <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.22</version>
        </dependency>
        <!--junit-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13</version>
            <scope>compile</scope>
        </dependency>
    </dependencies>

</project>

db.properties:

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/70813_db?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8&allowPublicKeyRetrieval=true
jdbc.username=root
jdbc.password=123456

mybatis_config.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="db.properties"></properties>
    <settings>
        <setting name="logImpl" value="STDOUT_LOGGING"/>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
    <typeAliases>
        <package name="com.yzh7.entity"/>
    </typeAliases>

    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <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接口,通过三一致的规则自动与mapper文件关联-->
        <mapper class="com.yzh7.mapper.BookMapper"/>
    </mappers>
</configuration>

mybatis映射器https://mybatis.org/mybatis-3/zh/configuration.html#mappers
在这里插入图片描述

Book:

package com.yzh7.entity;

import lombok.Data;

import java.util.Date;

@Data
public class Book {
//    book_id,book_name,author,price,publisher,pub_date

    private Integer bookId;
    private String bookName;
    private String author;
    private Double price;
    private String publisher;
    private Date pubDate;

}

BookMapper:

package com.yzh7.mapper;


import com.yzh7.entity.Book;

import java.util.List;
import java.util.Map;

public interface BookMapper {
	//查询
    List<Map> listAll();
    List<Book> listAll2();
    Book getById(Integer bookId);
	
	//添加
    int insert(Book book);
    //修改
    int update(Book book);  
    //删除
    int delete(Integer bookId);


}

BookMapper.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">

<mapper namespace="com.yzh7.mapper.BookMapper">
	<!--根据mapper接口中的方法定义增删改查-->
	<!--     book_id,book_name,author,price,publisher,pub_date-->

    <select id="listAll" resultType="map">
        select * from tb_book
    </select>
    <select id="listAll2" resultType="book">
        select * from tb_book
    </select>
    <select id="getById" parameterType="int" resultType="book">
        select * from tb_book
        where book_id=#{bookId}
    </select>
    <insert id="insert" parameterType="book">
        insert into tb_book
        (book_name,author,price,publisher,pub_date)
        values
        (#{bookName},#{author},#{price},#{publisher},#{pubDate})   <!-- # -->
    </insert>
    <update id="update" parameterType="book">
        update tb_book
        set book_name=#{bookName},author=#{author},price=#{price},publisher=#{publisher},pub_date=#{pubDate}
        where book_id=#{bookId}
    </update>
    <delete id="delete" parameterType="int">
        delete from tb_book
        where book_id=#{bookId}
    </delete>

</mapper>

demo:

package com.yzh7.test;

import com.yzh7.entity.Book;
import com.yzh7.mapper.BookMapper;
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.After;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;

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

public class demo {
    //添加
    @Test
    public void testInsert(){
        Book book=new Book();
        book.setBookName("图书1");
        book.setAuthor("作者1");
        book.setPrice(1.1);
        book.setPublisher("出版社1");
        book.setPubDate(new Date());
        BookMapper bookMapper=session.getMapper(BookMapper.class);
        int count=bookMapper.insert(book);
        System.out.println("插入的记录数:"+count);
        
		 //注意最后要提交事务
    }

    //查询
    @Test
    public void testQuery(){
        BookMapper bookMapper=session.getMapper(BookMapper.class);
        List<Map> mapList=bookMapper.listAll();     //list<Map>
        System.out.println(mapList);
        List<Book> bookList=bookMapper.listAll2();  //list<Book>
        System.out.println(bookList);
        Book book=bookMapper.getById(1);     //Book
        System.out.println(book);

    }

    //修改
    @Test
    public void testUpdate(){
        Book book=new Book();
        book.setBookId(2);
        book.setBookName("图书2");
        book.setAuthor("作者2");
        book.setPrice(2.2);
        book.setPublisher("出版社2");
        book.setPubDate(new Date());
        BookMapper bookMapper=session.getMapper(BookMapper.class);
        int count=bookMapper.update(book);
        System.out.println("修改的记录数:"+count);
    }

    //删除
    @Test
    public void testDelete(){
        BookMapper bookMapper=session.getMapper(BookMapper.class);
        int count=bookMapper.delete(1);
        System.out.println("删除的记录数:"+count);
    }
    
    //会话工厂
    private static SqlSessionFactory factory;    //静态
    //会话
    private  SqlSession session;

    @BeforeClass
    public static void befCla() throws IOException {
        String resource = "mybatis_config.xml";   //mybatis_config.xml
        InputStream inputStream = Resources.getResourceAsStream(resource);
        factory = new SqlSessionFactoryBuilder().build(inputStream);
    }

    @Before
    public void bf(){
        session=factory.openSession();
    }

    @After
    public void af(){
    	//提交事务
        session.commit();
        //关闭会话
        session.close();
    }
}

异常: java.io.IOException:

在这里插入图片描述

解决:

在这里插入图片描述

异常:java.lang.NullPointerException:

在这里插入图片描述
在这里插入图片描述

解决:

在这里插入图片描述

异常: org.apache.ibatis.exceptions.PersistenceException:

在这里插入图片描述

解决:

根据错误提示“Cause: java.sql.SQLSyntaxErrorException: Unknown column ‘图书1’ in ‘field list’”,向前找insert方法
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/118057.html

(0)
seven_的头像seven_bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!