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

MYSQL 生产环境字段更改failed问题

早上看到微信一个银行同学问了小问题,希望他不要背锅,具体问题是MYSQL 一个50G表要更改字段,将一个字段从varchar(3) 改成varchar(6). MYSQL 5.7 官版。...在这种情况下,所需长度字节数从1更改为2,这仅由表副本支持(ALGORITHM = COPY)。...到底是为什么,官方在文档明确了 ? 为了确保事务可串行性,服务器必须不允许一个会话对另一个会话未完成显式或隐式启动事务中使用表执行数据定义语言(DDL)语句。...服务器通过获取事务中使用元数据锁,并将这些锁释放推迟到事务结束时,来实现这一点。表上元数据锁可以防止对表结构更改。这种锁定方法意味着一个会话内事务正在使用表,不能在DDL状态下使用。...注:到目前为止MYSQL 在修改字段方面,对比其他数据库还是要注意地方多多,当然MYSQL 8 已经添加了 instant 让修改字段变得更让人放心。

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

mysql学习总结03 — 列属性(字段属性)

mysql学习总结03 — 列属性(字段属性) toc mysql6个列属性:null,default,comment,primary key,unique key,auto_increment 1...,具有业务意义(学生ID,课程ID) 逻辑主键:自然增长整型(应用广泛) 5. unique key 唯一键 主键也可以用来保证字段数据唯一性,但一张表只有一个主键 唯一键在一张表可以有多个。...唯一键允许字段数据为NULL,NULL可以有多个(NULL不参与比较) 5.1 创建唯一键 随表创建 mysql> -- 方法1,给字段增加 unique[ key] 属性 mysql> create...) charset utf8; 6. auto_increment 自动增长 通常自动增长用于逻辑主键,只适用于数值,sqlserver中使用identity(1,1) 6.1 自动增长原理 在系统维护一组数据保存当前使用自动增长属性字段...,字段属性之后不再保留 auto_increment 即可 6.5 初始设置 在系统中有一组变量维护自增长初始值和步长 show variables like ‘auto_increment%’; 6.6

2.3K30

mysql学习总结03 — 列属性(字段属性)

mysql6个列属性:null,default,comment,primary key,unique key,auto_increment 1. NULL 代表字段为空。...,具有业务意义(学生ID,课程ID) 逻辑主键:自然增长整型(应用广泛) 5. unique key 唯一键 主键也可以用来保证字段数据唯一性,但一张表只有一个主键 唯一键在一张表可以有多个。...唯一键允许字段数据为NULL,NULL可以有多个(NULL不参与比较) 5.1 创建唯一键 随表创建 mysql> -- 方法1,给字段增加 unique[ key] 属性 mysql> create...) charset utf8; 6. auto_increment 自动增长 通常自动增长用于逻辑主键,只适用于数值,sqlserver中使用identity(1,1) 6.1 自动增长原理 在系统维护一组数据保存当前使用自动增长属性字段...,字段属性之后不再保留 auto_increment 即可 6.5 初始设置 在系统中有一组变量维护自增长初始值和步长 show variables like ‘auto_increment%’;

1.7K30

MySQLjson字段

// MySQLjson字段 // MySQL5.7.8引入了json字段,这种类型字段使用频率比较低,但是在实际操作,有些业务仍然在用,我们以此为例,介绍下json字段操作方法...json内容。...其中: 1、$符号代表是json根目录, 2、我们使用$.age相当于取出来了jsonage字段, 3、当然,在函数最前面,应该写上字段名字info 下面来看json中常用函数: a、json_valid...,如果传入了字符串2,那么,返回结果是1 b、json_keys传回执行json字段最上一层key值 mysql> select json_keys('{"name":"yeyz","score":100...,形如{'aa':1}这种形式json,其深度是2 e、json_contains_path函数检索json是否有一个或者多个成员。

9K20

LinuxChattr命令更改文件属性

在Linux,文件属性是描述文件行为元数据属性。 例如,属性可以指示是否压缩文件或指定是否可以删除文件。...本文介绍了如何使用chattr命令更改Linux文件系统上文件属性。...[OPERATOR]部分值可以是以下符号之一: +-加号运算符告诉chattr将指定属性添加到现有属性。 - -负号运算符告诉chattr从现有属性删除指定属性。...= -等于运算符告诉chattr将指定属性设置为唯一属性。 操作符后跟一个或多个要添加或从文件属性删除[ATTRIBUTES]标志。...以下是一些常用属性和相关标志列表: a-设置此属性后,只能以追加模式打开文件进行写入。 A -打开具有该属性文件时,其atime记录不会更改

