0

0

MySQL数据表的基本操作二:表结构查看、修改与表操作_MySQL

php中文网

php中文网

发布时间:2016-06-01 13:02:39

|

1314人浏览过

|

来源于php中文网

原创

一、查看数据表结构

1) 查看表基本结构语句 DESCRIBE

语法:DESCRIBE 表名;

示例:

mysql> DESCRIBE product;
+--------------+--------------+------+-----+---------+----------------+
| Field        | Type         | Null | Key | Default | Extra          |
+--------------+--------------+------+-----+---------+----------------+
| product_id   | int(11)      | NO   | PRI | NULL    | auto_increment |
| product_name | varchar(50)  | NO   |     | NULL    |                |
| description  | varchar(200) | YES  |     | NULL    |                |
+--------------+--------------+------+-----+---------+----------------+

语法:DESC 表名;

示例:

mysql> DESC product;
+--------------+--------------+------+-----+---------+----------------+
| Field        | Type         | Null | Key | Default | Extra          |
+--------------+--------------+------+-----+---------+----------------+
| product_id   | int(11)      | NO   | PRI | NULL    | auto_increment |
| product_name | varchar(50)  | NO   |     | NULL    |                |
| description  | varchar(200) | YES  |     | NULL    |                |
+--------------+--------------+------+-----+---------+----------------+
说明:

NULL: 表示该列是否可以存储NULL值;Key: 表示该列是否已编制索引。PRI表示是表主键的一部分;UNI表示该列是UNIQUE索引一部分;MUL表示该列中某个给定值允许出现多次;Default: 表示该列是否有默认值,如果有是多少;Extra: 表示可以获取的与给定列有关的附加信息。例如AUTO_INCREMENT等;

2) 查看表详细结构语句 SHOW CREATE TABLE

功能说明:

用来显示创建表时的语句

语法:

SHOW CREATE TABLE <表名\G>;
提示:

该语句可以用来查看创建表的详细语句;还可以用来查看存储引擎和字符编码;加上参数'\G'后,可使显示结果更加直观,易于查看;

示例:

mysql> show create table bm\G;
*************************** 1. row ***************************
       Table: bm
Create Table: CREATE TABLE `bm` (
  `id` int(11) NOT NULL,
  `name` varchar(22) DEFAULT NULL,
  `location` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `STH` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.02 sec)
二、修改数据表

1) 修改表名

语法

ALTER TABLE <旧表名> RENAME [TO] <新表名>;

示例

赣极购物商城网店建站软件系统
赣极购物商城网店建站软件系统

大小仅1兆左右 ,足够轻便的商城系统; 易部署,上传空间即可用,安全,稳定; 容易操作,登陆后台就可设置装饰网站; 并且使用异步技术处理网站数据,表现更具美感。 前台呈现页面,兼容主流浏览器,DIV+CSS页面设计; 如果您有一定的网页设计基础,还可以进行简易的样式修改,二次开发, 发布新样式,调整网站结构,只需修改css目录中的css.css文件即可。 商城网站完全独立,网站源码随时可供您下载

下载
ALTER TABLE bm RENAME department;

2) 修改字段的数据类型

语法

ALTER TABLE <表名> MODIFY <字段名> <数据类型>; 

示例

ALTER TABLE department MODIFY id VARCHAR(11);

3) 修改字段名

语法

ALTER TABLE <表名> CHANGE <旧字段名><新字段名><新数据类型>;

示例

ALTER TABLE employees CHANGE location loc VARCHAR(350);//类型可以和原来保持一样,不用修改

4) 添加字段

语法

ALTER TABLE <表名> ADD <新字段名> <数据类型>  [约束条件]  [FIRST|AFTER已存在字段名];//默认添加到最后一列后面

示例

ALTER TABLE employees ADD manager_id INT(10);
ALTER TABLE employees ADD age INT(11) NOT NULL;//非空约束
ALTER TABLE employees ADD sal FLOAT FIRST;//在表的第一列添加
ALTER TABLE employees ADD hire_date DATE AFTER manager_id;//在指定列后添加

5) 删除字段

语法

ALTER TABLE <表名> DROP <字段名>;
示例
ALTER TABLE employees DROP manager_id;
ALTER TABLE employees DROP hire_date;

6) 修改字段的排列位置

语法

