myBatis入门和单表增删改查和模糊查询

概念

mybatis 是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。

mybatis通过xml或注解的方式将要执行的各种 statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。

最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc 进行了封装,屏蔽了jdbc api 底层访问细节,使我们不用与jdbc api 打交道,就可以完成对数据库的持久化操作。

基于ORM思想的半自动持久层框架。
ORM:object relation mapping。对象关系映射,让实体类和表产生映射关系。操作实体类等同于操作表。

写在前面的
引入依赖
编写映射配置文件:注意层级目录要相同,写sql语句。取值#{username}
接口的全类名
在这里插入图片描述
编写核心配置文件:起别名,配置数据源,加载映射配置文件
不用在写dao的实现类,写dao接口就好。第二张图加载dao接口的.class文件。生成代理的实现类对象。底层通过动态代理,找到对应的映射配置文件,执行sql语句。

.openSession();.openSession(boolean true/false):默认开启事务,但是不会自动提交。true为自动提交,false为手动提交。

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

开发步骤

①添加MyBatis的坐标

②创建user数据表

③编写User实体类

④编写映射文件UserMapper.xml

⑤编写核心文件SqlMapConfig.xml

⑥编写测试类

1. 添加坐标

<!--mybatis坐标-->
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.4.5</version>
</dependency>
<!--mysql驱动坐标-->
<dependency>    
    <groupId>mysql</groupId>   
    <artifactId>mysql-connector-java</artifactId>    
    <version>5.1.6</version>    
    <scope>runtime</scope>
</dependency>
<!--单元测试坐标-->
<dependency>    
    <groupId>junit</groupId>    
    <artifactId>junit</artifactId>    
    <version>4.12</version>    
    <scope>test</scope>
</dependency>
<!--日志坐标-->
<dependency>    
    <groupId>log4j</groupId>    
    <artifactId>log4j</artifactId>    
    <version>1.2.12</version>
</dependency>

核心配置文件

<?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文件-->
    <properties resource="jdbc.properties"/>

    <!--扫包-->
    <!--要求:接口和映射配置文件:同包同名-->
    <typeAliases>
        <package name="cn.itcast.domain"/>
    </typeAliases>

    <!--类设置设置类型别名-->
    <!--<typeAliases>-->
        <!--<package name="cn.itcast.domain"/>-->
    <!--</typeAliases>-->

    <!--<typeAlias type="cn.itcast.domain.User" alias="user"/> -->


    <!--配置数据源-->
    <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 resource="cn/itcast/mapper/UserMapper.xml"/>-->
        <!--<mapper resource="cn/itcast/dao/Impl/UserDaoImpl.xml"/>-->
        <!--只能在Mapper代理开发中使用-->
        <!--使用相对于类路径资源的引用,整个包下的配置文件引用-->
        <package name="cn.itcast.dao"></package>

    </mappers>
</configuration>

同包同名
同包同名
起别名
起别名
在这里插入图片描述
本来在这个位置需要全类名,但是由于在User实现类在domain下,起了别名,就直接写实现类名即可,不区分大小写。

配置配置文件和写代码注意的事项

注意事项
注意的细节:核心文件配置映射文件时,单个配置文件,是/分隔。配置一个包下的所有配置文件是.分隔
在这里插入图片描述
几个要一样的地方。

在这里插入图片描述

起别名

在这里插入图片描述

加载映射配置文件

在这里插入图片描述
层级结构相同:resource目录下建包以/分隔才能有层级。
在这里插入图片描述

关于#{}和${}

前者属于占位符相当于?。

#{}和${}的区别:
#{}表示一个占位符
#{}可以实现prepareStatment向占位符中设置值,自动进行JDBC和java类型转换,防止ql注入
#{}可以接收简单类型值或pojo属性值,如果parameterType传输基本数据类型,值随便写
${}表示拼接sql串
${}是将传入的参数原样拼接在sql中,不进行jdbc类型转换
可 以 接 收 简 单 类 型 值 或 p o j o 属 性 值 , 如 果 p a r a m e t e r T y p e 传 输 基 本 数 据 类 型 , {}可以接收简单类型值或pojo属性值,如果parameterType传输基本数据类型, pojoparameterType{}括号中只能是value

‘%${name}%’--------“tom”
#{name}--------"%tom%"

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

增删改查

在这里插入图片描述

模糊查询

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

河西彭于晏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值