首页 > 其他分享 >MyBatis学习笔记02

MyBatis学习笔记02

时间:2022-08-25 10:47:18浏览次数:43  
标签:02 CONSOLE 笔记 id mybatis import MyBatis org log4j

1. 环境搭建

1.1 数据初始化

//创建库
CREATE DATABASE tj_mybatis_learning;
//创建表
CREATE TABLE tbl_department (
  id varchar(32) NOT NULL,
  deptName varchar(32) NOT NULL,
  phone varchar(18) DEFAULT NULL,
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
//初始化数据
INSERT INTO tbl_department(id, deptName, phone) VALUES ('18ec781fbefd727923b0d35740b177ab', '开发部', '110');
INSERT INTO tbl_department(id, deptName, phone) VALUES ('53e3803ebbf4f97968e0253e5ad4cc83', '测试产品部', '111');
INSERT INTO tbl_department(id, deptName, phone) VALUES ('ee0e342201004c1721e69a99ac0dc0df', '运维部', '112');

1.2 Maven工程创建

pom.xml依赖


    <dependencies>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.5</version>
        </dependency>

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

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.18</version>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
    </dependencies>
	
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
        </plugins>
    </build>

日志文件log4j.properties

log4j.rootCategory=debug, CONSOLE

# Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE

# CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.Encoding=UTF-8
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m \n

mybatis全局的配置文件 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>
    <settings>
        <setting name="logImpl" value="LOG4J"/>
    </settings>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/tj_mybatis_learning?characterEncoding=utf-8"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="mapper/department.xml"/>
    </mappers>
</configuration>

部门mapper.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="departmentMapper">

    <select id="findAll" resultType="com.tongjun.mybatis.entity.Department">
        select * from tbl_department
    </select>
</mapper>

实体类编写

package com.tongjun.mybatis.entity;

import lombok.Data;

import java.io.Serializable;

/**
 * @author tj
 * @date 2022/8/25 10:26
 * @Version 1.0
 */
@Data
public class Department implements Serializable {

    private String id;

    private String deptName;

    private String phone;

}

测试程序编写

package com.tongjun.mybatis.app;

import com.tongjun.mybatis.entity.Department;
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.InputStream;
import java.util.List;

/**
 * @author tj
 * @date 2022/8/25 10:28
 * @Version 1.0
 */
public class ApplicationTest {
    public static void main(String[] args) throws Exception{
        //拿到mybatis配置文件的流
        InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
        //创建sqlSession工厂
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
        //通过工厂拿到sqlSession对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //通过sqlSession调用mapper
        List<Department> list = sqlSession.selectList("departmentMapper.findAll");
        list.forEach(System.out::println);
    }
}

执行程序,查看结果,控制台输出

Department(id=18ec781fbefd727923b0d35740b177ab, deptName=开发部, phone=110)
Department(id=53e3803ebbf4f97968e0253e5ad4cc83, deptName=测试产品部, phone=111)
Department(id=ee0e342201004c1721e69a99ac0dc0df, deptName=运维部, phone=112)

如果可以输出结果,说明基础代码已经成功了

标签:02,CONSOLE,笔记,id,mybatis,import,MyBatis,org,log4j
From: https://www.cnblogs.com/tongjun/p/16623301.html

相关文章

  • CSP 202006-1 202006-2 题解
    #202006-1线性分类器在坐标系中,我们可以考虑使用同一横坐标x值对应的y值来判断在直线的上方一侧还是在下方一侧。当然,如果不在坐标系中也可以统计点和直线的位置关系,这......
  • MyBastis学习笔记01
    1.MyBatis概述MyBatis是一款优秀的持久层框架,它支持自定义SQL、存储过程以及高级映射。MyBatis免除了几乎所有的JDBC代码以及设置参数和获取结果集的工作。MyBati......
  • 02第二章:Docker安装
    一、安装前提Docker安装前提条件目前,CentOS仅发行版本中的内核支持Docker。Docker运行在CentOS7(64-bit)上,要求系统为64位、Linux系统内核版本为3.8以上,......
  • Vectorworks 2022(首选3D建筑设计软件)
    Vectorworks2022是一款建筑设计软件,Vectorworks软件使得在概念设计阶段就很容易量化和分析信息,因此您可以做出明智的决定。运行“假设如何”场景和自动化进度表、计算成本......
  • 2022年8月份压测的一些想法
    停车压测:    查询类压测注意事项:       1.例如车牌查询,1000用户并发压测京AA20524,那么服务器的内存变化不大。如果压测的车牌不同每个不一样,那才会......
  • Dubbo/Zookeeper笔记
    分布式基础:Doubbo/Zookeeper分布式理论一、什么是分布式系统?分布式系统是若干个独立计算机的集合,这些计算机对于用户来说就像单个相关系统分布式系统是一组通过......
  • 2022牛客暑假第五场加塞
    M-MaimaiDX2077_"蔚来杯"2022牛客暑期多校训练营(加赛)(nowcoder.com)阅读理解和膜你题。doublepts[5][5]={ {1,1,0.8,0.5,0}, {2,2,1.6,1.0,0}, {3,3,2.4,1.5,0},......
  • 2022-08-24 第五组 赖哲栋 学习笔记
    JavaScriptJavaScript脚本语言,解释型,主要用来给HTML网页增加动态功能通常的js是运行在浏览器环境下的JS的两种模型DOM:文档对象模型documentBOM:浏览器对象模型wind......
  • 【2022知乎爬虫】我用Python爬虫爬了2300多条知乎评论!
    您好,我是@马哥python说,一枚10年程序猿。一、爬取目标前些天我分享过一篇微博的爬虫:https://www.cnblogs.com/mashukui/p/16414027.html但是知乎平台和微博平台的不同......
  • Java学习笔记5
    抽象类抽象类和其中抽象方法由abstract修饰,继承抽象类的所有方法必须由子类实现。Java的类是单继承,但是可以继承多个接口抽象类不能new实例化接口普通类:只有具体实......