3.6K20

Mysql数据类型以及字段属性大盘点

l   Year:存储年份信息,有两位和4位之分 2、  数字数值类型 Bool是tinyint别名,用于赋值0或者1 Bigint:数据类型提供了mysql最大整数范围,取值范围分为有符号:-9223372036854775808...Tinyint:提供了最小整数范围,值在-128-127(分清楚范围就不担心数据够不够存储) Decimal,double,float:存储浮点数 3、  字符串类型 Char:提供了固定长度字符串类型...,最大255字符 Varchar:可变长度字符串类型,最大255个字符(尽量使用char而不是varchar) Longblob:提供了最大二进制字符串存储,最大4294967295个字符 Longtext...组不同数据 Set:枚举类型,最多可以设置有64个成员 数据类型属性 Auto_increment:自增,每次插入该列值会是上次插入值+1 Default:默认值,当没存入数据时会自动存入默认值 Index...5那么存入1时候会自动添加00001,就是前面用0补全

88480

MySQLexplain结果字段介绍(三)

MySQLexplain结果字段介绍(三) 之前文章对于explain数据结果字段已经进行了一部分介绍了,今天来说一说剩下几个字段,为了防止忘记,先看看这个表结构: mysql...1个字节 3、对于varchar这种变长字段,需要有额外2个字节来保存长度 有了这三条规则,就能比较容易理解key_len值了,例如上面的例子,key_len值是4,它原因是int类型是固定长度...,与条件匹配值是一个常数还是一个变量之类,我们可以看到,上面的结果,ref字段值都是const,是因为我们使用常量a或者常量2和索引字段进行匹配,如果我们使用某个字段进行匹配,来看下面: mysql...Using where 表示Mysql将对storage engine提取结果进行过滤,过滤条件字段无索引; Using temporary 要解决查询,MySQL需要创建一个临时表来保存结果。...包含 ORDER BY 操作,而且无法利用索引完成排序操作时候,MySQL Query Optimizer 不得不选择相应排序算法来实现。

2.1K10

mysql更改密码首选语句_MySQL如何更改用户密码?(代码实例)「建议收藏」

MySQL,可以使用3种不同语句更改用户帐户密码:UPDATE statementSET PASSWORD statementALTER USER statement....现在让我们学习如何使用上面提到三个SQL语句在SQL更改用户密码: 1.使用SET PASSWORD语句更改MySQL用户密码 要使用SET PASSWORD语句更改用户密码,第一个要求是该帐户至少需要具有...要使用Alter User语句将用户帐户“gfguser1”密码更改为“newpass”,语法如下所示: 语法: 3.使用UPDATE语句更改MySQL用户密码 更改用户帐户密码第三种方法是使用UPDATE...FLUSH PRIVILEGES语句用于从mysql数据库grant表重新加载权限。...要将用户帐户“gfguser1”密码更改为从localhost服务器连接“newpass”,语法如下所示: 语法: 本篇文章就是关于MySQL更改用户密码方法介绍,相关mysql视频教程推荐:《

5.7K20

定义 Item 字段属性选项

Item 在 IRIS 作用和我们关系数据库中有关字段作用相同,可以通过定义 Item 属性,我们可以知道我们可以存储什么数据,以及数据之间有什么关系。...Item number每一个 Item 都会有一个 ID,这个 ID 是为唯一在数据库中用来标识 Item ,这个 ID 通常是数字。Item Title类似关系数据库字段名。...比如说我们定义一个用户名字段,为了标识用户名,我们可以把 Item Title 设置为 UserName。Data Type定义我们可以在数据存储什么样数据。...但 IRIS 字段类型有限,也就那么4种,所以在这里我们只知道这个是定义数据类型就行了。Networked(可选)这个就有点像我们关系数据库跨数据库了。...例如在关系数据库,我们有数据库 A 存储了一些数据,但我们在数据库 B 希望引用数据库 A 数据,那么我们 SQL 上通常是 a.col 字段名这种方式来引用

7200

Django模型字段属性choice使用说明

