首页 > 数据库 >mysql 大小写问题和非严格模式

mysql 大小写问题和非严格模式

时间:2023-11-06 11:33:49浏览次数:42  
标签:name 严格 大小写 emp mysql tb id

mysql 大小写问题

mysql select 语句,我们输入不管大小写都能查询到数据,例如:输入 aaa 或者 aaA 、AAA 都能查询同样的结果,说明查询条件对大小写不敏感。

解决方案一:

于是怀疑Mysql的问题。做个实验:直接使用客户端用sql查询数据库。 发现的确是大小不敏感 。

# DDL
CREATE TABLE `tb_emp` (
`id` int(11) NOT NULL,
`name` varchar(25) DEFAULT NULL,
`deptId` int(11) DEFAULT NULL,
`salary` float DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

# 数据初始化
INSERT INTO tb_emp (id, name, deptId, salary) VALUES(1, 'mark', 1, 3200.0);
INSERT INTO tb_emp (id, name, deptId, salary) VALUES(2, 'jack', 2, 5800.0);

执行查询

SELECT id, name, deptId, salary FROM tb_emp where name = 'jAck';

mysql 大小写问题和非严格模式_mysql

通过查询资料发现需要设置collate(校对) 。 collate规则:

*_bin: 表示的是binary case sensitive collation,也就是说是区分大小写的  
*_cs: case sensitive collation,区分大小写  
*_ci: case insensitive collation,不区分大小写

参考:dev.mysql.com/doc/refman/…

  1. 可以将查询条件用binary()括起来。  比如:
SELECT id, name, deptId, salary from tb_emp where binary(name) ='Jack';
  1. 可以修改该字段的collation 为 binary

比如:

ALTER TABLE tb_emp MODIFY COLUMN name varchar(50) BINARY CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL;

解决方案二:

mysql查询默认是不区分大小写的 如:

SELECT id, name, deptId, salary FROM test.tb_emp where name = 'jack';
SELECT id, name, deptId, salary FROM test.tb_emp where name = 'Jack';

得到的结果是一样的,如果我们需要进行区分的话可以按照如下方法来做:

第一种方法:

要让mysql查询区分大小写,可以:

SELECT id, name, deptId, salary from tb_emp where binary(name) ='jAck';

mysql 大小写问题和非严格模式_sql_02

第二种方法:

在建表时时候加以标识

create table tb_emp( name varchar(50) binary )

原理:

对于CHAR、VARCHAR和TEXT类型,BINARY属性可以为列分配该列字符集的 校对规则。BINARY属性是指定列字符集的二元校对规则的简写。排序和比较基于数值字符值。因此也就自然区分了大小写。

以上通过两种方案解决了MySql查询不区分大小写的问题,希望对大家有所帮助,更多有mysql数据查询问题,请登录本站学习

mysql ignore 问题

如果我们 insert 语句中带 ignore 那么 sql 将以非严格模式执行。

举个例子:

#DDL
CREATE TABLE `tb_record_t1` (
`id` int(11) NOT NULL,
`f1` varchar(25) DEFAULT '' NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

#INSERT
INSERT INTO tb_record_t1 (id, f1) VALUE(1, null);

如果 f1 字段为非空,那么执行 INSERT INTO 将直接报错

mysql 大小写问题和非严格模式_Java_03

增加 ignore 关键字

INSERT IGNORE INTO tb_record_t1 (id, f1) VALUES(1, null);

mysql 大小写问题和非严格模式_mysql_04

不会报错,且执行成功,数据库存的 f1 字段是默认值

参考:dev.mysql.com/doc/refman/…

mysql 大小写问题和非严格模式_Java_05

标签:name,严格,大小写,emp,mysql,tb,id
From: https://blog.51cto.com/u_11720620/8202974

相关文章

  • mysql insert的特殊用法
    1.正常的insert语句:插入一条数据如下:INSERTINTO`testdb`.`tb_user`(`id`,`userName`)VALUES(3,'张飞');  2.insert+ignore语句:当需要插入的语句发生主键冲突时可以使用ignore关键词,避免语句的冲突与报错 修改语句后可以成功执行: 3.insertreplace:使用REPLA......
  • 常见面试题-MySQL专栏(三)MVCC、BufferPool
    typora-copy-images-to:imgs了解MVCC吗?答:MVCC(Multi-VersionConcurrencyControl)是用来保证MySQL的事务隔离性的,对一行数据的读和写两个操作默认是不会通过加锁互斥来保证隔离性,避免了频繁加锁互斥,而在串行化隔离级别为了保证较高的隔离性是通过将所有操作加锁互斥来实现的。......
  • Docker-compose 运行MySQL 连接不上
    Docker-compose运行MySQL连接不上......
  • 【MySQL】MVCC机制、ReadView数据结构、匹配规则详解
    (目录)MySQLMVCC机制1.隔离级别在MySQLInnoDB存储引擎下,RC、RR基于MVCC(多版本并发控制)进行并发事务控制MVCC是**基于”数据版本”**对并发事务进行访问2.场景分析UNDO_LOG不是会被删除吗?中间数据万一被删了版本链不就断了?UNDO_LOG版本链不是立即删除,MySQL确保版......
  • MySQL教程:缓冲池Buffer Pool详解
    用于存储数据库的数据页和索引页查看缓冲池的大小showvariableslike'innodb_buffer_pool_size';查看缓冲池的使用情况showengineinnodbstatus;分析缓冲池命中率showstatuslike'innodb_buffer_pool_hit_rate';缓冲池满了LRU内存淘汰策略最近最少使用写回策略......
  • MySQL教程:如何更改mysql root密码
    要更改MySQL的root密码,你可以按照以下步骤进行操作:打开命令行终端或MySQL客户端工具。使用root用户登录到MySQL服务器。如果MySQL服务器已经在本地运行,并且你已经安装了MySQL客户端,则可以在终端中执行以下命令:mysql-uroot-p```系统将提示你输入密码。如果你之前没有设置过密......
  • mysql教程:更改数据页的大小(innodb_page_size)
    修改注意:更改innodb_page_size参数后,需要重新编译mysql的源码才能生效。在MySQL中,更改数据页的大小涉及到重新创建数据库的过程,因为数据页大小是在数据库创建时确定的,并且不能直接更改。以下是一般的步骤:备份数据库:在进行任何结构更改之前,强烈建议备份数据库以防止数据丢失。停止My......
  • mysql教程:binlog日志和数据备份
    DMLDDL数据恢复、主从复制数据备份:全量备份、增量备份数据恢复的步骤:备份数据库–还原数据文件–应用binlog–验证数据mysqlbinlog工具、将备份后的修改操作应用到数据库,将数据库恢复到最新的状态数据库的完整性、一致性binlog和数据备份数据备份是将数据库的数据文件复制到另......
  • Java+Jsp+MySQL高校选课系统设计与实现(附源码下载地址)
    @目录01源码下载02系统概述03开发工具及技术选型04运行环境05用户分析06功能分析07数据库设计08项目工程结构及说明09部分功能展示及源码9.1管理员端--首页9.2管理员端--专业管理9.3管理员--课程管理9.4管理员端--统计信息9.5普通用户端--基本信息9.6普通用户端--......
  • MySQL日期时间操作函数(全的)-九五小庞
    一、MySQL常用日期函数1.1、获取时间#获取当前日期时间selectNOW();#2021-04-0209:25:29#获取当前日期SELECTCURDATE();#2021-04-02#获取当前时间SELECTCURTIME();#09:26:10#对于时间2021-04-0209:25:29,分别获取其年、月、日、时、分、秒SELECTEXTRAC......