MyBatis标签及其应用示例

news2024/12/23 14:03:53

MyBatis标签及其应用示例

1. select

1.1 标签属性

id唯一的标识符
parameterType传给此语句的参数的全路径名或别名如:com.xxx.xxx.demo.entity.User或user
resultType语句返回值类型或别名。如果是集合List,此处填写集合的泛型T,而不是集合本身。同时,resultType 与resultMap 只能用一个。此外,

2.1 应用示例

	<select id="selectUserlist" parameterType="string" resultType="com.xxx.xxx.demo.entity.User">
	        select * from user where name = #{name}
	</select>
2.1.1 resultType到底该填啥

resultType:

基本类型resultType=‘基本类型’
List类型resultType=‘List中元素的类型即List中的T’
Map类型resultType =‘map’

2. insert

2.1 标签属性

id唯一的标识符
parameterType传给此语句的参数如 com.xxx.xxx.demo.entity.User

2.2 应用示例

2.2.1 常规应用
    <insert id="insertUser" parameterType="com.xxxx.xxxx.demo.entity.User">
        insert into user (name, age, email) values (#{name}, #{age}, #{email})
    </insert>
2.2.2 插入后返回主键

增加以下两个可以获取(获取方式:通过对象的get方法)刚刚插入数据库数据的主键如id
useGeneratedKeys=“true” 使用生成的主键
keyProperty="" 查询的主键名,主键字段对应实体类的属性,一般为id

    <insert id="insertUser" parameterType="com.xxxxx.xxx.demo.entity.User" useGeneratedKeys="true" keyProperty="id">
        insert into user (name, age, email)
        values (#{name},#{age},#{email})
    </insert>
2.2.3 插入多条数据

配合foreach标签使用:

<insert id="insertUsers" parameterType="com.xxx.xxx.demo.entity.User">
        insert into user (name, age, email)
        values 
        <foreach collection="list" item="item" separator=",">
        (#{item.name},#{item.age},#{item.email})
        </foreach>

3. delete

3.1 标签属性

id唯一的标识符
parameterType传给此语句的参数如 int

3.2 应用示例

3.2.1 删除一条记录
    <delete id="deleteUser" parameterType="integer">
        delete from user where id = #{id}
    </delete>
3.2.2 删除多条数据(批量删除)
    <delete id="deleteUsers" parameterType="integer">
        delete from user
        where id in
        <foreach collection="array" item="id" open="(" close=")" separator=",">
            #{id}
        </foreach>
    </delete>

4. update

4.1 标签属性

id唯一的标识符
parameterType传给此语句的参数如 com.xxx.xxx.demo.entity.User

4.2 应用示例

    <update id="updateUser" parameterType="com.xxx.xxx.demo.entity.User">
        update user set name=#{name},age=#{age},email=#{email} where id=#{id}
    </update>

resultMap

主要作用是为了建立SQL查询结果字段与实体属性的映射关系信息。查询的结果集转换为java对象,方便进一步操作。

PS:与java对象对应的列不是数据库中表的列名,而是查询后结果集的列名。

<resultMap id="BaseResult" type="com.xxx.xxx.demo.entity.User">
属性描述
id当前命名空间中的一个唯一标识,用于标识一个结果映射。
type类的完全限定名, 或者一个类型别名(关于内置的类型别名,可以参考上面的表格)如: com.xxx.xxx.demo.entity.User。
autoMapping如果设置这个属性,MyBatis 将会为本结果映射开启或者关闭自动映射。 这个属性会覆盖全局的属性 autoMappingBehavior。默认值:未设置(unset)。
extends继承其他 resultMap 标签(通常 resultMap 标签都代表了一个实体类,在多表联查时候,如果都需要配置 resultMap 的话,子类的 resultMap 就可以继承父类的 resultMap,然后父类有的那一部分属性标签(id、result标签)就不用在重写了)

id 和 result 元素都将一个列的值映射到一个简单数据类型(String, int, double, Date 等)的属性或字段。

    <resultMap id="BaseResult" type="com.xxx.xxx.demo.entity.User">
        <id property="id" column="id" javaType="Integer"/>
        <result property="name" column="name" javaType="String"/>
        <result property="age" column="age" javaType="Integer"/>
        <result property="email" column="email" javaType="String"/>
    </resultMap>
property对应实体类的属性
column数据库中的列名,或者是列的别名
javaType对应java的数据类型,MyBatis 通常可以推断类型。如果要映射到的是 HashMap,需要明确地指定 javaType

association标签

association 标签:用于一对一、多对一场景使用

标签属性

属性描述
property配置实体类属性名
javaType指定封装结果的类型。当使用 select 属性时,无需指定关联的类型,结果会直接封装到调用的查询语句中
column配置数据库列名,搭配 select 属性使用,从第一条 SQL 中获取当前指定字段的内容,在将该内容传入 select 属性调用的 SQL 中
select使用另一个select查询封装的结果。当使用该属性时,无需配置实体类与数据库之间的映射关系

association需要我们告知MyBatis 如何加载关联。MyBatis 提供2种不同的方式加载关联:

嵌套 Select 查询通过执行另外一个 SQL 映射语句来加载期望的复杂类型
嵌套结果映射使用嵌套的结果映射来处理连接结果的重复子集
    /**
     * 通过id查询商品名记录
     * @param id
     * @return
     */
    String selectShopName(Integer id);
    /**
     * 查询符合条件的数据记录
     * @return
     */
    List<User> selectUser();
    <resultMap id="BaseResult" type="cjw.study.mybatis.demo.entity.User">
        <id property="id" column="id" javaType="Integer"/>
        <result property="name" column="name" javaType="String"/>
        <result property="age" column="age" javaType="Integer"/>
        <result property="email" column="email" javaType="String"/>
        <association property="shopname" column="id" javaType="string" select="selectShopName"/>
    </resultMap>

    <select id="selectShopName" parameterType="integer" resultMap="RecordResult">
        select shopname
        from record
        <where>
            <if test="id != '' and id != null">
                id = #{id}
            </if>
        </where>
    </select>
    @Test
    public void selectUser() { 
        userMapper.selectUser();
    }
JDBC Connection [HikariProxyConnection@1131673199 wrapping com.mysql.cj.jdbc.ConnectionImpl@399ca607] will not be managed by Spring
==>  Preparing: select id, name, age, email from user
==> Parameters: 
<==    Columns: id, name, age, email
<==        Row: 7, Jack, 20, test2@baomidou.com
====>  Preparing: select shopname from record WHERE id = ?
====> Parameters: 7(Integer)
<====    Columns: shopname
<====        Row: pc
<====      Total: 1
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 7(Long)
<====    Columns: id, shopname, num
<====        Row: 7, pc, 20
<====      Total: 1
<==        Row: 8, Tom, 28, test3@baomidou.com
====>  Preparing: select shopname from record WHERE id = ?
====> Parameters: 8(Integer)
<====    Columns: shopname
<====        Row: ipad
<====      Total: 1
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 8(Long)
<====    Columns: id, shopname, num
<====        Row: 8, ipad, 28
<====      Total: 1
<==        Row: 9, Sandy, 21, test4@baomidou.com
====>  Preparing: select shopname from record WHERE id = ?
====> Parameters: 9(Integer)
<====    Columns: shopname
<====        Row: car
<====      Total: 1
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 9(Long)
<====    Columns: id, shopname, num
<====        Row: 9, car, 21
<====      Total: 1
<==        Row: 10, Billie, 24, test5@baomidou.com
====>  Preparing: select shopname from record WHERE id = ?
====> Parameters: 10(Integer)
<====    Columns: shopname
<====        Row: shoe
<====      Total: 1
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 10(Long)
<====    Columns: id, shopname, num
<====        Row: 10, shoe, 24
<====      Total: 1
<==        Row: 13, zbd, 22, cjw.163
====>  Preparing: select shopname from record WHERE id = ?
====> Parameters: 13(Integer)
<====      Total: 0
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 13(Long)
<====      Total: 0
<==        Row: 14, cjw, 22, cjw.163
====>  Preparing: select shopname from record WHERE id = ?
====> Parameters: 14(Integer)
<====      Total: 0
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 14(Long)
<====      Total: 0
<==      Total: 6

collection标签

一对多,多对多是使用,即对应多条数据结果如list、map等时使用。

        <collection property="record" column="id" select="selectRecords" ofType="com.xxx.xxx.demo.entity.Record"/>

collection 标签属性:

属性描述
property实体类属性名
select使用另一个select查询封装的结果。当使用该属性时,便不需要在配置实体类与数据库之间的映射关系了
column为数据库中的列名,与select配合使用
ofType指定集合中的泛型信息 ofType = List中的T

比如select查询条件为id = #{id},则设置colunm = ‘id’。找到购买人与商品的关系,查询商品表中对应的购买人id。

    /**
     * 根据id查询对应的记录
     * @return
     */
    List<Record> selectRecords(Integer id);
        /**
     * 查询符合条件的数据记录
     * @return
     */
    List<User> selectUser();
    <resultMap id="BaseResult" type="com.xxx.xxx.demo.entity.User">
        <id property="id" column="id" javaType="Integer"/>
        <result property="name" column="name" javaType="String"/>
        <result property="age" column="age" javaType="Integer"/>
        <result property="email" column="email" javaType="String"/>
        <collection property="record" column="id" select="selectRecords" ofType="com.xxx.xxx.demo.entity.Record"/>
    </resultMap>

    <resultMap id="RecordResult" type="com.xxx.xxx.demo.entity.Record">
        <id property="id" column="id" javaType="Integer"/>
        <result property="shopname" column="name" javaType="String"/>
        <result property="num" column="age" javaType="Integer"/>
    </resultMap>

    <sql id="RecordCol">
        id, shopname, num
    </sql>
    
    <select id="selectRecords" resultMap="RecordResult">
        select <include refid="RecordCol"></include>
        from record
        <where>
            <if test="id != '' and id != null">
                id = #{id}
            </if>
        </where>
    </select>
    @Test
    public void selectUser() { 
        userMapper.selectUser();
    }
JDBC Connection [HikariProxyConnection@1141984159 wrapping com.mysql.cj.jdbc.ConnectionImpl@76bf1bb8] will not be managed by Spring
==>  Preparing: select id, name, age, email from user
==> Parameters: 
<==    Columns: id, name, age, email
<==        Row: 7, Jack, 20, test2@baomidou.com
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 7(Long)
<====    Columns: id, shopname, num
<====        Row: 7, pc, 20
<====      Total: 1
<==        Row: 8, Tom, 28, test3@baomidou.com
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 8(Long)
<====    Columns: id, shopname, num
<====        Row: 8, ipad, 28
<====      Total: 1
<==        Row: 9, Sandy, 21, test4@baomidou.com
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 9(Long)
<====    Columns: id, shopname, num
<====        Row: 9, car, 21
<====      Total: 1
<==        Row: 10, Billie, 24, test5@baomidou.com
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 10(Long)
<====    Columns: id, shopname, num
<====        Row: 10, shoe, 24
<====      Total: 1
<==        Row: 13, zbd, 22, cjw.163
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 13(Long)
<====      Total: 0
<==        Row: 14, cjw, 22, cjw.163
====>  Preparing: select id, shopname, num from record WHERE id = ?
====> Parameters: 14(Long)
<====      Total: 0
<==      Total: 6

foreach

foreach标签主要用于构建in条件,他可以在sql中对集合进行迭代。

collectioncollection属性的值有三个分别是list、array、map三种,分别对应的参数类型为:List、数组、map集合
item表示在迭代过程中每一个元素的别名
index表示在迭代过程中每次迭代到的位置(下标)
open前缀
close后缀
separator分隔符,表示迭代时每个元素之间以什么分隔

foreach 通常可以将之用到批量删除、添加等操作中。

    <insert id="insertUsers" parameterType="com.xxxx.xxx.demo.entity.User">
        insert into user (name, age, email)
        values <foreach collection="list" item="item" separator=",">
        (#{item.name},#{item.age},#{item.email})
    </foreach>

    <delete id="deleteUsers" parameterType="integer">
        delete from user
        where id in
        <foreach collection="array" item="id" open="(" close=")" separator=",">
            #{id}
        </foreach>
    </delete>

sql和include

sql用来定义可重用的 SQL 代码片段,以便在其它语句中使用。 参数可以静态地(在加载的时候)确定下来,并且可以在不同的 include 元素中定义不同的参数值。

include表示引用sql标签,作为sql一部分。

	<include refid="sqlvalues"></include>

sql常见的几种用法:

1. 静态写法
    <sql id="userCol">
        id, name, age, email
    </sql>
    
    <select id="selectUser" resultMap="BaseResult">
        select
        <include refid="userCol"></include>
        from user
    </select>
2. 动态加载写法
	<sql id="userColumns"> ${alias}.id,${alias}.username,${alias}.password </sql>
	
	<select id="selectUsers" resultType="map">
	  select
	    <include refid="userColumns"><property name="alias" value="t1"/></include>,
	    <include refid="userColumns"><property name="alias" value="t2"/></include>
	  from some_table t1
	    cross join some_table t2
	</select>
	
	<sql id="sometable">
	  ${prefix}Table
	</sql>
	<sql id="someinclude">
	  from
	    <include refid="${include_target}"/>
	</sql>
	
	<select id="select" resultType="map">
	  select
	    field1, field2, field3
	  <include refid="someinclude">
	    <property name="prefix" value="Some"/>
	    <property name="include_target" value="sometable"/>
	  </include>
	</select>

动态标签

主要搭配顶级标签使用,实现将映射的 SQL 语句动态化。
if、 where、trim、set、 foreach、choose、bind

if 标签

作用:动态拼接
类似 Java 中的 if 语句,符合判断条件的便执行指定内容,否则跳过判断。

/* 
@Param是MyBatis所提供的(org.apache.ibatis.annotations.Param),
作为实体层的注解,作用是用于传递参数,从而可以与SQL中的的字段名相对应
*/
	List<User> selectUsers(@Param("cjw") Integer id);

	<select id="selectUsers" parameterType="integer" resultType="com.xxx.xxx.demo.entity.User">
        select * from user where 1=1
        <if test="cjw > 10 and cjw != ''">
            id = #{cjw}
        </if>
    </select>

where 标签

where标签可以去除多余的 where,作为sql的条件语句。

当使用 if 标签进行动态 SQL 拼接时,如果 if 标签的判断条件不满足的话,便不拼接 if 标签中的内容,这便导致了 SQL 语句的 where 子句缺失,造成 SQL 错误。使用 where 标签便可以解决上述问题,使用 where 标签将 if 标签包裹起来,当 if 标签的判断条件不满足,动态 SQL 不拼接时,便不会向 SQL 语句中插入 where 子句,从而避免该错误。

因为有 where 就必须有查询条件,如果没有便会报错,所以加上 1=1条件。
在这里插入图片描述

    /**
     * 使用mybatis的where标签实现查询select数据
     * @param id
     * @return
     */
    List<User> selectUsersbyWhere(@Param("cjw") Integer id);
	<select id="selectUsersbyWhere" parameterType="integer" resultType="com.xxx.xxx.demo.entity.User">
        select * from user
        <where>
            <if test="cjw > 1 and (cjw != '' or cjw != null)">
                id = #{cjw}
            </if>
        </where>
    </select>
    @Test
    public void selectUsersbyWhere() {
        userMapper.selectUsersbyWhere(9);
    }
JDBC Connection [HikariProxyConnection@1201324747 wrapping com.mysql.cj.jdbc.ConnectionImpl@220c9a63] will not be managed by Spring
==>  Preparing: select * from user WHERE id = ?
==> Parameters: 9(Integer)
<==    Columns: id, name, age, email, creattime, updatetime
<==        Row: 9, Sandy, 21, test4@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==      Total: 1

set标签

用于动态包含需要更新的列,忽略其它不更新的列。该标签会动态地在行首插入 SET 关键字,并会删掉额外的逗号(逗号是使用if标签给列索引赋值时引入的)

     /**
     * 使用mybatis的set标签实现更新update数据
     * @param user
     */
	void updateUserbyUseSet(User user);
    <update id="updateUserbyUseSet" parameterType="com.xxx.xxx.demo.entity.User">
        update user
        <set>
            <if test="name !='' and name != null">name = #{name},</if>
            <if test="age !='' and age != null">age = #{age},</if>
            <if test="email !='' and email != null">email = #{email}</if>
        </set>
        where id = #{id}
    </update>
    @Test
    public void updateUserbyUseSet() {
        User user = new User();
        user.setId(14);
        user.setName("cjw");
        //这里我们不给他传age,看看set能不能实现动态更新数据
//        user.setAge(26);
        user.setEmail("cjw.163");
        userMapper.updateUserbyUseSet(user);
    }
JDBC Connection [HikariProxyConnection@1654228203 wrapping com.mysql.cj.jdbc.ConnectionImpl@7b1e5e55] will not be managed by Spring
==>  Preparing: update user SET name = ?, email = ? where id = ?
==> Parameters: cjw(String), cjw.163(String), 14(Integer)
<==    Updates: 1

age没传,也就是不更新,mybatis的set标签自动识别需要更新的数据,并去除所带的逗号。


trim标签

trim标签可替代where和set标签,也可以在特定业务场景实现一些功能。

	<trim prefix="where | set" prefixOverrides="AND | OR | ,">
	  ...
	</trim>
属性描述
prefix给sql语句拼接的前缀
suffix给sql语句拼接的后缀
prefixOverrides去除sql语句前面的关键字或者字符,该关键字或者字符
suffixOverrides去除sql语句后面的关键字或者字符,该关键字或者字符由suffixOverrides属性指定

trim实现where标签

    /**
     * 使用mybatis的trim标签实现where标签的功能进而实现查询select数据
     * @param id
     * @param name
     * @return
     */
    List<User> selectUsers(@Param("cjw") Integer id, String name);
    <trim prefix="where" prefixOverrides="and">
        <if test="cjw > 1 and (cjw != '' or cjw != null)">
            id = #{cjw}
        </if>
        <if test="name != null and name != ''">
            and name = #{name}
        </if>
    </trim>

PS:cjw是mapper层设置的@Param(“cjw”)有关

    @Test
    public void selectUsers() {
        userMapper.selectUsers(9, "");
    }
JDBC Connection [HikariProxyConnection@116155384 wrapping com.mysql.cj.jdbc.ConnectionImpl@66223d94] will not be managed by Spring
==>  Preparing: select * from user where id = ?
==> Parameters: 9(Integer)
<==    Columns: id, name, age, email, creattime, updatetime
<==        Row: 9, Sandy, 21, test4@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==      Total: 1

trim实现set标签

     /**
     * 使用mybatis的trim标签实现set标签的功能进而实现更新update数据
     * @param user
     */
    void updateUserbyUseTrim(User user);
    @Test
    public void updateUserbyUseTrim() {
        User user = new User();
        user.setId(13);
        user.setName("zbd");
//        user.setAge(26);
        user.setEmail("cjw.163");
        userMapper.updateUserbyUseTrim(user);
    }
JDBC Connection [HikariProxyConnection@116155384 wrapping com.mysql.cj.jdbc.ConnectionImpl@66223d94] will not be managed by Spring
==>  Preparing: update user set name = ?, email = ? where id = ?
==> Parameters: zbd(String), cjw.163(String), 13(Integer)
<==    Updates: 1

choose、when、otherwise标签

从多个条件中选择一个(即使多个符合也只执行一个)使用。针对这种情况,MyBatis 提供了 choose标签,类似 Java 的 switch 语句。

    /**
     * mybatis的choose标签实现条件查询select数据
     * @param user
     * @return
     */
    List<User> selectUserbyChoose(Userdto user);
    <select id="selectUserbyChoose"  parameterType="com.xxx.xxx.demo.entity.dto.Userdto" resultType="com.xxx.xxx.demo.entity.User">
        select * from user
        <where>
        <choose>
            <when test="age != '' and age != null">
                age <![CDATA[ <= ]]> #{age}
            </when>
            <when test="name != '' and name != null">
                and name like concat('%',#{name},'%')
            </when>
            <otherwise>
                and id <![CDATA[ <= ]]> #{id}
            </otherwise>
        </choose>
        </where>
    </select>
    @Test
    public void selectUserbyChoose() {
        Userdto user = new Userdto();
        user.setName("c");
        user.setAge(26);
        user.setId(10);
        userMapper.selectUserbyChoose(user);
    }
JDBC Connection [HikariProxyConnection@1713520020 wrapping com.mysql.cj.jdbc.ConnectionImpl@2bc7db89] will not be managed by Spring
==>  Preparing: select * from user WHERE age <= ?
==> Parameters: 26(Integer)
<==    Columns: id, name, age, email, creattime, updatetime
<==        Row: 7, Jack, 20, test2@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==        Row: 9, Sandy, 21, test4@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==        Row: 10, Billie, 24, test5@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==        Row: 13, zbd, 22, cjw.163, 2023-01-22 17:42:20, 2023-01-24 13:39:46
<==        Row: 14, cjw, 22, cjw.163, 2023-01-22 17:42:20, 2023-01-24 13:25:09
<==      Total: 5

注意:如果同时符合多个when标签,则穿透执行最后一个符合的when标签,when标签都不符合,则执行otherwise标签;
一般使用choose时,传值较多可采用dto传值的方式。

MyBatis标签实现like模糊查询

    /**
     * mybatis标签实现模糊查询select数据
     * @param name
     * @return
     */
    List<User> selectUserlike(String name);
    <select id="selectUserlike"  resultType="com.先xxx.xxx.demo.entity.User">
    select * from user
    <where>
        <if test="name != '' and name != null">
            name like concat('%',#{userName},'%')
        </if>
    </where>
    </select>
    @Test
    public void selectUserlike() {
        //查询当前数据库中name中包含c的记录
        userMapper.selectUserlike("c");
    }
JDBC Connection [HikariProxyConnection@1276991949 wrapping com.mysql.cj.jdbc.ConnectionImpl@76cf841] will not be managed by Spring
==>  Preparing: select * from user WHERE name like concat('%',?,'%')
==> Parameters: c(String)
<==    Columns: id, name, age, email, creattime, updatetime
<==        Row: 7, Jack, 20, test2@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==        Row: 14, cjw, 22, cjw.163, 2023-01-22 17:42:20, 2023-01-24 13:25:09
<==      Total: 2

MyBatis特殊字符转义

MyBatis在解析XML文件时会将5种特殊字符进行转义,分别是

&<>, “, ‘, 

当不希望语法被转义时就需要进行特殊处理时,使用

<![CDATA[ 特殊字符写这里边 ]]>
如:小于等于 <![CDATA[ <= ]]>

标签来包含特殊字符,也可以使用XML转义序列来表示特殊字符。

直接写 <= 会报错:

Cause: org.xml.sax.SAXParseException; lineNumber: 117; columnNumber: 22; 元素内容必须由格式正确的字符数据或标记组成。
    /**
     * MyBatis特殊字符转义查询年龄小于等于21的数据记录
     * @param age
     * @return
     */
    List<User> selectUserbyage(Integer age);
    <select id="selectUserbyage"  parameterType="integer" resultType="com.xxx.xxx.demo.entity.User">
        select * from user
        <where>
            <if test="age != '' and age != null">
                age <![CDATA[ <= ]]> #{age}
            </if>
        </where>
    </select>
    @Test
    public void selectUserbyage() {
        userMapper.selectUserbyage(21);
    }
JDBC Connection [HikariProxyConnection@1276991949 wrapping com.mysql.cj.jdbc.ConnectionImpl@76cf841] will not be managed by Spring
==>  Preparing: select * from user WHERE age <= ?
==> Parameters: 21(Integer)
<==    Columns: id, name, age, email, creattime, updatetime
<==        Row: 7, Jack, 20, test2@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==        Row: 9, Sandy, 21, test4@baomidou.com, 2023-01-22 15:36:45, 2023-01-22 15:36:45
<==      Total: 2

注意: 在CDATA内部的所有内容都会被解析器忽略,保持原貌。所以在Mybatis配置文件中,要尽量缩小 <![CDATA[ ]]>的作用范围,避免sql标签无法解析的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1343867.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

人机交互中信息数量与质量

在人机交互中&#xff0c;信息的数量和质量都是非常重要的因素。 信息的数量指的是交互过程中传递的信息的多少。信息的数量直接影响到交互的效率和效果&#xff0c;如果交互中传递的信息量太少&#xff0c;可能导致交互过程中的信息不足&#xff0c;用户无法得到想要的结果或者…

js实时监听input输入框值的变化

实习日记之通过调用common chemistry的api接口实现输入keyword查找cas号和mw。做了一个简单的html网页&#xff0c;用到了ajax技术。比较简单&#xff0c;适合刚入门的宝学习参考。代码如下&#xff1a; <!DOCTYPE html> <html lang"en"> <head>&l…

面试算法78:合并排序链表

题目 输入k个排序的链表&#xff0c;请将它们合并成一个排序的链表。 分析&#xff1a;利用最小堆选取值最小的节点 用k个指针分别指向这k个链表的头节点&#xff0c;每次从这k个节点中选取值最小的节点。然后将指向值最小的节点的指针向后移动一步&#xff0c;再比较k个指…

cleanmymac这个软件怎么样?值不值得下载

cleanmymac是我必装的mac端清理软件&#xff0c;界面简洁好看&#xff0c;完美适配mac系统&#xff0c;文件清理的速度、精度都比较优秀&#xff0c;还是比较不错的呢。cleanmymac作为一款第三方清洁应用程序&#xff0c;具有专业完整的清理功能&#xff0c;包括释放内存、一键…

Halcon阈值处理的几种分割方法threshold/auto_threshold/binary_threshold/dyn_threshold

Halcon阈值处理的几种分割方法 文章目录 Halcon阈值处理的几种分割方法1. 全局阈值2. 基于直方图的自动阈值分割方法3. 自动全局阈值分割方法4. 局部阈值分割方法5. var_threshold算子6 . char_threshold 算子7. dual_threshold算子 在场景中选择物体或特征是图像测量或识别的重…

FairyGUI-Cocos Creator官方Demo源码解读

博主在学习Cocos Creator的时候&#xff0c;发现了一款免费的UI编辑器FairyGUI。这款编辑器的能力十分强大&#xff0c;但是网上的学习资源比较少&#xff0c;坑比较多&#xff0c;主要学习方式就是阅读官方文档和练习官方Demo。这里博主进行官方Demo的解读。 从gitee上克隆项目…

《PCI Express体系结构导读》随记 —— 第I篇 第1章 PCI总线的基本知识(15)

接前一篇文章&#xff1a;《PCI Express体系结构导读》随记 —— 第I篇 第1章 PCI总线的基本知识&#xff08;14&#xff09; 1.3 PCI总线的存储器读写总线事务 1.3.4 PCI读写主存储器 前文已提到&#xff0c;由于本节内容较长&#xff0c;因此将后一部分内容放在本文中。 为…

基于Python、Keras和OpenCV的实时人脸活体检测

你在互联网上找到的大多数人脸识别算法和研究论文都遭受照片攻击。这些方法在检测和识别来自网络摄像头的图像、视频和视频流中的人脸方面非常有效。然而&#xff0c;他们无法区分现实生活中的面孔和照片上的面孔。这种无法识别人脸的现象是由于这些算法在二维帧上工作。 现在…

【JS笔记】JavaScript语法 《基础+重点》 知识内容,快速上手(二)

数组 什么是数组&#xff1f; 字面理解就是 数字的组合 其实不太准确&#xff0c;准确的来说数组是一个 数据的集合 也就是我们把一些数据放在一个盒子里面&#xff0c;按照顺序排好 [1, 2, 3, hello, true, false]这个东西就是一个数组&#xff0c;存储着一些数据的集合 …

深度学习框架Keras与Pytorch对比

对于许多科学家、工程师和开发人员来说&#xff0c;TensorFlow是他们的第一个深度学习框架。TensorFlow 1.0于2017年2月发布&#xff0c;可以说&#xff0c;它对用户不太友好。 在过去的几年里&#xff0c;两个主要的深度学习库Keras和Pytorch获得了大量关注&#xff0c;主要是…

【Java EE初阶五】wait及notify关键字

1. wait和notify的概念 所谓的wait和notify其实就是等待、通知机制&#xff1b;该机制的作用域join类似&#xff1b;由于多个线程之间是随机调度的&#xff0c;引入wait和notify就是为了能够从应用层面上&#xff0c;干预到多个不同线程代码的执行顺序&#xff0c;此处的干预&a…

C# WPF上位机开发(Web API联调)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 很多时候&#xff0c;客户需要开发的不仅仅是一个上位机系统&#xff0c;它还有其他很多配套的系统或设备&#xff0c;比如物流小车、立库、数字孪…

web前端开发html/css求职简介/个人简介小白网页设计

效果图展示&#xff1a; html界面展示&#xff1a; html/css代码&#xff1a; <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns"http://www.w3.…

Java IDEA JUnit 单元测试

JUnit是一个开源的 Java 单元测试框架&#xff0c;它使得组织和运行测试代码变得非常简单&#xff0c;利用JUnit可以轻松地编写和执行单元测试&#xff0c;并且可以清楚地看到哪些测试成功&#xff0c;哪些失败 JUnit 还提供了生成测试报告的功能&#xff0c;报告不仅包含测试…

VSCode + vite + vue3断点调试配置

没想到这个配置我搞了一上午&#xff0c;网上很多的配置方案都没有效果。总算搞定了&#xff0c;特此记录一下。 首先需要在.vscode文件夹下面创建launch.json配置文件。然后输入如下配置&#xff1a; {// 使用 IntelliSense 了解相关属性。 // 悬停以查看现有属性的描述。//…

Java Swing GUI实现ATM机(涉及网络编程聊天功能)

一、序言 1.首先这是本人大二时期的编程&#xff0c;涉及到网络编程的聊天功能&#xff0c;大佬勿喷。 二、且看展示图片 1.首先启动服务端&#xff08;启动Fuwuduan代码&#xff09;&#xff0c;也就是客服聊天窗口 提供给用户申请银行卡号&#xff0c;客服界面如下&#x…

复试 || 就业day01(2023.12.29)项目一

文章目录 前言正规方程二元一次示例正规方程 : w ( X T X ) − 1 X T y w (X^TX)^{-1}X^Ty w(XTX)−1XTy三元一次方程示例八元一次方程示例sklearn带截距的线性方程总结 前言 &#x1f4ab;你好&#xff0c;我是辰chen&#xff0c;本文旨在准备考研复试或就业 &#x1f4ab;…

unity exe程序置顶和全屏

1.置顶和无边框 设置显示位置和范围 using System; using System.Runtime.InteropServices; using UnityEngine; public class WindowMod : MonoBehaviour {public enum appStyle{FullScreen,WindowedFullScreen,Windowed,WindowedWithoutBorder}public enum zDepth{Normal…

手写Spring与基本原理--简易版

文章目录 手写Spring与基本原理解析简介写一个简单的Bean加载容器定义一个抽象所有类的BeanDefinition定义一个工厂存储所有的类测试 实现Bean的注册定义和获取基于Cglib实现含构造函数的类实例化策略Bean对象注入属性和依赖Bean的功能Spring.xml解析和注册Bean对象实现应用上下…

STM32CubeMX学习(二) USB CDC 双向通信

STM32CubeMX学习&#xff08;二&#xff09; USB CDC 双向通信 简介CubeMX新建工程&#xff08;串口LED&#xff09;测试串口和LED串口接收测试USB CDC通信 简介 利用正点原子F407探索者开发板&#xff0c;测试基于USB CDC的双向数据通信。 CubeMX新建工程&#xff08;串口LE…