Mysql的instr()函数用法及说明

 更新时间:2026年01月04日 09:12:02   作者:TTc_  
mysql中instr()函数用于返回子字符串在字符串中第一次出现的位置,可以实现模糊查询,类似于like用法

Mysql的instr()函数用法

mysql的内置函数instr(filed,str)

作用是返回str子字符串在filed字符串的第一次出现的位置。

当instr(filed,str)=0时

表示子符串str不存在于字符串filed中,因此可以用来实现mysql中的模糊查询,与like用法类似。

如下:

 // 1、instr()函数,#{name}为参数
select id,name from test where instr(name,#{name})>0 

上述写法等同于下面
// 2、like
select id,name from test where name like concat('%',#{name},'%')

 instr(filed,str) > 0 ⇒ file like '%str%'
instr(filed,str) = 1 ⇒ file like  'str%'
instr(filed,str) = 0 ⇒ file not like  '%str%'

下面是一段mapper.xml的部分示例代码 

<select id="selectUserListByConds" parameterType="java.lang.String" resultMap="BaseResultMap">
        select
        a.userid,
        a.username,
        a.account,
        a.password,
        a.mobile,
        a.description,
        a.delete_flag,
        a.enabled,
        a.email,
        a.address,
        a.is_online,
        a.created_time,
        a.updated_time,
        a.created_user,
        a.updated_user,
        a.org_code,
        s.org_name,
        a.limit_ip,
        a.expiry_date,
        a.last_login_time,
        a.last_login_ip,
        a.account_type,
        a.account_type_name,
        a.tenant_id
        from s_user a
        left join s_department s on s.org_code=a.org_code and s.tenant_id=a.tenant_id
        where 1=1
        <if test="showdelete==null">
            and a.delete_flag!=1
        </if>
        <if test="account!=null and account!=''">
            and instr(a.account,#{account})>0
        </if>
        <if test ="username!=null and username!=''">
            and instr(a.username,#{username})>0
        </if>

        <if test="roleIds!=null and roleIds!=''">
            and exists(select * from s_user_role where user_id=a.userid and role_id = #{roleIds})
        </if>

        <if test="orgCode!=null and orgCode!=''">
            and instr(a.org_code,#{orgCode})>0
        </if>
        <if test="tenantId!=null and tenantId!=''">
            and a.tenant_id=#{tenantId}
        </if>
        order by a.created_time DESC
    </select>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • SQL语句之如何用JOIN连接多个表

    SQL语句之如何用JOIN连接多个表

    这篇文章主要介绍了SQL语句之如何用JOIN连接多个表,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • kali虚拟机mysql修改绑定ip的问题

    kali虚拟机mysql修改绑定ip的问题

    这篇文章主要介绍了kali虚拟机mysql修改绑定ip,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • MySQL并行DDL的实现方法

    MySQL并行DDL的实现方法

    本文详细介绍了MySQL8.0.27并行DDL的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-10-10
  • MySQL忽略表名大小写的2种方法实现

    MySQL忽略表名大小写的2种方法实现

    在 MySQL 中,默认情况下表名是大小写敏感的,本文主要介绍了MySQL忽略表名大小写的2种方法实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • MySQL之锁类型解读

    MySQL之锁类型解读

    MySQL锁类型包括读锁(共享锁)和写锁(排他锁),并介绍了意向锁、自增锁、元数据锁、行级锁和间隙锁等概念,悲观锁和乐观锁是两种不同的锁设计思想,悲观锁在每次操作前加锁,适用于并发冲突多的场景;乐观锁在更新时判断数据是否被修改
    2025-02-02
  • SQL实现LeetCode(175.联合两表)

    SQL实现LeetCode(175.联合两表)

    这篇文章主要介绍了SQL实现LeetCode(175.联合两表),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • mysql WITH RECURSIVE语法的具体使用

    mysql WITH RECURSIVE语法的具体使用

    WITH RECURSIVE是一个用于创建递归查询的语句,本文主要介绍了mysql WITH RECURSIVE语法的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • mysql sql字符串截取函数详解

    mysql sql字符串截取函数详解

    mysql支持的字符串截取函数主要有 left()、right()、substring()、substring_index(),下面是这些函数的详细使用方法
    2022-10-10
  • MySQL 常用引擎总结分享

    MySQL 常用引擎总结分享

    这篇文章主要介绍了MySQL 常用引擎总结分享,MySQL有很多存储引擎,所谓的存储引擎是指用于存储、处理和保护数据的核心服务,更多常用引擎分享,需要的小伙伴可以参考下面文章内容
    2022-06-06
  • Docker MySQL启动问题及解决过程

    Docker MySQL启动问题及解决过程

    Docker MySQL启动失败多因权限限制导致无法写入/tmp和/var/run/mysqld目录,推荐使用tmpfs挂载卷解决,同时需检查SELinux和数据目录权限,避免使用特权模式
    2025-09-09

最新评论