当前位置: 首页 > news >正文

MyBatis框架的入门案例

MyBatis框架的入门案例

资源地址:https://download.csdn.net/download/weixin_41957626/87531373

1.MyBatis的配置

环境:基于maven的结构

1.1目录结构

1.2依赖包

    <dependencies>
        <!--mybatis-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.7</version>
        </dependency>
        <!--mysql驱动-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.12</version>
        </dependency>
        <!--junit-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.10</version>
        </dependency>
        <!--log4j-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.12</version>
        </dependency>
<!--       简化属性开发-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>RELEASE</version>
            <scope>compile</scope>
        </dependency>
    </dependencies>

1.3配置文件代码

1.主要分为log4j的配置和MyBatis的配置文件的配置

SqlMapConfig.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<!--nybatis的配置文件
设置数据源等信息
-->
<configuration><!--配置mysql环境-->
<!--    默认采用development环境的配置--><environments default="development">
<!--        开发环境,id的值随便写--><environment id="development"><!--配置事务类型交给JDBC处理,还有别的--><transactionManager type="JDBC"></transactionManager><!--数据源POOLED设置使用连接池UNPOOLED表示不使用连接池--><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://127.0.0.1:3306/xxxx?userSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=UTC"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><!--注册映射文件,注意地址--><mappers>
<!--        注意地址的写法-->
<!--    采用的不是在resource目录下配置的    <mapper resource="cn/lxz/mapper/xml/UserMapper.xml"></mapper>-->
<!--        采用的是在resource目录下配置的--><mapper resource="mappers/UserMapper.xml"></mapper></mappers></configuration>

log4j配置

log4j.rootLogger=debug, stdout, Rlog4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%nlog4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.loglog4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=5log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n

1.4实体和mapper代码

1.4.1实体代码

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements Serializable {
    private Integer id;
    private String name;}

1.4.2mapper代码

public interface UserMapper {public List<User> findAllUsers();public int addUser(User user);public int deleteUserById(User user);public int updateUser(User user);}

1.4.3mapper映射文件代码

 

<?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="cn.lxz.mapper.UserMapper">
    <!--sql-->    <!-- select insert update delete -->
    <insert id="addUser">
        insert into user(name) values (#{name})
    </insert>
    <update id="updateUser">
        update user set name=#{name} where id=#{id}
    </update>
    <delete id="deleteUserById">
        delete from user where id=#{id}
    </delete>
    <select id="findAllUsers" resultType="cn.lxz.domain.User">
         select  * from user;
    </select></mapper>

1.4.4注意事项

映射文件注意事项:
映射文件中的id属性是对应的持久层接口中的方法名
映射文件要和接口名称相同。
映射文件要和接口的目录结构相同。
映射文件中namespace属性要写接口的全名。
映射文件中标签的id属性是接口方法的方法名。
映射文件中标签的resultType属性是接口方法的返回值类型。
映射文件中标签的parameterType属性是接口方法的参数类型。
映射文件中resultTypeparameterType属性要写全类名,如果是集合类型,则写其泛型的全类名。

1.5测试类

1.5.1测试代码

需要学会使用Junit单元测试的方法

掌掌握builder,factory再session,再去加载mapper再去执行相关的操作

1.查询所有的用户信息

public class UserMapperTest {@Testpublic void findAll() throws IOException {//读取核心配置文件InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");//创建builder对象SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();//factory对象SqlSessionFactory factory = builder.build(inputStream);//创建sessionSqlSession session = factory.openSession();//SqlSession对象获取代理对象UserMapper mapper = session.getMapper(UserMapper.class);//代理对象执行方法List<User> all = mapper.findAllUsers();for (User u : all){System.out.println(u);}//关闭资源
        session.close();
        inputStream.close();}
}

2.增加用户的信息

 @Test
    public void addUser() throws Exception{
        //读取核心配置文件
        InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");
        //创建builder对象
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        //factory对象
        SqlSessionFactory factory = builder.build(inputStream);
        //创建session
        SqlSession session = factory.openSession();
        //SqlSession对象获取代理对象
        UserMapper mapper = session.getMapper(UserMapper.class);
//================================================================
        mapper.addUser(new User(null,"王五"));
//================================================================
        //关闭资源
        session.close();
        inputStream.close();
    }

1.5.2测试截图

  • 查询全部的信息

  • 增加

http://www.lryc.cn/news/28722.html

相关文章:

  • 红黑树-随记
  • Python异常处理更新,正常和不正常的都在这里
  • [数据结构]:10-二叉排序树(无头结点)(C语言实现)
  • openstack浅析
  • 华为OD机试Golang解题 - 特异性双端队列 | 含思路
  • 代码随想录中:回溯算法的基础
  • Android kotlin 系列讲解(进阶篇)Jetpack系列之LiveData
  • 如何判断有向无环图:构造有向无环图
  • 【2022.1.3】手脱压缩壳练习(含练习exe)
  • 【异或哈希】CF855 div3 F
  • 深度学习|改进两阶段鲁棒优化算法i-ccg
  • C++11轻松打印本地时间
  • Eureka - 总览
  • 【算法设计-枚举、分治】素数、约数、质因数分解
  • 【第十四届蓝桥杯】第三期模拟赛B组C++题解(待修正+持续更新-ing)
  • 线程池和ThreadLocal详解
  • [深入理解SSD系列综述 1.7] SSD固态存储市场发展分析与预测_固态存储技术发展方向(2022to2023)
  • 【2021.12.25】ctf逆向中常见加密算法和编码识别
  • 【数据结构初阶】堆排序
  • Day5: platformDriver-1
  • 开发手册——一、编程规约_7.控制语句
  • python每日学9 : windows上配置gitee的远程仓库,git的初步使用
  • 精确率与召回率,ROC曲线与PR曲线
  • 现代操作系统——Linux架构与学习
  • 中文代码82
  • 顺序表(一篇带你掌握顺序表)
  • 【SpringCloud】SpringCloud教程之Feign实战
  • 嵌入式linux必备内存泄露检测神器
  • 设计模式之行为型模式
  • 解密 三岁的三岁到底为什么叫做三岁?