ALTER TABLE <表名> MODIFY <字段1><数据类型> FIRST|AFTER <字段2>;
示例
ALTER TABLE employees MODIFY name VARCHAR(22) FIRST;//把name移动到第一列
ALTER TABLE department MODIFY location VARCHAR(350) AFTER department_id;//把location列移到department_id列之后

7) 更改表的存储引擎

MySQL支持的主要存储引擎

引擎名 是否支持
FEDERATED
MRG_MYISAM
MyISAM
BLACKHOLE
CSV
MEMORY
ARCHIVE
InnoDB 默认
PERFORMANCE_SCHEMA

语法

ALTER TABLE <表名> ENGINE=<更改后的存储引擎名>;
示例
ALTER TABLE department ENGINE=MyISAM;

8) 删除表的外键约束

语法

ALTER TABLE <表名> DROP FOREIGN KEY <外键约束名>;
示例 
ALTER TABLE employees DROP FOREIGN KEY fk_emp_dept; 

三、删除数据表

1) 删除没有被关联的表

语法

DROP TABLE [IF EXISTS] 表1,表2,...表n;

示例

DROP TABLE IF EXISTS employees; 

2) 删除被其他表关联的主表

说明:先要删除外键

示例  
mysql> create database rm_tab;
Query OK, 1 row affected (0.00 sec)

mysql> use rm_tab;
Database changed
mysql> create table department
    -> (
    -> id int(11) primary key,
    -> name varchar(22),
    -> location varchar(200)
    -> );
Query OK, 0 rows affected (0.07 sec)

mysql> create table employee
    -> (
    -> id int(11) primary key,
    -> name varchar(25),
    -> department_id int(11),
    -> salary float,
    -> constraint fk_emp_dept foreign key(department_id) references department(id)
    -> );
Query OK, 0 rows affected (0.10 sec)

mysql> drop table department;
ERROR 1217 (23000): Cannot delete or update a parent row: a foreign key constraint fails
mysql> alter table employee drop foreign key fk_emp_dept;
Query OK, 0 rows affected (0.22 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> drop table department;
Query OK, 0 rows affected (0.04 sec)

mysql> show tables;
+------------------+
| Tables_in_rm_tab |
+------------------+
| employee         |
+------------------+
1 row in set (0.00 sec)

如果您们在尝试的过程中遇到什么问题或者我的代码有错误的地方,请给予指正,非常感谢!

联系方式:david.louis.tian@outlook.com

版权@:转载请标明出处!

相关专题

更多
Word 字间距调整方法汇总
Word 字间距调整方法汇总

本专题整合了Word字间距调整方法,阅读下面的文章了解更详细操作。

2

2025.12.24

任务管理器教程
任务管理器教程

本专题整合了任务管理器相关教程,阅读下面的文章了解更多详细操作。

2

2025.12.24

AppleID格式
AppleID格式

本专题整合了AppleID相关内容,阅读专题下面的文章了解更多详细教程。

0

2025.12.24

csgo视频观看入口合集
csgo视频观看入口合集

本专题整合了csgo观看入口合集,阅读下面的文章了知道更多入口地址。

29

2025.12.24

yandex外贸入口合集
yandex外贸入口合集

本专题汇总了yandex外贸入口地址,阅读下面的文章了解更多内容。

58

2025.12.24

添加脚注通用方法
添加脚注通用方法

本专题整合了添加脚注方法合集,阅读专题下面的文章了解更多内容。

1

2025.12.24

重启电脑教程汇总
重启电脑教程汇总

本专题整合了重启电脑操作教程,阅读下面的文章了解更多详细教程。

3

2025.12.24

纸张尺寸汇总
纸张尺寸汇总

本专题整合了纸张尺寸相关内容,阅读专题下面的文章了解更多内容。

5

2025.12.24

Java Spring Boot 微服务实战
Java Spring Boot 微服务实战

本专题深入讲解 Java Spring Boot 在微服务架构中的应用,内容涵盖服务注册与发现、REST API开发、配置中心、负载均衡、熔断与限流、日志与监控。通过实际项目案例(如电商订单系统),帮助开发者掌握 从单体应用迁移到高可用微服务系统的完整流程与实战能力。

1

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 5.9万人学习

Django 教程
Django 教程

共28课时 | 2.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号