首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 模糊查询实现不区分大小写

需求说明: 有时候,我们需要从数据库中模糊查询,但是字母有大写也有小写。 1:在执行查询的时候,需要忽略大小写。 2:以输入字母开头进行查询的 创建表: ? 请点击此处输入图片描述 ?...请点击此处输入图片描述 假设用户现在要查询name是D或者d开头的数据怎么? 解决需求一,忽略大小写的。可以先查询大写,在查询小写。然后union 下 先查询出所有小写字母d开头的: ?...在查询出所有大写字母D开头的 ? 请点击此处输入图片描述 ? 使用union 进行连接。 ? 请点击此处输入图片描述 ? 当然这样也可以得到最终的结果。但是这样执行从效率上来说很不好。...解决需求二:以输入字母开头进行模糊查询 在上面语句中我们可以看到使用的是‘d%’或者是'D%'这样看上去好像有点不是很好。...接下来查看优化后的sql语句: SELECT id,NAME,name_all AS name_all   FROM  base_new_info_abbreviation    WHERE 1=1 AND

5.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql中select子查(select中的select子查询)询探索

    ------+------+ | 4 | 运营 | 杭州 | +--------+-------+------+ 1 row in set (0.08 sec) select 中的子查询 mysql...在执行子查询的时候,子查询中的e.deptno是来自于主查询中的emp表,是通过where条件过滤出来的,所以子查询中的e.deptno是一个固定的值。...到这里对于select子查询的执行顺序更迷惑了,不知道DEPENDENT SUBQUERY到底时怎么执行的,到底有没有生产临时表,但是可以明确这种子查询的效率不如join好 注意事项 在select子查询中...= 3; Subquery returns more than 1 row 子查询中的limit mysql> select d.dname,(select e.ename from emp e where...,主查询只需要一行,例如查询部门名称,所在地,和部门中id最大的一个人的名称 mysql> select d.dname,(select e.ename from emp e where e.deptno

    11200

    细说MySQL区分字母大小写

    在Linux系统上使用MySQL,MySQL是区分字母大小写的,例如建A表时表名是大写的A,修改A表时脚本里写的a,就会报错表a不存在。...在MySQL中,数据库对应数据目录中的目录,数据库中的每个表至少对应数据库目录中的一个文件或多个文件,所以,是否区分大小写是其所在的操作系统决定的。...在大多数基于Unix的系统中,MySQL是区分大小写的;而在Windows系统中,MySQL是不区分大小写的。...0表示使用指定的大小写字母在硬盘上保存表名和数据库名,并且区分字母大小写;1表示表名在硬盘上以小写保存,MySQL将所有表名转换为小写在存储和查找表上,不区分字母大小写;2表示表名和数据库名在硬盘上使用指定的大小写字母进行保存...如果想在Linux系统中修改lower_case_table_names的值,让其不区分字母大小写,Google出来的操作步骤大部分都是下面这种: 1.以root登录系统 2.cd /etc/mysql

    2.7K50

    MySQL区分大小写参数配置

    一、背景简述在云环境中,我们经常会遇到以下几个场景:1、MySQL5.7及以下修改区分大小写参数,导致大写表无法识别,影响业务对表/库的操作,间接导致备份失败;2、MySQL8.0修改区分大小写参数,导致...lower_case_table_names 值◆ 0  表名存储为给定的大小;比较是区分大小写的◆ 1  表名存储在磁盘是小写的;比较的时候是不区分大小写◆ 2  表名存储为给定的大小写;比较的时候是小写的注...异常分析让我们先来回答背景中的第一个问题,假设MySQL默认是区分大小写的,即小写的表a与大写的表A是完全不同的两个表。...进一步思考,不难发现,既然表a与表A的识别元数据不同,如果我们把区分大小写改成不区分大小写,会出现什么问题呢?没错,表a可以被MySQL识别,当MySQL读取表A的时候,会报错表不存在!!!...我想你肯定想到了,既然在区分大小写的模式下,a表与A表元数据识别是不同的,那么我把她修改成不区分大小写模式下,MySQL能够识别的不就行了?答案是:对的。

    9100

    MySQL如何设置不区分大小写

    MySQL如何设置不区分大小写 摘要 本文将深入探讨MySQL数据库中如何设置不区分大小写,并针对不同操作系统以及使用Navicat等工具的情况进行详细介绍。...通过了解如何设置不区分大小写,您可以更好地管理MySQL数据库,提高工作效率。 引言 在MySQL数据库中,大小写敏感性可能会影响到数据库的操作和管理。...在Windows中设置MySQL不区分大小写 在Windows操作系统中,默认情况下MySQL是不区分大小写的。但是,您可以通过修改MySQL的配置文件来更改这一行为。...sudo service mysql restart 或者 sudo systemctl restart mysql 在Linux中设置MySQL不区分大小写 在Linux系统中,MySQL默认是区分大小写的...小结 通过本文的介绍,我们了解了在Windows和Linux系统中如何设置MySQL不区分大小写,以及在Navicat等工具中的设置方法。

    25310

    Elasticsearch 如何实现查询聚合不区分大小写?

    1、实战问题 最近社区里有多个关于区分大小写的问题: 问题1:ES查询和聚合怎么设置不区分大小写呢? 问题2:ES7.6 如何实现模糊查询不区分大小写?...这或许是铭毅天下公众号的使命所在。 这个问题不复杂,所以本文会言简意赅,直击要害! 2、问题拆解 2.1 拆解一:如果默认分词方式,能区分大小写的吗?...是的,默认分词器是Standard 标准分词器,是不区分大小写的。...keyword 类型属于精准匹配,也就是说:单纯的keyword 类型没法实现大小写区分。 进一步小结: 我们上面的组合multi-field 方式,并没有解决检索和聚合区分大小写的问题?...刚才提及的进一步处理,反映到我们的解决方案上:就是可以做小写 lowercase 转换。 由于写入阶段和检索阶段:normalizer 都生效,所以就实现了我们想要的不区分大小写的结果。

    7.9K20

    设置MySQL数据库不区分大小写

    这个时候怎么办呢,显然改程序是不行的,时间上也不允许,所以只能设置MySQL数据库不区分大小写了,大家看以下步骤: 1、查询MySQL是否设置了区分大小写 show variables like "%case...其中lower_case_table_names代表了:0是区分大小写; 1是不区分大小写。显然我这个MySQL是区分大小写的。...2、解决方法 一 Ubuntu环境下: vim /etc/mysql/my.cnf 在这个文件中的[mysqld]的后面加lower_case_table_names=1 ?...拓展知识 MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的: 1、数据库名与表名是严格区分大小写的; 2、表的别名是严格区分大小写的; 3、列名与列的别名在所有的情况下均是忽略大小写的...; 4、变量名也是严格区分大小写的; MySQL在Windows下都不区分大小写。

    16.6K21

    MYSQL 从正则查询 扯到 查询中的大小写敏感的解决方法

    MYSQL 中的查询给人的观念大多是简单的,不复杂的,将复杂的事情都交给程序来做,数据库就是一个容器的概念或一个固化的观念。...其实随着MYSQL8 的到来,越来越多以前不能在SQL 端执行的语句,可以在MYSQL中执行,例如CTE ,窗口函数,等等,而查询中有的是使用like来查,而LIKE 的查询中有一些查询比较复杂,而正则表达式在...(如果你最近看了MYSQL 8.017 的那个版本的变化) 怎么能进行这样的查询,我们来看下面几个例子 1 如我们要查询 employees 表中 first_name 是 G 开头的名字的人有多少...,结果可想而知,会不区分大小写来将所有的Georgi gEORGI 都查出来 其实在早期的MYSQL 的版本 5.X 之前 正则表达式是可以区分大小写的 但现在的版本是不能区分的。...如何让目前的正则表达式能区分出大小写 我们可以在 你要查询的字段名前加上 binary 然后匹配正常的正则,你就可以查到你要查的数据了,请见上图 那么问题来了,题目说扯到大小写敏感,你上面那个能算是扯到大小写敏感吗

    2.7K10

    MYSQL基本操作-select 查询语句

    目录 MYSQL基本操作-select 查询语句 MYSQL基本操作-select 查询语句 针对数据表里面的每条记录,select查询语句叫做数据查询语言(DQL) select的语法格式 SELECT...查询表的所有字段 select * from book; 通配符,代表查询所有字段 使用 * 时,只能按照数据表中字段的顺序进行排列,不能自定义字段排序 建议:不知道所需查询的列名称时,才用 *...,否则获取不需要的列数据会降低查询和所使用应用程序的效率 查询表的部分字段 select bookid, bookname from book; 可以指定表的所有字段,然后更改字段顺序, 这种查询所有字段的写法比较灵活...like “%%” 如果需要区分大小写,需要加入 binary 关键字,如: like binary “TEST_”; select * from book where bookname like 'java...,只有第一个排序字段有相同的值,才会对第二个字段进行排序,以此类推 如果第一个排序字段的所有数据都是唯一的,将不会对第二个排序字段进行排序,以此类推 按字母(A-Z进行排序,大小写不敏感) 限制条数limit

    2.8K20

    MySQL中的大小写敏感

    ,我们暂时跳过,看看第二个参数lower_case_table_names,它的含义 0:区分大小写,1:不区分大小写 。...MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:    1、数据库名与表名是严格区分大小写的;    2、表的别名是严格区分大小写的;    3、列名与列的别名在所有的情况下均是忽略大小写的...;    4、变量名也是严格区分大小写的; 而Windows下的MySQL却是大小写不敏感的,所有表名和数据库名都会变成小写。...是不区分大小写的。...这个参数只能够保证登录用户密码的大小写敏感,其他还是和原来一样,12c中这个参数变了味儿,在新版本中已经过期, 在设置的时候务必需要保证sqlnet.ora中的设置需要兼容,文件中的参数SQLNET.ALLOWED_LOGON_VERSION_SERVER

    2.6K60
    领券