db2版本查看命令linux linux查看db2表结构_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 外键