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

修改MySQL varchar类型字段的排序规则

记录一个在工作中遇到的问题,也不算是问题,为的是找一种简便的方法批量修改数据表字段的排序规则,在MySQL中叫collation,常常和编码CHARACTER一起出现的。...collation有三种级别,分辨是数据库级别,数据表级别和字段级别。...level https://confluence.atlassian.com/display/CONFKB/How+to+Fix+the+Collation+and+Character+Set+of+a+MySQL...但是我遇到的场景是数据表级别已经是utf8_unicode_ci,而字段级别是utf8_general_ci,(这里我们关心的字段类型是varchar)。...由于需要修改的字段太多了,手工修改肯定是费时费力的。自然也想到了用脚本的方式批量修改,但是发现这种通过查找MySQL信息表、过滤、拼接生成批量修改的语句太好用了,而且还能做到针对varchar类型。

4.6K30

MySQL online DDL 更改Varchar字段长度

mysql 在DDL 权威指南 5.6 官方文档 :verision :https://dev.mysql.com/doc/refman/5.6/en/innodb-online-ddl-operations.html...5.7 官方文档 : https://dev.mysql.com/doc/refman/5.7/en/innodb-online-ddl-operations.html 对比 对比过后我们可知...在5.6 里面执行DDL 根本没有单独操作Varchar这个字段类型。...注意 一个的字节长度VARCHAR列是依赖于字符集的字节长度 。 减少VARCHAR使用就地尺寸ALTER TABLE不被支持。减小VARCHAR 大小需要表副本(ALGORITHM=COPY)。...总结 在数据量很大的时候,varchar通过Online DDL做到快速进行更改字段长度。但是前提条件就是不会进行锁表和copy数据的过程。 这个前提条件就是数据库的支持5.7及5.7以上。

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

MySQL中使用VARCHAR字段进行日期筛选

在这篇文章中,我将为你解析如何在MySQL数据库中,对VARCHAR类型的日期字段进行筛选。这是一个在数据库设计中经常遇到的问题,尤其是当日期被保存为字符串格式时。...你是否也在搜索“MySQL VARCHAR日期筛选”、“如何在MySQL中筛选字符串日期”等关键词?不用再找了,这里有你想要的答案! 引言 在数据库设计中,选择合适的字段类型非常重要。...正确筛选VARCHAR日期字段的方法 ️ 为了正确筛选VARCHAR日期字段,我们可以使用MySQL的 STR_TO_DATE 函数: -- 考虑日期和时间 SELECT * FROM your_table_name...总结 虽然使用VARCHAR字段来存储日期和时间提供了灵活性,但它也带来了筛选数据的挑战。幸运的是,通过使用MySQL的内置函数,我们可以有效地解决这个问题。...希望这篇文章帮助你解决了在MySQL中筛选VARCHAR日期字段的问题! 参考资料 MySQL官方文档 - STR_TO_DATE函数: 链接 日期和时间的存储选择: 链接

11610

MySQL · 最佳实践 · 如何索引JSON字段

原文地址: http://mysql.taobao.org/monthly/2017/12/09/ MySQL · 最佳实践 · 如何索引JSON字段 概述 MySQL从5.7.8起开始支持JSON字段...但MySQL并没有提供对JSON对象中的字段进行索引的功能,至少没有直接对其字段进行索引的方法。本文将介绍利用MySQL 5.7中的虚拟字段的功能来对JSON对象中的字段进行索引。...MySQL只是在数据字典里保存该字段元数据,并没有真正的存储该字段的值。这样表的大小并没有增加。我们可以利用索引把这个字段上的值进行物理存储。...在虚拟字段上加索引 再添加索引之前,让我们先看下面查询的执行计划 EXPLAIN SELECT * FROM `players` WHERE `names_virtual` = "Sally"\G  ...小结 本文介绍了如何在MySQL 5.7中保存JSON文档。为了高效的检索JSON中内容,我们可以利用5.7的虚拟字段来对JSON的不同的KEY来建索引。极大的提高检索的速度。

