百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

MySQL 修改表alter语法(mysql 修改表内容)

wuantov 2025-07-24 22:35 5 浏览

修改表结构ALTER TABLE

Alter TABLE 数据表名 alter_spec[,alter_spec]…

ALTER TABLE tbl_name

ADD [COLUMN] create_definition [FIRST | AFTER column_name ] 增加字段名

or ADD INDEX [index_name] (index_col_name,...) 增加普通索引

or ADD [CONSTRAINT [symbol]] PRIMARY KEY (index_col_name,...) 增加主键索引

or ADD UNIQUE [index_name] (index_col_name,...) 增加唯一索引

or ADD FULLTEXT [INDEX|KEY] [index_name] (index_col_name,...) 增加全文索引

or ADD [CONSTRAINT [symbol]] FOREIGN KEY [index_name] (index_col_name,...) reference_definition 增加外键索引

or ALTER [COLUMN] col_name {SET DEFAULT literal | DROP DEFAULT} 设置/删除字段的默认值

or CHANGE [COLUMN] old_col_name create_definition 修改字段类型

or MODIFY [COLUMN] create_definition 修改字段类型

or DROP [COLUMN] col_name 删除字段

or DROP PRIMARY KEY 删除主键

or DROP FOREIGH KEY fk_symbol 删除外键

or DROP INDEX index_name 删除普通索引、唯一索引、全文索引

or RENAME [AS] new_tbl_name 更改表名


? create table 查询帮助语句

以上所有[COLUMN]是固定的可选语句, 不是指表中列的变量

ALTER TABLE语句允许指定多个动作, 其动作间使用逗号分隔, 每个动作表示对表的一个修改。

ALTER TABLE 表名 ADD 字段名 <建表语句> [FIRST | AFTER 列名]

如果没指定FIRST和AFTER,则在列尾添加一列

ALTER TABLE users ADD email VARCHAR(30) NOT NULL;

ALTER TABLE users ADD name VARCHAR(30) NOT NULL FIRST;

ALTER TABLE users ADD height DOUBLE NOT NULL DEFAULT '0.00' AFTER userPass;

实例:

ALTER TABLE `cmf_anchor` ADD `near_channel_endtime` int(11) UNSIGNED NOT NULL DEFAULT '0' COMMENT '最近直播结束的时间' AFTER `near_channel_time`;

删除字段

ALTER TABLE `draws` drop COLUMN `prev_balance`;

增加主键索引

ALTER TABLE tbl_name ADD PRIMARY KEY (index_col_name,...)

alter table categories add primary key (categoryId);

括号前可留可不留空格;如:alter table categories add primary key(categoryId);也是正确的

增加唯一索引

ALTER TABLE tbl_name ADD UNIQUE [index_name] (index_col_name,...)

alter table books add unique (bookName);

增加普通索引

ALTER TABLE tbl_name ADD INDEX [index_name] (index_col_name,...)

alter table carts add index ind (userId,bookId);

增加全文索引

ALTER TABLE tbl_name ADD FULLTEXT (index_col_name,...)

alter table books add fulltext (detail);

添加外键索引

alter table 表名1 add foreign key (字段1,[,字段名2,...]) references 表名2(字段1,[,字段名2,...]);

alter table books add foreign key (userId) references bookstype(id);

alter table books add constraint id_check foreign key(id) references bookstype(id) on delete cascade on update cascade;

constraint 是固定的可选语句 id_check 是外键索引名

设置/删除字段的默认值

ALTER [COLUMN] col_name {SET DEFAULT literal | DROP DEFAULT}

alter table film alter column val_tpl set default 5;

alter table film alter val_tpl set default 5;

alter table film alter column val_tpl drop default;

alter table film alter val_tpl drop default;

ALTER TABLE 表名 CHANGE(MODIFY) 列表 <建表语句>

此语句也可以修改数据字段属性如UNSIGNED、ZEROFILL、AUTO_INCREMENT、NULL和NOT NULL、DEFAULT

ALTER TABLE users MODIFY telNo INT UNSIGNED DEFAULT '0';

ALTER TABLE users CHANGE telNo telNo INT UNSIGNED DEFAULT '0';

