mysql相关知识总结

目录

1.建表

sql 复制代码
CREATE TABLE `test`.`table_test` (
`id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '主键id',
`day` date DEFAULT NULL COMMENT '日期',
`show_cnt` bigint(20) DEFAULT 0 COMMENT '曝光次数',
`play_time` double(20, 2) DEFAULT 0.00 COMMENT '播放时长',
`start_type` varchar(100) DEFAULT '' COMMENT '启动方式',
PRIMARY KEY (`id`),
KEY `idx_start_type` (`day`,`start_type`)
) ENGINE = InnoDB CHARSET = utf8 ROW_FORMAT=DYNAMIC COMMENT '该表用于测试,天增量';

注意:

1、表有主键,PRIMARY KEY;

2、有索引,idx_start_type;

3、各字段有字段类型

2.添加字段

sql 复制代码
ALTER TABLE `user` 
ADD COLUMN `age` INT DEFAULT 0 COMMENT '年龄',
ADD COLUMN `sex` VARCHAR(10) DEFAULT '' COMMENT '性别';

ALTER TABLE `user` ADD (
    `age`          INT DEFAULT 0 COMMENT '年龄',,
    `sex`          VARCHAR(10) DEFAULT '' COMMENT '性别'
    );

3.修改字段类型

sql 复制代码
ALTER TABLE mytable MODIFY COLUMN mycolumn INT;

4.添加索引

sql 复制代码
ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`, `column3` )

ALTER TABLE `payment` ADD INDEX idx_customer_id_staff_id(`customer_id`, `staff_id`);

ALTER TABLE  table_name ADD INDEX idx1 ( `aaa`), ADD INDEX idx2 ( `bbb`,`ccc`), ADD INDEX idx3( `ddd`);

5.遇到的问题

在创建要给表的时候遇到一个有意思的问题,提示Specified key was too long; max key length is 767 bytes,从描述上来看,是Key太长,超过了指定的 767字节限制。通常出现在尝试创建一个过长的唯一键(UNIQUE KEY)或主键(PRIMARY KEY)时。MySQL对于InnoDB存储引擎有一个索引键长度的限制,这个限制基于字符集的不同而不同。

下面是建表时的语句:

sql 复制代码
CREATE TABLE `test_table` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(1000) NOT NULL DEFAULT '',
  `link` varchar(1000) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`),
  KEY `name` (`name`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;

分析原因:

在使用utf8字符集时,每个字符可能占用3个字节,那么对于innodb表,索引键的最大长度大约为1000个字符左右(因为3072 / 3 ≈ 1024)。若字符集是utf8mb4,每个字符可能占用4个字节,所以最大长度会进一步减少到768个字符左右(3072 / 4 = 768)

解决方法:

修改索引中字段的长度,比如你的索引字段是字符串,类型是varchar(512),修改到varchar(225),或者更低,比如varchar(100),

注意:UTF-8编码:一个英文字符等于一个字节,一个中文(含繁体)等于三个字节。

相关推荐
Dxy12393102168 小时前
MySQL 连表查询更新:从理论到实践
数据库·mysql
阿丰资源9 小时前
基于Springboot+mysql的在线兼职平台(附源码)
spring boot·后端·mysql
怪祝浙9 小时前
从简单项目入手Java(学生系统)V6(Web版本 Spring Boot3 MySQL Vue3 MyBatis)
java·spring boot·mysql
噢,我明白了9 小时前
MySql数据库数据基础操作(增删改查)
数据库·mysql·增删改查
tongluowan00710 小时前
MySql中Binlog,Redolog,Undolog的应用场景及作用的时机
mysql·日志文件
振宇i10 小时前
MySQL数据库修改表结构语句
数据库·mysql
czlczl2002092510 小时前
MySQL InnoDB 加锁全解析
数据库·mysql
lifewange10 小时前
SQL Server、MySQL、Oracle 核心区别对比
数据库·mysql·oracle
重生之小比特11 小时前
【MySQL 数据库】内外连接
数据库·mysql
weixin_7042660512 小时前
MySQL到ES
数据库·mysql·elasticsearch