SQL-Mysql表结构操作

1,117 阅读4分钟

一 前言

本篇内容是关于 基本的数据库操作,建表,表结构修改等内容;

学习本篇的基础是知识追寻者以前发布的文章:

《SQL-你真的了解什么SQL么?》

《SQL-小白最佳入门sql查询一》

《SQL-小白最佳入门sql查询二》

《SQL- 多年开发人员都不懂的插入与更新删除操作注意点》

《SQL-SQL事物操作》

《SQL-Mysql数据类型》

公众号:知识追寻者

知识追寻者(Inheriting the spirit of open source, Spreading technology knowledge;)

二 SQL 分类操作

2.1 SQL 分类

sql 对数据库的操作分为如下三种类型,如果都学会这三种SQL语言熟练对数据库操作,说明你已经对数据库登堂入室,如果再学会数据库高级操作,说明你对数据库就有一定的使用经验,如果你还学会对数据库进行优化,分表分库,读写分离等操作,说明你使用数据库已经到专家级别;

  1. DDL:数据定义语言(Data Define Language),即定义数据的结构。比如:create,drop,alter操作
  2. DML:数据管理语言(Data Manage Language),即增删改查。比如:insert,delete,update,select。这个也在之前的文章详细写过,不再提及;
  3. DCL:数据控制语言(Data Control Language),对权限、事务等的控制。比如:grant(授权)revoke(取回权限),commit,roolback等; 事物在上篇已经说明,不会在本篇提及;

2.2 数据库基操

数据库的基本操作如下,也就是我们日常使用的操作

  1. 连接数据库: mysql -h 地址 -P 端口 -u 用户名 -p 密码;

    mysql -h 192.168.0.127 -P 3306 -u root -p root
    
  2. 查看当前数据库:

    SELECT DATABASE();
    
  3. 显示用户活动线程:

    SHOW PROCESSLIST;
    
  4. 显示系统变量:

    SHOW VARIABLES;
    
  5. 显示当前时间,用户,数据库版本号

    SELECT now(), user(), version();
    
  6. 创建数据库:CREATE DATABASE[ IF NOT EXISTS] 数据库名 [数据库选项]

    数据库选项:
            CHARACTER SET 字符集名称
            COLLATE 排序规则名称
    示例:create database zszxz;        
    
  7. 删除数据库: DROP DATABASE [ IF EXISTS] 数据库名;

    drop  database zszxz;
    

2.3 建表语句

数据库表的日常操作如下

CREATE [TEMPORARY] TABLE[ IF NOT EXISTS] [库名.]表名 ( 表的结构定义 ) [ 表选项]

其中 TEMPORARY 表示临时表;中括号内容都表示可选,在正规的数据库版本管理开发会经常使用到;

字段的修饰如下 数据类型

  • 非空|空约束:[NOT NULL | NULL]
  • 默认值:[DEFAULT default_value]
  • 自动增长:[AUTO_INCREMENT]
  • 唯一键|主键:[UNIQUE [KEY] | [PRIMARY] KEY]
  • 备注:[COMMENT 'string']

表选项一般就是指定数据库引擎和字符集:

ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='顾客表';

示例

CREATE TABLE IF NOT EXISTS `customer` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `customer_name` varchar(255) DEFAULT NULL COMMENT '顾客名称',
  `gender` varchar(255) DEFAULT NULL COMMENT '性别',
  `telephone` varchar(255) DEFAULT NULL COMMENT '电话号码',
  `register_time` timestamp NULL DEFAULT NULL COMMENT '注册时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='顾客表';

2.4 修改表结构

查看所有表

SHOW TABLES

查看指定数据库的表

SHOW TABLES FROM 数据库名称;
示例:SHOW TABLES FROM zszxz;

删除表

DROP TABLE[ IF EXISTS] 表名;
示例: drop table op;

清空表(清除数据)

TRUNCATE [TABLE] 表名

复制表结构

CREATE TABLE 表名 LIKE 要复制的表名;
示例: create table op like `order`;

复制表结构和数据

CREATE TABLE 表名 [AS] SELECT * FROM 要复制的表名;
示例: CREATE TABLE op AS SELECT * FROM `order`;

常见的alter操作如下:

增加一列(追加至末尾)

alter table [数据库名.]表名 add [column] 字段 数据类型;
示例: alter table `order` add column `year` year ;

增加到第一列

alter table [数据库名.]表名 add [column] 字段 数据类型 first;

增加一列到指定字段名后

alter table [数据库名.]表名 add [column] 字段 数据类型 after 另一个字段;

修改字段名的 数据类型

alter table [数据库名.]表名称 modify [column] 字段名 新的数据类型;
示例: altert table `order` modify column `gender` tinyint;

修改表字段的数据类型,并且移动至第一列

alter table [数据库名.]表名称 modify [column] 字段名 数据类型 first;

修改表字段的数据类型,并且移动至指定字段后面

alter table [数据库名.]表名称 modify [column] 字段名 数据类型 after 另一个字段名;

修改表字段的名称

alter table [数据库名.]表名称 change [column] 旧字段名 新的字段名 数据类型;

添加主键

alter table [数据库名.]表名称 ADD PRIMARY KEY(字段名);
示例: altert table `order` add primary key(`id`)

添加唯一键

alter table [数据库名.]表名称 ADD UNIQUE [索引名] (字段名)

添加索引

alter table [数据库名.]表名称 ADD INDEX [索引名] (字段名)

删除一列

alter table [数据库名.]表名称 drop [column] 字段名;
示例:altert table `order` drop column `gender`;

删除索引

alter table [数据库名.]表名称 DROP INDEX 索引名

删除主键

alter table [数据库名.]表名称 DROP PRIMARY KEY

删除外键

alter table [数据库名.]表名称 DROP FOREIGN KEY 外键

关注知识追寻者:

tLeP2D.png