CHANGE除了更改类型外还能更改列名, 而MODIFY不能实现这个功能

ALTER TABLE users CHANGE 旧表名 新表名

删除主键:

alter table 表名 drop primary key; #每一个表最多只能有一个主键

alter table books drop primary key;

删除外键:

alter table 表名 drop foreign key 外键名;

注意:外键名(symbol)不等于索引名(index_name);

外键名(symbol)查询:show create table 表名

mysql> show create table books

......

CONSTRAINT `books_ibfk_1` FOREIGN KEY (`dage_id`) REFERENCES `dage` (`id`)

......

其中:books_ibfk_1为外键名, 外键名(索引名)是定义在子表上

索引名(index_name)查询: show index from 表名

此语句只能查询普通索引、唯一索引、全文索引的索引名(index_name)

alter table books drop foreign key userId;

删除索引:(用于删除普通索引、唯一索引、全文索引)

alter table 表名 drop index 索引名;

alter table books drop index ind;

删除索引必须先要知道索引名

查询索引名的方法有两种:

show create table 表名;

show index from 表名;

删除索引另一种方法

DROP INDEX index_name ON tal_name

INDEX:是固定格式, 不能省略, 除了可以删除普通索引,还可删除唯一索引、全文索引

index_name: 索引名

tab_name: 表名

注意: 在建表时如何未指定索引名时, 默认情况下索引名等于字段名

查询索引名的方法:show index from tab_name;

drop index detail on books #可用于删除普通索引、唯一索引、全文索引(其中detail是索引名)

实际上, 此语句同样被映射为一条"alter table"的删除索引语句。

删除主键索引和外键索引只能采用alter table tab_name drop语句

alter table books drop primary key; (如果该字段名有auto_increment属性,则删除主键失败)

alter table books drop foreign key 外键名;(外键名通过"show create table 表名"查询)

当然也可以通过查询索引名后, 再去删除索引

show index from mytable; //mytable 是表名

alter table mytable drop index key_name; //key_name是上表查出的索引名

drop index key_name on mytable //删除键名的另一种方法

如果主键索引有auto_increment属性,应先通过alter table tbl_name modify语句修改;

如alter table books modify bookId int(10) not null;

然后才能删除主键索引:alter table books drop primary key;

修改表名

ALTER TABLE 旧表名 RENAME AS 新表名

alter table books rename as book;

修改表选项:

alter table 表名 选项名1=选项值1 选项名2=选项值2,...;

表选项:

engine = 存储引擎名, 默认是InnoDB(可以不写)

auto_increment = 自增长值的起始值, 默认是1(可以不写), 表中已经删除的记录行, 可以通过此参数恢复起始值。

charset = 字符集名称(编码名称), 默认是数据库上设定的编码(可以不写)

comment = '表的说明', 可以不写;

alter table books charset=utf8 collate=utf8_general_ci;

alter table books AUTO_INCREMENT=0; 修改自增长的起始值


修改数据库字符集和校对规则:

alter database 数据库名 [charset =新的要使用的编码] [collate = 新的要使用的排序规则];

alter database shop charset=utf8 collate=utf8_general_ci;

删除表

DROP TABLE [IF EXISTS] 表名

drop table if exists bookes;

修改表结构(ALTER TABLE语句), 修改字段类型, 存在的列的数据不会丢失, 而新添加的字段值为NULL;

实际在开发中, 数据表是设计好的, 数据是无价的, 我们需要做的就只是添加而已;

mysql> alter table sc_student_info add primary key (id);

ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

错误解析:数据表中有重复的数据, 需要删除数据后, 才能添加索引;

相关推荐

SQL关联各种JOIN傻傻分不清楚,读这一篇就够了

在关系型数据库中支持多表关联,不同场景下通过不同join方式让分布在不同表中的数据呈现在同一个结果里。熟练使用sql联合查询是日常开发的基础工作。为了方便演示讲解,假设有两个表,一张是保存学生踢足球的...

MyBatis的SQL执行流程不清楚?看完这一篇就够了

推荐学习真香警告!Alibaba珍藏版mybatis手写文档,刷起来全网独家的“MySQL高级知识”集合,骨灰级收藏,手慢则无前言MyBatis可能很多人都一直在用,但是MyBatis的SQL执行...

