温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL数据表操作的方法有哪些

发布时间:2022-05-05 09:19:41 来源:亿速云 阅读:108 作者:iii 栏目:开发技术

这篇文章主要介绍“MySQL数据表操作的方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL数据表操作的方法有哪些”文章能帮助大家解决问题。

    一、创建数据表

    1、基本语法

    create table 表名 (
        字段名 字段类型 [字段属性],
        字段名 字段类型 [字段属性],
        ...
    ) [表选项];

    需要注意:表需要放在对应的数据库下面

    2、创建方式一

    -- 先选择数据库
    use mydatabase;
    -- 创建数据表
    create table user(
        name varchar(10)
    );

    3、创建方式二

    -- 直接将数据表挂到数据库下
    create table mydatabase.user(
        name varchar(10)
    );

    4、表选项

    • Engine 存储引擎

    • Charset 字符集

    • Collate 校对集

    指定表的字符集

    create table user(
        name varchar(10)
    ) charset utf8;

    5、复制已有表结构

    create table 表名 like 表名;
    -- eg 从test数据库复制表
    create table user like test.user;

    二、显示数据表

    -- 显示所有表
    mysql> show tables;
    +----------------------+
    | Tables_in_mydatabase |
    +----------------------+
    | t_author             |
    | user                 |
    +----------------------+
    -- 显示匹配表
    mysql> show tables like '%author';
    +--------------------------------+
    | Tables_in_mydatabase (%author) |
    +--------------------------------+
    | t_author                       |
    +--------------------------------+

    三、显示表结构

    基本语法:

    desc 表名(常用);
    describe 表名;
    show columns from 表名;

    示例:

    mysql> desc user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | name  | varchar(10) | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+
    1 row in set (0.00 sec)
    mysql> describe user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | name  | varchar(10) | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+
    1 row in set (0.01 sec)
    mysql> show columns from user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | name  | varchar(10) | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+
    1 row in set (0.01 sec)

    字段含义:

    Field    字段名
    Type     字段类型
    Null     是否允许为空
    Key      索引
    Default  默认值
    Extra    额外的属性

    四、显示表创建语句

    基本语法:

    show create table 表名;

    示例:

    mysql> show create table user;
    +-------+----------------+
    | Table | Create Table   |
    +-------+----------------+
    | user  | CREATE TABLE `user` (
      `name` varchar(10) COLLATE utf8mb4_general_ci DEFAULT NULL
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci |
    +-------+----------------+
    1 row in set (0.00 sec)

    语句结束符:

    • ; \g 效果一样,字段在上,数据在下

    • \G 字段在左,数据在右

    mysql> show create table user\G
    *************************** 1. row ***************************
           Table: user
    Create Table: CREATE TABLE `user` (
      `name` varchar(10) COLLATE utf8mb4_general_ci DEFAULT NULL
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci
    1 row in set (0.00 sec)

    五、设置表属性

    • engine

    • charset

    • collate

    -- 基本语法
    alter table 表名 表选项 [=] 值;
    -- eg 修改表的字符集
    alter table user charset gbk;

    如果数据表已经有数据,不要轻易修改表属性

    六、修改表结构

    1、修改表名

    --基本语法
    rename table 旧表名 to 新表名;
    -- eg:
    rename table user to tb_user;

    2、新增字段

    -- 基本语法
    alter table 表名 add [column] 字段名 字段类型 [字段属性] [位置first/after 字段名];
    mysql> desc user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | name  | varchar(10) | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+
    -- 给学生表新增age字段,默认加到表的最后
    mysql> alter table tb_user add age int;
    mysql> desc tb_user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | name  | varchar(10) | YES  |     | NULL    |       |
    | age   | int(11)     | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+
    
    -- 在最前面增加一个id字段
    mysql> alter table tb_user add id int first;
    mysql> desc tb_user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | id    | int(11)     | YES  |     | NULL    |       |
    | name  | varchar(10) | YES  |     | NULL    |       |
    | age   | int(11)     | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+

    字段位置:

    first          放在最前名
    alter 字段名    放在某个字段后面

    3、修改字段名

    -- 基本语法
    alter table 表名 change 旧字段名 新字段名 字段类型 [字段属性] [新位置]
    -- 将age字段修改为old
    mysql> alter table tb_user change age old int;
    mysql> desc tb_user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | id    | int(11)     | YES  |     | NULL    |       |
    | name  | varchar(10) | YES  |     | NULL    |       |
    | old   | int(11)     | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+

    4、修改字段属性

    -- 基本语法
    alter table 表名 modify 字段名 新字段类型 [新字段属性] [新位置]
    -- eg 将name的长度由10修改为20
    mysql> alter table tb_user modify name varchar(20);
    
    mysql> desc tb_user;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | id    | int(11)     | YES  |     | NULL    |       |
    | name  | varchar(20) | YES  |     | NULL    |       |
    | old   | int(11)     | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+

    5、删除字段

    -- 基本语法
    alter table 表名 drop 字段名
    -- eg 删除old字段
    alter table tb_user drop old;

    七、删除表结构

    -- 基本语法, 可以同时删除多个表
    drop table 表名 [, 表名...];
    -- eg: 删除 tb_user表
    mysql> drop table tb_user;
    
    mysql> show tables;
    +----------------------+
    | Tables_in_mydatabase |
    +----------------------+
    | t_author             |
    +----------------------+

    关于“MySQL数据表操作的方法有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI