温馨提示×

温馨提示×

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

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

MySQL数据库及表的管理

发布时间:2020-09-04 00:44:03 来源:网络 阅读:991 作者:没有响应 栏目:数据库



库管理


1.创建数据库


mysql> help create database;

CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name
    [create_specification] ...
create_specification:
    [DEFAULT] CHARACTER SET [=] charset_name
  | [DEFAULT] COLLATE [=] collation_name



MySQL数据库及表的管理



MySQL数据库及表的管理




2.删除数据库


mysql> help drop database;

DROP {DATABASE | SCHEMA} [IF EXISTS] db_name


MySQL数据库及表的管理



3.修改数据库的字符集和排序字符以及数据字典


mysql> help alter database;

ALTER {DATABASE | SCHEMA} [db_name]
    alter_specification ...
ALTER {DATABASE | SCHEMA} db_name
    UPGRADE DATA DIRECTORY NAME

alter_specification:
    [DEFAULT] CHARACTER SET [=] charset_name
  | [DEFAULT] COLLATE [=] collation_name



表管理


1.创建表


(a)第一种方式

CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
    (create_definition,...)
    [table_options]
    [partition_options]

[create_definition]
     字段的定义:字段名、类型和类型修饰符;
     键、索引和约束; --> 键是索引,索引未必是键;键可以表示约束
          primary key、unique key、foreign key、check(条件约束)
          {index|key}

[table_options]
     engine [=] engine_name  ---> 注1
     AUTO_INCREMENT [=] value 指定AUTO_INCREMENT的起始值
     [DEFAULT] CHARACTER SET [=] charset_name 指定默认字符集
     CHECKSUM [=] {0 | 1} 是否使用校验值
     [DEFAULT] COLLATE [=] collation_name 排序规则
     COMMENT [=] 'string' 注释
     DELAY_KEY_WRITE [=] {0 | 1} 是否启用键延迟写入 (索引降低了写操作)
     ROW_FORMAT [=] {DEFAULT(默认)|DYNAMIC(动态)|FIXED(静态)|COMPRESSED(压缩)|REDUNDANT(冗余)|COMPACT(紧致)} 表格式
     TABLESPACE tablespace_name [STORAGE {DISK|MEMORY|DEFAULT}] 表空间  ---> 注2


(b)第二种方式(复制表数据)

 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
    [(create_definition,...)]
    [table_options]
    select_statement


MySQL数据库及表的管理


MySQL数据库及表的管理


(c)第三种方式(复制表结构)

CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
    { LIKE old_tbl_name | (LIKE old_tbl_name) }


MySQL数据库及表的管理


2.查看表的状态信息

show table status like ‘table_name’



3.删除表

DROP [TEMPORARY] TABLE [IF EXISTS]
    tbl_name [, tbl_name] ...
    [RESTRICT | CASCADE]



4.修改表

ALTER [ONLINE | OFFLINE] [IGNORE] TABLE tbl_name
    [alter_specification [, alter_specification] ...]


(a)修改字段定义

插入新字段:
    ADD [COLUMN] col_name column_definition
        [FIRST | AFTER col_name ]
删除字段
    DROP [COLUMN] col_name
修改字段
    修改字段名称
        CHANGE [COLUMN] old_col_name new_col_name column_definition
            [FIRST|AFTER col_name]
    修改字段类型及属性等
        MODIFY [COLUMN] col_name column_definition
            [FIRST | AFTER col_name]



(b)表改名

mysql > rename table to old_name TO new_name


(c)修改存储引擎

engine =


(d)指定排序标准的字段

ORDER BY col_name [, col_name] ...

 

(e)转换字符集及排序规则

CONVERT TO CHARACTER SET charset_name [COLLATE collation_name]



注1

mysql > show engine


MySQL数据库及表的管理


MySQL数据库及表的管理


MySQL数据库及表的管理


MySQL数据库及表的管理


注2

TABLESPACE tablespace_name [STORAGE {DISK|MEMORY|DEFAULT}] 表空间

     MyISAM表,每个表有三个文件,都位于数据库目录中

        tb_name.frm:表结构定义

        tb_name.MYD:数据文件

        tb_name.MYI:索引文件

     InnoDB表,有两种存储方式

        1.默认:每表有一个独立文件和一个多表共享的文件

        tb_name.frm:表结构的定义,位于数据库目录中

        ibdata#:共享的表空间文件,默认位于数据目录(datadir指向的目录)中

        图

        2.独立的表空间文件:

        每表有一个表结构文件tb_name.frm

        一个独立的表空间文件 tb_name.ibd(数据和索引)

            (a)应该修改innodb_file_per_table为ON 

            (b)可以通过修改配置文件永久有效在 [mysqld]段

               innodb_file_per_table=ON


MySQL数据库及表的管理


MySQL数据库及表的管理




向AI问一下细节

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

AI