1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引) mysql...>ALTER TABLE `table_name` ADD UNIQUE ( `column` ) 3.添加INDEX(普通索引) mysql>ALTER TABLE `table_name` ADD...INDEX index_name ( `column` ) 4.添加FULLTEXT(全文索引) mysql>ALTER TABLE `table_name` ADD FULLTEXT ( `column...` ) 5.添加多列索引 mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`, `column3` )
可选的解决方案 详细内容请参考专栏的文章: MySQL 5.7新特性:Online DDL MySQL 5.5 与 以前 在 MySQL 5.5 与更老的版本中,对 Alter 操作做了较简单的实现,添加和删除列的操作使用的是...MySQL 8.0 的快速添加列 在 >=MySQL 8.0.12 的版本中,官方为 Online DDL 操作添加了 instant 算法,使得添加列时不再需要 rebuild 整个表,只需要在表的...SET 列的定义 变更索引的类型(B 树,哈希) 使用 alter 语法重命名表 使用如下 sql 命令可以查看每个表通过 instant 算法加列前的非 instant 列的数量,如果该表没有添加过...仅支持使用 MySQL 8.0 新表空间格式的表。 不支持临时表。 包含 instant 列的表无法在旧版本的 MySQL 上使用(即物理备份无法恢复)。...总结一下 实际上快速加列的 patch 是腾讯提交给官方,然后由官方自己重新实现的特性,腾讯云数据库 MySQL 自然也集成了这个功能,使用 5.7 版本的实例,简单测试一下: mysql> CREATE
// MySQL 8.0 之 Online DDL快速加列 // 问题描述 前几天同事问了我一个问题:业务A从MySQL迁移到MongoDB的原因是什么?...在实际的MySQL运维过程中,我们经常会遇到业务需要给某张表添加字段的情况,那么常用的MySQL添加字段的方法有哪些呢?...这里我简单列举一下: 1、percona的pt-osc工具 2、github开源项目gh-ost工具 3、MySQL原生Online DDL 01 MySQL Online DDL加列的历史方法 01...Copy方法 MySQL5.5版本及之前的加列方法:Copy 它的执行示意图如下: 我们有一个原表A,只包含1个字段,它包含1、2、4、6这几条记录,当我们使用Copy算法加列时: 1、创建了一个新的表...02 MySQL8.0.12 引入的Instant方法 MySQL8.0.12版本引入了Instant的方法,它让加列变得更加简单。
直接了当上SQL SELECT a.字段1, a.字段2, b.字段1, COUNT(DISTINCT a.字段1),COUNT(DISTINCT b.字段1) //...这行为去重 FROM xs_highway_transport_log a LEFT JOIN b表 b ON b.id = a.main GROUP BY a.字段...1 ,b.字段1 // 这行为分组 直接这样 即可实现 多字段去重情况。...同时可以配合having过滤分组,也可以在 分组前 GROUP BY 前添加WHERE 条件 [GROUP BY 字段][HAVING ] 上效果图 注:要放在COUNT
mysql中的6个列属性:null,default,comment,primary key,unique key,auto_increment 1. NULL 代表字段为空。...', default); 3 comment 列描述 基本语法:comment ‘字段描述’; mysql> create table tbTest ( name varchar(10...,具有业务意义(学生ID,课程ID) 逻辑主键:自然增长的整型(应用广泛) 5. unique key 唯一键 主键也可以用来保证字段数据唯一性,但一张表只有一个主键 唯一键在一张表中可以有多个。...) charset utf8; 6. auto_increment 自动增长 通常自动增长用于逻辑主键,只适用于数值,sqlserver中使用identity(1,1) 6.1 自动增长原理 在系统中维护一组数据保存当前使用自动增长属性的字段...,字段属性之后不再保留 auto_increment 即可 6.5 初始设置 在系统中有一组变量维护自增长的初始值和步长 show variables like ‘auto_increment%’;
mysql学习总结03 — 列属性(字段属性) toc mysql中的6个列属性:null,default,comment,primary key,unique key,auto_increment 1...', default); 3 comment 列描述 基本语法:comment '字段描述'; mysql> create table tbTest ( name varchar(10...,具有业务意义(学生ID,课程ID) 逻辑主键:自然增长的整型(应用广泛) 5. unique key 唯一键 主键也可以用来保证字段数据唯一性,但一张表只有一个主键 唯一键在一张表中可以有多个。...) charset utf8; 6. auto_increment 自动增长 通常自动增长用于逻辑主键,只适用于数值,sqlserver中使用identity(1,1) 6.1 自动增长原理 在系统中维护一组数据保存当前使用自动增长属性的字段...,字段属性之后不再保留 auto_increment 即可 6.5 初始设置 在系统中有一组变量维护自增长的初始值和步长 show variables like ‘auto_increment%’; 6.6
在需求中由于要批量查数据,且表中数据量挺大(2300万条记录) 且查询条件的这两个字段没有加索引,为了增加查询速度,现在需要去为这两个字段添加索引。...所以是可以加的 这个作引应该怎么加 由于每个字段的大小是256 所以说这个索引树建下来还是很浪费存储的,于是考虑前缀索引,和复合索引。...由于前缀索引的话这两个字段并不是有规律可寻的所以说加了的话 这玩意会增加扫描的行数的。 然后算了就加复合索引吧。 既然创建复合索引那么我们如何去吧那个索引放在前面呢?...由于联合索引的是先以 前面的排序在根据后面的排序所以说将区分度高的放在前面会减少扫描行数增加查询效率 但是最重要的问题来了,我就要提交SQL的时候 leader 问了一句我,你这边的话这个数据字段 默认值为...于是带着疑问去查了查, 在innodb引擎是可以在为null的列里创建索引的,并且在当条件为is null 的时候也是会走索引的。
同事提了个需求,如下测试表,有code、cdate和ctotal三列,select * from tt;现在要得到code的唯一值,但同时带着cdate和ctotal两个字段。...distinct支持单列去重和多列去重,如果是单列去重,简明易懂,即相同值只保留1个,如下所示,select distinct code from tt;多列去重则是根据指定的去重列信息进行,即只有所有指定的列信息都相同...错误 [1064] [42000]: You have an error in your SQL syntax; check the manual that corresponds to your MySQL...MySQL不同版本sql_mode默认值可能是不同的,因此在数据库升级配合的应用迁移过程中,尤其要注意像only_full_group_by这种校验规则的改变,很可能是个坑。...distinct,就可以过滤所有的重复值,满足了需求,select group_concat(distinct code), cdate, ctotal from tt group by code;当然,这种在会话级通过改动
MySQL数据类型 (1)数值类型 1、整数型 2、浮点型 3、定点型 (2)日期时间类型 (3)字符串类型 MySQL字段属性 1、空\不为空值:NULL、NOT NULL 2、主键:primary...浮点型和定点型可以用类型名称后加(M,D)来表示,M表示该值的总共长度,D表示小数点后面的长度,M和D又称为精度和标度。...float和double在不指定精度时,默认会按照实际的精度来显示,而DECIMAL在不指定精度时,默认整数为10,小数为0。...存储文字,当字符大于255时,一般使用text; mediuntext L+3 中等长度文本数据 longtext L+4 极大文本数据 不要轻易的使用最大限度来存储字符串,因为涉及记录长度问题 : MySQL...唯一键可以约束字段,使得字段的数据不能重复 如果唯一键同时也有not null,并且表中没有主键的话,在desc查看表结构中会显示成主键 如果唯一键也不允许为空,那么功能与主键相同 唯一键的定义方法可以参考主键的
很早就听说 MySQL8.0 支持快速加列,可以实现大表秒级加字段。笔者自己本地也有8.0环境,但一直未进行测试。本篇文章我们就一起来看下 MySQL8.0 快速加列到底要如何操作。...了解背景信息 表结构的变更是业务运行过程中比较常见的需求之一,在 MySQL 的环境中,可以使用 Alter 语句来完成这些操作,这些 Alter 语句对应的操作通常也称之为 DDL 操作。...查阅官方文档得知,快速加列即 Instant Add Column ,该功能自 MySQL 8.0.12 版本引入,是由腾讯游戏DBA团队贡献。注意一下,此功能只适用于 InnoDB 表。...只能顺序加列, 仅支持在最后添加列,而不支持在现有列的中间添加列。 不支持压缩表,即该表行格式不能是 COMPRESSED。 不支持包含全文索引的表。 不支持临时表。...总结 虽然快速加列存在一些限制, instant 算法也只适用于部分 DDL 操作,但 8.0 的这项新功能已经足以令人兴奋,很大程度上解决了大表加字段的大难题。
前言: 很早就听说 MySQL8.0 支持快速加列,可以实现大表秒级加字段。笔者自己本地也有8.0环境,但一直未进行测试。本篇文章我们就一起来看下 MySQL8.0 快速加列到底要如何操作。...1.了解背景信息 表结构的变更是业务运行过程中比较常见的需求之一,在 MySQL 的环境中,可以使用 Alter 语句来完成这些操作,这些 Alter 语句对应的操作通常也称之为 DDL 操作。...2.快速加列测试 快速加列采用的是 instant 算法,使得添加列时不再需要 rebuild 整个表,只需要在表的 metadata 中记录新增列的基本信息即可。...只能顺序加列, 仅支持在最后添加列,而不支持在现有列的中间添加列。 不支持压缩表,即该表行格式不能是 COMPRESSED。 不支持包含全文索引的表。 不支持临时表。...总结: 虽然快速加列存在一些限制, instant 算法也只适用于部分 DDL 操作,但 8.0 的这项新功能已经足以令人兴奋,很大程度上解决了大表加字段的大难题。
对于分区字段必须是主键的一部分,那么建了复合主键之后,是否需要对分许字段再单独添加一个索引呢?有没有效果?...filtered extra 1 SIMPLE effect_new p8 ref idx_ctime idx_ctime 5 const 60760 100 null 6、结论: 虽然表已经根据此字段分区...分了区,只能说该字段为某个值的记录会在某个分区里面,但不是索引,还要一顿好找。 有时候,主键不等于分区依据列,这时候主键又想建聚集索引的话,那么必须包含分区依据列,搞成复合主键。...那么,这种情况下,分区依据列不就有索引了吗?...是的,可是它不够快,如果在这个复合索引里面,分区依据列不排在第一位,就不够快,如果查找语句里常常用分区依据列作为过滤条件,就有必要为分区依据列额外单独建立一个索引。
mysql 5.7中有很多新的特性,但平时可能很少用到,这里列举2个实用的功能:虚拟列及json字段类型 一、先创建一个测试表: drop table if exists t_people; CREATE...三、前缀索引 肯定有同学想到了,在name上建一个前缀索引,只对name的第1个字做索引 alter table t_people add key ix_name(name(1)); 确实是个好办法,...,insert时也无法指定字段值。...注意:profile->"$.phone"=xxx 就是json字段的检索语法 ?...参考文章: http://mysqlserverteam.com/generated-columns-in-mysql-5-7-5/ https://dev.mysql.com/doc/refman/5.7
在MySQL中,可以通过alter table语句来修改表中一个字段的数据类型。下面本篇文章就来带大家了解一下alter table语句,介绍如何修改字段类型,希望对大家有所帮助。...在MySQL中,alter table语句是用于在已有的表中添加、修改或删除列(字段)的。...1、添加字段(列)alter table 表名 add 字段名 数据类型 示例:在表 “Persons” 中添加一个名为 “Birthday” 的新列,数据类型为“date”alter table Persons...add Birthday date 说明:新列 “Birthday” 的类型是 date,可以存放日期 2、修改字段名alter table 表名 rename column A to B 3、修改字段类型...4、删除字段alter table 表名 drop column 字段名 示例:删除 “Person” 表中的 “Birthday” 列alter table Persons drop column Birthday
s_tablename IS NOT NULL ) DO SET @MyQuery = CONCAT( "alter table `", s_tablename, "` add COLUMN `字段名
oracle 1、创建一个序列,然后在需要自增的字段里使用它 drop sequence seq_stu create sequence seq_stu start with 22 Increment...seq_stu.nextval) 如何重置数据表中自增 1、删除该序列,再重新创建该序列即可 2、 truncate table 表名; 注意:截断表,即删除所有数据,只保留表结构 Mysql...创建表时直接制定自增列/字段 1、通过点击点击相关表选择“设计表”进行设置 ?...int, FOREIGN key(dept_id) REFERENCES dept(dept_id) )auto_increment = 1000; --auto_increment = 1000作用是从字段数字从...1000开始 如何重置数据表中自增 TRUNCATE TABLE 表名; 注意:会删除表中的数据,只有在MySQL中,TABLE字段可省略
需求 在发布系统中所有前置任务里面增加一些内容,发布系统中大约有200+的项目,手动是不可能手动的,只有在数据库中操作了。 思路 思路?既然操作数据库哪肯定得去看MySQL手册喽。...在Mysql手册中查找String相关资料,找到并进入String Functions,可以找到CONCAT和CONCAT_WS两个关于字符串拼接的函数文档链接。 ? ?...函数格式:CONCAT(str1,str2,...) mysql> select concat('lian','st'); +---------------------+ | concat('lian'...-------------------+ 1 row in set (0.00 sec) CONCAT_WS函数 CONCAT_WS函数与CONCAT函数大致相同,唯一的不同点是CONCAT_WS支持在两个字符串之间使用分隔符...CONCAT_WS的第一个参数是分隔符: char(10):换行符 char(13):回车符 mysql> select concat_ws(',','lian','st'); # 第一个参数是分隔符
同时,MySQL 是支持前缀索引的,也就是说,你可以定义字符串的一部分作为索引。默认地,如果你创建索引的语句不指定前缀长度,那么索引就会包含整个字符串。...以上为第一条语句的索引图,以下为第二条语然的索引图。...第一种方式是使用倒序存储。...第二种方式是使用 hash 字段。你可以在表上再创建一个整数字段,来保存身份证的校验码,同时在这个字段上创建索引。...从占用的额外空间来看,倒序存储方式在主键索引上,不会消耗额外的存储空间,而 hash 字段方法需要增加一个字段。
引言 今天我们来说一个MySQL查询的例子,比如有一个统计需求, 分组后的数据,我们知道只能使用聚合函数进行统计, 那如果要根据分组约定,将一系列的值合并到单个字段显示出来, 应该怎么写呢? ?...或者说MySQL有没有这个能力处理呢? 当然是有的。MySQL贴心地给出了 GROUP_CONCAT 函数,用于使用分隔符连接多行字段的值。...比如说按照 person_id 进行分组,然后第二列输出用户喜好,使用逗号分隔符: SELECT person_id, GROUP_CONCAT(hobbies SEPARATOR ', ') AS all_hobbies...FROM peoples_hobbies GROUP BY person_id; 当然了,peoples_hobbies 表完全有可能在 hobbies 字段有重复的值,我们也可以进行唯一性筛选。...比如对我们的输出字段进行排序后再使用分隔符连接。
PO:重点是autoResultMap = true和@TableField(typeHandler = FastjsonTypeHandler.class)
领取专属 10元无门槛券
手把手带您无忧上云