3.3K20

小白学习MySQL - varchar类型字段为什么经常定义成255?

很多时候我们看到一些表字符串类型的字段定义为varchar(255),开始以为varchar只能定义为255这个长度值,其实不然。...官方文档所说,varchar有效的最大长度取决于行的容量,以及用的字符集,整行的所有列的定义长度不能超过65535字节(bytes),text、blob等大字段类型除外, P.S. https://dev.mysql.com.../doc/refman/5.7/en/char.html 《小白学习MySQL - 变通创建索引的案例一则》提到了, InnoDB,如果需要建索引,就不能超过767bytes,utf8编码,255*3...一般情况下,我们用的是InnoDB引擎,utf8则是常用字符集,因此varchar类型字段定义为255比较合适。...但实际上,varchar(255)并不是最优的字符定义长度,究竟定成多少,还是要根据实际需求来决定,例如这个字段我就不需要创建索引,定义超过255,是可以的,只能说255是常规情况下较少出错的一个值。

93320

小白学习MySQL - varchar类型字段为什么经常定义成255?

很多时候我们看到一些表字符串类型的字段定义为varchar(255),开始以为varchar只能定义为255这个长度值,其实不然。...官方文档所说,varchar有效的最大长度取决于行的容量,以及用的字符集,整行的所有列的定义长度不能超过65535字节(bytes),text、blob等大字段类型除外, P.S. https://dev.mysql.com...一般情况下,我们用的是InnoDB引擎,utf8则是常用字符集,因此varchar类型字段定义为255比较合适。...但实际上,varchar(255)并不是最优的字符定义长度,究竟定成多少,还是要根据实际需求来决定,例如这个字段我就不需要创建索引,定义超过255,是可以的,只能说255是常规情况下较少出错的一个值。...《小白学习MySQL - 索引键长度限制的问题》 《小白学习MySQL - MySQL会不会受到“高水位”的影响?》

2.8K10

MySQL:The CHAR and VARCHAR Types

CHAR 和 VARCHAR 声明时格式为 CHAR(num) 和 VARCHAR(num),这里的 num 表示的是你想存储的最大字符数。注意是字符数,而不是字节数。...即 VARCHAR 仅使用必要空间,一般情况下,它比 CHAR 要更节省空间。 二、存储区别 VARCHAR 会额外使用1到2个字节来记录字符串的长度。...示例如下(mysql版本5.7,后同): CREATE TABLE t1 (c1 CHAR(10)); INSERT INTO t1 (c1) VALUES('xy'); set sql_mode...因为 MySQL 通常会分配固定大小的内存块来保存内部值,尤其是使用内存临时表进行排序或操作时。在利用磁盘临时表进行排序也同样糟糕。所以,最好的策略是只分配真正需要的空间。...from 《高性能MySQL》 六、参考资料 官方文档 《高性能MySQL》第四章

1.1K00

MySQL 支持JSON字段的基本操作、相关函数及索引使用如何索引JSON字段

具体语法规则可以参考: MySQL 5.7新增对JSON支持 https://blog.csdn.net/szxiaohe/article/details/82772881 如何索引JSON字段 MySQL...并没有提供对JSON对象中的字段进行索引的功能,我们将利用MySQL 5.7中的虚拟字段的功能来对JSON对象中的字段进行索引。...这也是MySQL默认的方式 加完虚拟列的建表语句如下,此时虚拟字段还没加索引 CREATE TABLE `t` ( `id` INT UNSIGNED NOT NULL, `js`...MySQL只是在数据字典里保存该字段元数据,并没有真正的存储该字段的值。这样表的大小并没有增加。我们可以利用索引把这个字段上的值进行物理存储。...参考:MySQL如何索引JSON字段 https://developer.aliyun.com/article/303208 MyBatis Plus查询json字段 https://blog.csdn.net

26.2K31

关于索引字段

