记录一个在工作中遇到的问题,也不算是问题,为的是找一种简便的方法批量修改数据表字段的排序规则,在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类型。
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以上。
在这篇文章中,我将为你解析如何在MySQL数据库中,对VARCHAR类型的日期字段进行筛选。这是一个在数据库设计中经常遇到的问题,尤其是当日期被保存为字符串格式时。...你是否也在搜索“MySQL VARCHAR日期筛选”、“如何在MySQL中筛选字符串日期”等关键词?不用再找了,这里有你想要的答案! 引言 在数据库设计中,选择合适的字段类型非常重要。...正确筛选VARCHAR日期字段的方法 ️ 为了正确筛选VARCHAR日期字段,我们可以使用MySQL的 STR_TO_DATE 函数: -- 考虑日期和时间 SELECT * FROM your_table_name...总结 虽然使用VARCHAR字段来存储日期和时间提供了灵活性,但它也带来了筛选数据的挑战。幸运的是,通过使用MySQL的内置函数,我们可以有效地解决这个问题。...希望这篇文章帮助你解决了在MySQL中筛选VARCHAR日期字段的问题! 参考资料 MySQL官方文档 - STR_TO_DATE函数: 链接 日期和时间的存储选择: 链接
很多时候我们看到一些表字符串类型的字段定义为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是常规情况下较少出错的一个值。
1.varchar类型 (1)varchar (N):中的N指的是字符的长度,即:该字段最多能存储多少个字符(characters),不是字节数。...:varchar字段定义中带有 default null 允许列空,则需要 1 bit 来标识,每 8 个bits的标识组成一个字段。...(3)虽然InnoDB内部支持 varchar 65535 字节的行大小,但是MySQL本身对所有列的合并大小施加了 65535 字节的行大小限制。...若定义的时候超过上述限制,则varchar字段会被强行转为text类型,并产生warning。...mysql> alter table t4 modify column c3 varchar(21813); ERROR 1118 (42000): Row size too large.
很多时候我们看到一些表字符串类型的字段定义为varchar(255),开始以为varchar只能定义为255这个长度值,其实不然。...官方文档所说,varchar有效的最大长度取决于行的容量,以及用的字符集,整行的所有列的定义长度不能超过65535字节(bytes),text、blob等大字段类型除外, P.S. https://dev.mysql.com...一般情况下,我们用的是InnoDB引擎,utf8则是常用字符集,因此varchar类型字段定义为255比较合适。...但实际上,varchar(255)并不是最优的字符定义长度,究竟定成多少,还是要根据实际需求来决定,例如这个字段我就不需要创建索引,定义超过255,是可以的,只能说255是常规情况下较少出错的一个值。...TIMESTAMP类型字段非空和默认值属性的影响》 《小白学习MySQL - 聊聊数据备份的重要性》 《小白学习MySQL - InnoDB支持optimize table?》
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》第四章
这样的表在数据库中没有外键关系,而且一般ForeignKey的类型是varchar,为了兼容其他表的主键可能不一样。...ForeignKey = b.ID } select a; 因为xxx.id是Guid(uniqueidentifier)类型和WorkflowInstance.ForeignKey是string(varchar...equals new { ForeignTable = nameof(xxx), ForeignKey = b.ID+"" } select a; 以为这段代码最终都会转成sql语句,而Guid是不能直接转换成varchar...(50) AS BEGIN RETURN CONVERT(VARCHAR(50),@id) END 把函数添加到db模型 可以直接编辑edmx模型文件添加如下代码: <Function Name...添加自定义函数对应的方法 /// /// sql函数Guid转varchar /// /// /// <returns
(columnIndex)获取字段的Java类型。...SET(‘value1′,’value2’,…) CHAR java.lang.String 三、类型转换 上面我们看到MySQL的BIGINT默认转为Java的java.lang.Long,那是不是就不能转为...MySQL的JDBC(Connector/J)在字段类型与Java类型之间的转换是比较灵活的。...一般来说,任何字段类型都可以转换为java.lang.String,任何数值字段类型都可以转换为Java的数据类型(当然会出现四舍五入、溢出、精度丢失的问题)。...MySQL数据类型可以被转换的Java类型 CHAR, VARCHAR, BLOB, TEXT, ENUM, and SET java.lang.String, java.io.InputStream,
目录 1 实现 1 实现 /** * 驼峰式命名法 例如:user_name->userName * 将数据库字段名称 转为 Java实体类字段属性 */ public
若要将繁体转换为简体,请将toTraditional改为toSimplified。
mysql–varchar类型时间排序和查询某一个时间段信息 背景: 在实际操作中会经常将时间数据以 varchar 类型存入数据库,因为业务要求需要查询最近时间内的数据,所以需要根据时间排序 排序实例...SELECT * FROM 表名 ORDER BY 时间字段名 DESC; 降序 SELECT * FROM 表名 ORDER BY 时间字段名 ASC; 升序 SELECT * FROM 表名...ORDER BY 时间字段名; 升序 查询介于一个时间段之间的信息实例 SELECT 字段名 FROM 表名 WHERE STR_TO_DATE(时间字段名, '%Y-%m-%d...') BETWEEN STR_TO_DATE(起始时间, '%Y-%m-%d') AND STR_TO_DATE(结束时间, '%Y-%m-%d') ORDER BY STR_TO_DATE(时间字段名
MySQL分区类型主要包括:range分区、list分区、hash分区、key分区; 无论是那种MySQL分区类型,要么分区表上没有主键/唯一键,要么分区表的主键/唯一键都必须包含分区键,也就是说不能使用主键.../唯一键字段之外的其他字段分区。...如: 去掉主键约束后,创建表会成功: 分区的名字遵循MySQL标识符的原则。分区的名字不区分大小写,如果分区名分别为 mypart 和 MyPart 将会被MySQL认为是同一个分区而报错。...类似的函数有 to_days()、to_seconds();5.5版本后可直接使用日期字段作为分区键。...,否则不被接受 4、Hash/Key 分区中,null 值会被当做零值来处理 5、为了避免在处理 null 值时出现误判,推荐通过设置字段非空和默认值来绕开 MySQL 对 null 值的默认处理 发布者
问题描述 我们在设计表结构的时候,设计规范里面有一条如下规则: 对于可变长度的字段,在满足条件的前提下,尽可能使用较短的变长字段长度。 为什么这么规定?...基于性能考虑,是因为过长的字段会影响到查询性能?...Created_tmp_files 为 4 sort_merge_passes为645 关于sort_merge_passes, Mysql给出了如下描述: ❝ Number of merge passes...四.最终结论 至此,我们不难发现,当我们最该字段进行排序操作的时候,Mysql会根据该字段的设计的长度进行内存预估, 如果设计过大的可变长度, 会导致内存预估的值超出sort_buffer_size的大小..., 导致mysql采用磁盘临时文件排序,最终影响查询性能
学习原因 在开发当中,经常看见有些字段长度是varchar(20)或者varchar(32),但是在自己建表的时候,navicat基本上都是默认的varchar(255)的长度。...长度限制和字段选择 查阅了资料后,发现了一些关于数据库的长度限制及表设计的相关资料 相关资料: 各个数据库表名和字段名长度限制 MySQL中各种数据类型的长度及在开发中如何选择 MySql数据库表字段命名及设计规范...数据库中存储日期的字段类型到底应该用varchar还是datetime 为什么很多公司要求 mysql 表主键 id 必须是 long 型?...为什么mysql的varchar字符长度会被经常性的设置成255 在仔细阅读上述的相关资料后,算是解决了很多的疑问,也学习到了不少数据库书本上难以学习到的经验。...MySQL中采用类型varchar(20)和varchar(255)对性能上的影响 创建一个测试表,并创建相关的字段,存入1000条数据。
从字段类型的执行效率上,int最高,varchar最低。...状态类型字段,使用char或者varchar是不可取的,int类型更容易建立索引和进行检索,毕竟数字类型是数据库检索的基础,char类型的毕竟需要经过转换,而varchar就更复杂了,其排序不仅需要转换和计算...因此,通常在数据库设计中,都是尽量使用int类型字段而不是字符类型字段,这在大型和超大型数据库的优化中,有明显的性能差异。
例如,我创建了一张参数配置表,当初针对参数配置值的长度预估为varchar(500)。...问题浮现我们先来看一下现在的表结构,也就是在进行 varchar 转 text 之前的表结构,表字段长度等信息,直接通过 DM管理工具 来查看表属性, 字段 sys_config 的长度为 varchar...(500) 达梦数据库和Mysql 数据库不同,如果你直接操作命令行来更新数据表字段类型会报错,比如我直接执行sql语句ALTER TABLE ALM."...sys_config" RENAME COLUMN config_value_tmp TO config_value;执行完成之后就可以看到表结果已经是最新的表结构了到这里整个达梦数据库字段类型 varchar...总结总的来说,达梦数据库不支持直接将字段类型从 varchar 转 text ,这个时候就需要采用一些曲折的方法来实现,上面就是我提到的两种方法,根据数据量的大小采用不同的方式,希望对大家有帮助。
介绍 CHAR和VARCHAR几乎相同,但在存储和从数据库中检索数据的阶段,两者都不同。 对于这两种数据类型,我们必须传递length说明符,它表示字段可以保存多少数据。...例如char(30)和varchar(30),这意味着这些数据类型的字段最多可以容纳30个字符。 对于CHAR,此长度可以是从0到255之间的任何值,对于VARCHAR可以是从0到65,535。...CHAR 当值存储在CHAR字段中时,剩余的字符将用空格填充。 例如,一个字段是“name CHAR(5)”,并且您要存储只是“jack”,则实际值将存储为“jack ”。...想象一下,MySQL想要检索集合的第10个记录。 使用VARCHAR,它必须读取第一个记录的前缀以知道第二个开始的哪个字节,等等。...原文:http://www.xpertdeveloper.com/2011/12/char-varchar-in-mysql/
1. varchar 和 char 共同点 ---- varchar 和 char 是 MySQL 中的两种数据类型,都是用来存储字符串的。...2. varchar 和 char 区别 ---- 一、长度是否可变 varchar 类型的长度是可变的,而 char 类型的长度是固定的 char 类型是一个定长的字段,以 char(10) 为例,不管真实的存储内容多大或者是占了多少空间...长度最大为 65535 个字符 三、检索效率方面 varchar 类型的查找效率比较低,而 char 类型的查找效率比较高 3. varchar 和 char 的选择 ---- 存储的字符长度是可变化的...,建议使用 varchar 类型,它可以节省存储空间。...使用场景:使用 md5 加密的密码长度固定为 32 位字符 总结: 可变长度使用 varchar,固定长度使用 char
------- bigint(20) smallint ------- smallint(6) tinyint ------- tinyint(4) MySQL...2个字节有16位,无符号从0000 0000 0000 0000(0)到1111 1111 1111 1111(2^16-1) 有符号:(-2^15到2^15-1) mysql中设置varchar长度的问题...如果某一项中设置的是varchar(50),那么对英文当然是50,那么对中文呢?utf-8的中文占3个字节,那么这个varchar(50)是不是只能存16个汉字了?...mysql varchar(50) 不管中文 还是英文 都是存50个的