/* 一、库的管理 创建、修改、删除 二、表的管理 创建、修改、删除 创建: create 修改: alter 删除: drop */ #一、库的管理 #1、库的创建 /* 语法: create database [if not exists]库名; */ #案例:创建库Books,为了有健壮性的判断,添加一个if not exists CREATE DATABASE IF NOT EXISTS books ;
#2、库的修改
#目前新版本废弃支持修改数据库的名字,下面这个语句是不能用的,老版本可以;现在如果想修改数据库的名,可以直接找到所在磁盘的文件夹,库对应就是个文件夹名,把文件夹名改了重启数据库即可。 RENAME DATABASE books TO 新库名; #更改库的字符集 ALTER DATABASE books CHARACTER SET gbk; #3、库的删除 DROP DATABASE IF EXISTS books;
1.表的创建
2.表的修改
3.表的删除
4.表的复制
#1.表的创建 ★ /* 语法: create table 表名( 列名 列的类型【(长度) 约束】, 列名 列的类型【(长度) 约束】, 列名 列的类型【(长度) 约束】, ... 列名 列的类型【(长度) 约束】 ) */ #案例:创建表Book CREATE TABLE book( id INT,#编号 bName VARCHAR(20),#图书名 price DOUBLE,#价格 authorId INT,#作者编号 publishDate DATETIME#出版日期 ); #查看表结构 DESC book; #案例:创建表author CREATE TABLE IF NOT EXISTS author( id INT, au_name VARCHAR(20), nation VARCHAR(10) ) DESC author;
#2.表的修改 /* 语法 alter table 表名 add|drop|modify|change column 列名 【列类型 约束】; */ #①修改列名 ALTER TABLE book CHANGE COLUMN publishdate pubDate DATETIME; #②修改列的类型或约束 ALTER TABLE book MODIFY COLUMN pubdate TIMESTAMP; #③添加新列 ALTER TABLE author ADD COLUMN annual DOUBLE; #④删除列 ALTER TABLE book_author DROP COLUMN annual; #⑤修改表名 ALTER TABLE author RENAME TO book_author; DESC book; #3.表的删除 DROP TABLE IF EXISTS book_author; SHOW TABLES; #通用的写法:创建一个库或表之前先删除一下,如果想保留原来的数据就别先删除 DROP DATABASE IF EXISTS 旧库名; CREATE DATABASE 新库名; DROP TABLE IF EXISTS 旧表名; CREATE TABLE 表名(); #4.表的复制 INSERT INTO author VALUES (1,‘村上春树‘,‘日本‘), (2,‘莫言‘,‘中国‘), (3,‘冯唐‘,‘中国‘), (4,‘金庸‘,‘中国‘); SELECT * FROM Author; SELECT * FROM copy2;
#1.仅仅复制表的结构 CREATE TABLE copy LIKE author; #2.复制表的结构+数据 CREATE TABLE copy2 SELECT * FROM author; #只复制部分数据,注意此时创建的表也会只有查询出来的部分字段 CREATE TABLE copy3 SELECT id,au_name FROM author WHERE nation=‘中国‘; #仅仅复制某些字段,且必须是一个空表,不要数据。 CREATE TABLE copy4 SELECT id,au_name FROM author WHERE 0;--这里也可以写成1=2,因为0代表的false,1=2也是false,肯定查询不出数据,所以创建的表是一个空表。
原文:https://www.cnblogs.com/yangche/p/10702452.html