SQL优化这十条,面试的时候你都答对了吗?

尽量不要在要给在SQL语句的where子句中使用函数,这样会使索引失效。如果已经确定查询结果只有一条数据(当表中数据的该字段是唯一的),在查询SQL末尾增加limit1,这样MySQL的查询执行引...

SQL查询Excel结果数据还可这样输出到窗体控件ListBox和ListView

上一期作品,我们分享了通过SQL查询Excel的结果数据输出到Excel自身的工作表区域。大家估计应该感觉到了SQL查询的强大功能,它对精确或模糊查询均无畏惧,优点是查询检索效率高,将查询结果输出的形...

数据库|SQLServer数据库:模糊查询的三种情况

哈喽,你好啊,我是雷工!就是字面意思,当数据库的查询条件并不是十分具体时就用到模糊查询,比如查询姓氏为雷的人名,就需要从姓名列模糊查询。01like关键字查询当使用like关键字进行查询时,字段中的...

数据库教程-SQL Server多条件模糊查询

表单查询是以数据存储管理为基础的信息管理系统各业务功能实现的基础,也是数据库CRUD操作的重点与难点,尤其是多表连接查询、条件查询、分组查询、聚合函数等的综合应用。本文以某一比赛样式要求为基础,对数据...

如何利用教育网站源码成功搭建在线教育网站

如今是一个信息化时代,人们都想接受各种各样的教育,在线教育也就因此发展了起来,并且逐渐成为了一种趋势。而成熟的在线教育网站皆是由高质量的教育网站源码搭建而成的。如何利用教育网站源码成功搭建在线教育网站...

宝塔搭建WordPress跨境电商外贸商城模板汉化woodmart7.5.1源码

大家好啊,欢迎来到web测评。本期给大家带来一套php开发的WoodmartV7.5.1汉化主题|跨境电商|外贸商城|产品展示网站模板WordPress主题,是wordpress开发的。上次是谁要的系...

小狐狸ChatGPT付费创作系统V2.4.7全开源版 (vue全开源端)

测试环境:Nginx1.20+PHP7.4+MySQL5.7本版本为官方的最新开源包对应V2.4.7版本,包含了前后端所有开源包,是目前最新全开源版本,需要二开的这部分朋友也有选择了,如果不需要二...

php宝塔搭建部署thinkphp红色大气装修公司官网php源码

大家好啊,欢迎来到web测评。本期给大家带来一套php开发的thinkphp红色大气装修公司官网源码,上次是谁要的系统项目啊,帮你找到了,还说不会搭建,让我帮忙录制一期教程,趁着今天有空,简单的录制测...

php宝塔搭建免登录积分商城系统php源码

大家好啊,欢迎来到web测评。本期给大家带来一套php开发的免登录积分商城系统php源码,上次是谁要的系统项目啊,帮你找到了,还说不会搭建,让我帮忙录制一期教程,趁着今天有空,简单的录制测试了一下,部...

零代码搭建接口收费平台——接口大师YesApi

主流的API接口收费模式目前各大API接口平台,采用的收费模式主可以分为:免费接口、免费试用、接口流量套餐、先充值后按量计费的模式。例如,聚合数据的API收费模式是:按接口流量套餐。例如身份证二要素...

php宝塔搭建部署实战抽奖系统开源php源码

大家好啊,我是测评君,欢迎来到web测评。本期给大家带来一套抽奖系统开源php源码。感兴趣的朋友可以自行下载学习。技术架构PHP5.4+nginx+mysql5.7+JS+CSS+...

【推荐】一款开源个人与企业私有化部署使用的在线知识库管理平台

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍zyplayer-doc是一款基于Java+Vue开源、专注于个人与企业私有化部署使用的在线知识库管...

网上的付费文档无法下载?这几个方法10秒搞定,任意免费复制

工作或者学习过程中,我们很多时候需要在网上找资料,但是想要的资料却要付费或者提示无法下载怎么办?别怕,这几个方法,让你10秒就能搞定付费文档,任意复制。1.打印界面复制遇到文档需要付费或者无法复制的...