关于索引字段 问题描述 关于删除字段是否适合建索引 案例重现 前段时间公司系统的一个查询接口非常缓慢,前端页面查询的时候都超时报500 了,于是去分析了sql,其实sql 很简单,就是两个表的关联查询,...settlement_list where delete_status = 1 ,速度非常慢,23s 左右,不带delete_status 也是很慢 20多s,于是看了下 settlement_list 的索引...,其他的索引都没问题,然后我就在delete_status 字段也建了个索引,建了以后再查询SELECT * FROM settlement_list where delete_status = 1...好家伙,一下就到了0.36s,这速度是一个质的飞跃啊,于是我就开始纠结了,删除字段索引,会不会被鄙视啊,理论上小基数字段不要建索引,但是实际情况,建了索引确实速度提高了啊,于是我还是提交了代码,果不其然被同事发现了...,于是开始了掰扯,把索引删掉后,速度一下又到了二十几s,加上索引速度变成1s以内,最后同事得出的结论是,确实找不到反驳的理由,加了索引速度是真的提升了,也许理论和实践还是不一样。

9220

MySQL 使用规范 —— 如何建好字段索引

这包括;库表创建规范、字段的创建规范、索引的创建规范以及SQL使用的相关规范,通过这些内容的讲解,让读者更好使用 MySQL 数据库,创建出符合规范的表和字段以及建出合适的索引。...包括;表的引擎、命名约束、字段长度、金额类型、更新时间、索引字段、组合索引等内容,方便大家学习以后,可以基于这些字段的规范演示讲解,在自己创建库表的时候有个参考对照,尽可能创建出性能更佳的库表和索引。...单表索引建议控制在5个以内,单索引字段数不超过5个。注意:已有idx(a, b)索引,又有idx(a)索引,可以把idx(a)删了,浪费空间,降低更新、写入性能。...在一些低区分度的字段,例如type、status上建立独立索引几乎没意义,降低更新、写入性能。 防止因字段不同造成的隐式转换,导致索引失效。 更新频繁的字段,不要建索引。 4....,MySQL内部需要进行特殊处理,表中有较多空字段的时候,数据库性能下降严重。

54530

mysql 分区 varchar_MySQL分区总结

MySQL分区类型主要包括:range分区、list分区、hash分区、key分区; 无论是那种MySQL分区类型,要么分区表上没有主键/唯一键,要么分区表的主键/唯一键都必须包含分区键,也就是说不能使用主键.../唯一键字段之外的其他字段分区。...如: 去掉主键约束后,创建表会成功: 分区的名字遵循MySQL标识符的原则。分区的名字不区分大小写,如果分区名分别为 mypart 和 MyPart 将会被MySQL认为是同一个分区而报错。...类似的函数有 to_days()、to_seconds();5.5版本后可直接使用日期字段作为分区键。...,否则不被接受 4、Hash/Key 分区中,null 值会被当做零值来处理 5、为了避免在处理 null 值时出现误判,推荐通过设置字段非空和默认值来绕开 MySQL 对 null 值的默认处理 发布者

3.2K20

技术分享 | MySQL 可以对相同字段创建不同索引

同事问了个问题,MySQL 的某个测试库,发现有这种情况: 给已设置为主键的列又加了一次索引,如下前两条 SQL 语句。 给同一个字段加了 2 次索引,如下后两条 SQL 语句。...1测试一 数据库版本:MySQL 8.0,为表 t 设置主键,再对同字段加个索引可以执行成功。...2测试二 通过 explain,可以验证出对于同时存在 PRIMARY KEY 和普通索引字段作为检索条件时,优化器会选择 PRIMARY KEY 作为 key,这种选择应该和 MySQL索引组织表存储的形式有关...之所以存在上面的这些问题,因为 MySQL 允许创建不同名称相同索引字段索引。...Oracle 19c,在主键字段上创建索引,会提示 此列列表已索引 的错误。在相同字段上创建第二个索引,也是提示 此列列表已索引 的错误。

32140
领券