今天设计models时,用到了choice这个属性,用来限制用户做出选择范围。比如说性别的选择(男或女)。 class User(AbstractUser): 。。。...显而易见,display_name就是要在页面展示。 如何取到value和displayname?...在模板可以通过模板语言 {{ user.sex }}很简单地显示value,但不能直接调用 get_属性_display()方法(模板毕竟是模板语言) 只能自定义过滤器,顺便提一句django是不能直接调用函数...补充知识:djangochoices字段获取对应字段值 如下所示: class Area(models.Model): Area_Level = ( (0, u'全国'), (...models.IntegerField(choices=Area_Level,verbose_name='层级', null=True) object.get_level_display() 以上这篇Django模型字段属性

2.8K10

MySQLexplain结果字段介绍(1)

MySQLexplain结果字段介绍 我们在使用MySQL时候,用最多情况可能就是select语句了,当我们在一个表查找数据时候,经常会遇到查找速度比较慢情况,作为一名DBA,我也会经常遇见业务方写...而判断一条SQL语句是否会变慢最主要依据还是"执行计划"。 MySQL,可以通过explain语句来查看一个SQL执行计划。...01 id值 在一个大select语句中,每一个语句都对应一个id值,例如上面的例子,这个select 1就对应了一个id值,再来看下面这个SQL: mysql:(none) 21:49:37...,将会出现2个一样id值 02 Select_type值 select关键字对应是查询类型,如果查询类型是一般select,那么select_type字段值是simple,在上面的几个例子...,选择将子查询物化之后与外层查询进行连接查询时,该子查询对应select_type属性就是MATERIALIZED 03 table 表名称,这个比较容易理解。

2.8K20

MySQL 定义数据字段类型

MySQL定义数据字段类型对你数据库优化是非常重要MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。...关键字INT是INTEGER同义词,关键字DEC是DECIMAL同义词。 BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。...作为SQL标准扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要每个整数类型存储和范围。...LONGTEXT 0-4 294 967 295 bytes 极大文本数据 注意:char(n) 和 varchar(n) 括号 n 代表字符个数,并不代表字节个数,比如 CHAR(30)...CHAR 和 VARCHAR 类型类似,但它们保存和检索方式不同。它们最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程不进行大小写转换。

2.4K00

MySQL自增长属性

01 MySQL自增长属性锁 我们在设计表结构时候,经常会对某一列设置自增长值,它作用是可以帮助我们自动递增某一列值,自增长属性经常被设置在主键列上,原因是主键必须具有唯一性,而自动增长可以避免重复...除此之外,自增长属性还可以避免在数据插入时候,出现大量数据页分裂操作,关于这一点,后面说到索引时候,会着重介绍,现在我们只需要知道,主键一般设置成自增长即可。...关于自增长属性,这里我多唠叨一句,试想一个这个场景,如果一个表主键现在已经增长到8了,也就是id=8,此时我们删除这条记录,那么再次插入值时候,这个值会是几???...在innodb存储引擎,针对每个自增长字段都有一个自增长计数器,在对还有自增长列表进行插入操作时候,这个计数器会被初始化,在mysql,我们可以执行下面的语句来得到这个计数器的当前值: select...MySQL5.1.22版本对这种锁进行了升级,提出了一个参数innodb_autoinc_lock_mode参数来控制自增长模式,这个参数默认值是1,总共可以设置三个值0,1,2 mysql--dba_admin

2.4K30

Elasticsearch入门必备——ES字段类型以及常用属性

背景知识 在Es字段类型很关键: 在索引时候,如果字段第一次出现,会自动识别某个类型,这种规则之前已经讲过了。 那么如果一个字段已经存在了,并且设置为某个类型。...字段索引和存储 其中需要说明是: index定义字段分析类型以及检索方式 如果是no,则无法通过检索查询到该字段; 如果设置为not_analyzed则会将整个字段存储为关键词,常用于汉字短语、...而且获取独立存储字段要比从_source解析快得多,而且额外你还需要从_source解析出来这个字段,尤其是_source特别大时候。...解析 date 日期类型,该类型可以接受一些常见日期表达方式,官方文档参考。...重要参数: index分析 not_analyzed(默认) ,设置为该值可以保证该字段能通过检索查询到 no store存储 true 独立存储 false(默认)不存储,从_source解析 format

7.6K80

mysql如何修改字段类型_MySQL怎么修改字段类型?「建议收藏」

大家好,又见面了,我是你们朋友全栈君。 在MySQL,可以通过alter table语句来修改表中一个字段数据类型。...下面本篇文章就来带大家了解一下alter table语句,介绍如何修改字段类型,希望对大家有所帮助。 在MySQL,alter table语句是用于在已有的表添加、修改或删除列(字段)。...1、添加字段(列)alter table 表名 add 字段名 数据类型 示例:在表 “Persons” 添加一个名为 “Birthday” 新列,数据类型为“date”alter table Persons...alter table 表名 alter column 字段名 数据类型 示例:将表 “Persons” “Birthday” 列数据类型改为“year”alter table Persons...4、删除字段alter table 表名 drop column 字段名 示例:删除 “Person” 表 “Birthday” 列alter table Persons drop column Birthday

27.7K20
领券