注:汉化就是翻译的意思。觉得汉化词比较高大上。
数据库使用的基本流程
1.创建数据库
2.明确好表结构(三范式)
3.设置完整性约束
4.操作数据
DDL
单词汇总 show create drop alter(建议一定背过)
关于数据库-->用库 use 查库show 创库create 删库drop
关于数据表-->查表 show desc describe 创表create 删表 drop truncate 修改表alter
使用库;
格式--->use 数据库名;
例1:use books;汉化:使用books数据库;
创建数据库
格式--->create database 数据库名;
例1:create database `book`;汉化:创建一个book的数据库;
例2:create database book; 汉化:创建一个book的数据库;
例3:create database if not exists book; 汉化:创建一个book数据库,当这个数据库不存在的时候;
删除数据库
格式--->drop database 数据库名;
例1:drop database `people`; 汉化:删除一个people数据库;
例2:drop database people; 汉化:删除一个people数据库;
例3:drop database if exists people; 汉化:删除一个数据库,当这people个数据库存在的时候。
展示所有数据库名称(常用)
格式-->
例1:show databases; 汉化:查看所有数据库名称
查看表结构(常用)
desc 表名;
例1:desc book; 汉化:查看book的表结构;
例2:desc `book`;汉化:查看book的表结构;
注意:查看的一个表中的字段的属性;如何选中库就不要使用库这个命令了。
查看表结构的第二种方式
格式1-->show columns from 表名;
格式2-->show columns from 表名 from 库名;
例1:
第一步:先使用库 use
第一步:先使用库 use show columns from book; 汉化:查看表books库里面book整体结构;
例2:
第一步:先使用库 use
第二步:show columns from `book`; 汉化:查看表books库里面book整体结构;
例3:
show columns from book from books; 汉化:查看表books库里面book整体结构;
注意:它的用法和describe相似,可以说”show columns from 表名;“简化版。
查看表结构的第三种方式(可以直接查看字段)
格式1-->describe 表名;
格式2-->describe 表名 字段名;
例1:
第一步:先使用库 use
第二步:describe book; 汉化:查看特定book的表结构;
例2:
第一步:先使用库 use
第二步:describe book book_id;汉化:查看特定book的book_id的表结构
查看表结构的第四种方式(查看创建表的过程)(推荐!)
格式1-->show create table 表名;
例1:
第一步:先使用库 use
第二步:show create table book; 汉化:查看创建book过程的表结构;
注意:查询指定的库的字符集 (字符集默认都是utf8)
创建数据表
格式--->create table 数据表名;
例1:create table `book`;汉化:创建一个book的数据表;
例2:create table book; 汉化:创建一个book的数据表;
例3:create table if not exists book; 汉化:创建一个book数据表,当这个数据表不存在的时候;
删除数据表(不经常用)
格式--->drop table 数据表名;
例1:drop table `people`; 汉化:删除一个people数据表;
例2:drop table people; 汉化:删除一个people数据表;
例3:drop table if exists people; 汉化:删除一个数据表,当这people个数据表存在的时候。
清空表数据(不经常用而且注意!)(截断表)
格式-->truncate table 表名;
例1:truncate table `book`;汉化:清空book里面的数据;
例2:truncate table book; 汉化:清空book里面的数据;
注意:truncate不能与where一起使用。
警告:当你要删除部分记录或者有可能会后悔的话;
更多:但不能回滚,不会触发触发器;
修改数据库字符集(常用)
格式-->alter database 数据库表名 属性;
alter database people charset utf8; 汉化:更改数据库的字符集为utf8;
修改表
修改的字段类型
格式1-->alter table 表名 modify 当前的字段名称 新的字段类型;
例1:alter table book modify book_id varchar(11); 汉化:将book表里面book_id的字段原来int的类型改变成varchar(11)类型。
修改的字段名称
格式2-->alter table 表名 change 旧字段名称 新的字段名称 以前的数据类型;
例1:alter table book change book_id books_id int; 汉化:将book表里面book_id的字段改为books_id,原来类型不变。
注意:
相同点:都是用来改变字段的属性,change和modify执行成功后都会这本次设置的属性替换字段原属性,请注意是【替换】;
不同点:重命名字段只能使用change
添加一个新的字段
格式1-->alter table 表名 add 字段名称 字段类型;
例1:alter table book add book_name vachar(6); 汉化:向book表中添加book_name字段,且类型为vachar(6);
复制一张表
格式-->create table 新表名 like 旧表名;
例1:create table letter like book; 汉化:把book旧表名更换为letter新表名;
第一种重命名表
修改表名, to或as都可以,也以省略掉
格式1-->alter table 表名 rename [to|as] 新表名
例1:alter table book rename to book2; 汉化:将book旧表名更改到books新表名;
例2:alter table book rename as book2; 汉化:将book旧表名更改到books新表名;
第二种重命名表
格式1-->rename table 表名 to 新表名; 这里面的to不可以省略
例1:rename table book to book2; 汉化:将book旧表名更改到books新表名;
第三种添加外键
格式1-->alter table 主表 add constraint fk_主表名_从表名 foreign key 主表的字段 references 从表(从表字段) ;
例1:alter table book add constraint fk_book_people foreign key people_id references people(people_id);
汉化:给book表里面people_id字段添加外键另外一张people表的people_id字段。
----------------------------------------------------------------------
有些因为mysql版本而不兼用问题,大家可以留言提提意见。