#第10章_创建和管理表
#1.创建和管理数据库
#1.1如何创建数据库:
#方式1:
CREATE DATABASE mytest1;#创建的此数据库使用的是默认的字符集
SHOW DATABASES;
#方式2:显示的指明了要创建的数据库的字符集
CREATE DATABASE mytest2 CHARACTER SET 'gbk';
SHOW CREATE DATABASE mytest2;
#方式3:如果创建的数据库已经存在,就创建不成功,但是不会报错
#如果不存在,就创建成功
CREATE DATABASE IF NOT EXISTS mytest2 CHARACTER SET 'utf8';#(推荐使用)
#1.2管理数据库:
#查看当前连接中的数据库有哪些
SHOW DATABASES;
#切换数据库:
USE atguigudb;
#查看当前数据库中保存的表
SHOW TABLES;
#查看当前使用的数据库:
SELECT DATABASE() FROM DUAL;
#查看指定数据库下面保存的表:
SHOW TABLES FROM mysql;
#1.3:修改数据库
#更改数据库的字符集:
SHOW CREATE DATABASE mytest2;
ALTER DATABASE mytest2 CHARACTER SET 'utf8';
#1.4删除数据库:
#方式1:
DROP DATABASE mytest1;
#方式2:
DROP DATABASE IF EXISTS mytest1;
#2.如何创建数据表?
USE atguigudb;
SHOW CREATE DATABASE atguigudb;
SHOW TABLES;
#方式1(白手起家):
CREATE TABLE IF NOT EXISTS myemp1(
id INT,
emp_name VARCHAR(15),
hire_date DATE
);
DESC myemp1;
SHOW CREATE TABLE myemp1;#如果创建表时没指明使用的字符集,就默认使用表所在数据库的字符集
#方式2(继承):基于现有的表去创建新的表,
CREATE TABLE myemp2
AS
SELECT employee_id,last_name,salary
FROM employees;
DESC myemp2;
SELECT * FROM myemp2;
#说明1:查询语句中的字段的别名可以作为新创建的表的字段的名称。
#说明2:可以使用任何的SELECT语句
#3修改表--->ALTER TABLE
#3.1添加一个字段
DESC myemp1;
ALTER TABLE myemp1
ADD salary DOUBLE(10,2);#默认添加到最后一个位置。
ALTER TABLE myemp1
ADD phone_number VARCHAR(20) FIRST;
ALTER TABLE myemp1
ADD email VARCHAR(20) AFTER emp_name;
#3.2修改一个字段:数据类型 长度 默认值
ALTER TABLE myemp1
MODIFY emp_name VARCHAR(25);
ALTER TABLE myemp1
MODIFY emp_name VARCHAR(35) DEFAULT 'aaa';
#3.3重命名一个字段
ALTER TABLE myemp1
CHANGE salary mouth_salary DOUBLE
ALTER TABLE myemp1
CHANGE email my_email VARCHAR(50);
#3.4删除一个字段
ALTER TABLE myemp1
DROP COLUMN my_email;
#4.重命名表
#方式1:
RENAME TABLE myemp1
TO myemp11;
DESC myemp11
#方式2:
ALTER TABLE myemp2
RENAME TO myemp12;
#5.删除表
#将这个表结构删除掉,同时也删除数据,释放表空间
DROP TABLE IF EXISTS myemp12;
#6.清空表
#清空表:TRUNCATE TABLE#将这个表结构保留,删除数据,释放表空间
SELECT * FROM employees_copy;
#7.DCL中的 COMMIT ROLLBACK
#COMMIT:提交数据。一旦执行COMMIT,则数据就被永久的保存在了数据库中,意味着数据不能回滚。
#ROLLBACK:回滚数据。一旦执行Rollback,则可以实现数据的回滚。回滚到最近的一的COMMIT之后。
#8.TRUNCATE TABLE 和DELETE FROM
# 相同点:都可以实现对表中所有数据的删除,同时保留表结构。
# 不同点:
#TRUNCATE TABLE:一旦执行此操作,表中的数据全部清除。同时,数据时不可以回滚的。
#DELETE FROM:一旦执行此操作,表中的数据可以全部清除(不带WHERE就行)。同时,数据时是可以回滚的。
/*
9.DDL 和 DML的说明
DDL一旦执行就不可以回滚。指令SET autocommit = FALSE对DDL无效(因为在DDL之后就
执行了一次COMMIT操作 )
DML 的操作的默认情况,一旦执行,也是不可以回滚的。但是如果在DML执行之前,
执行了SET autocommit = FALSE,则执行的操作就可以实现回滚。
*/
#演示:DELETE FROM
SELECT *
FROM myemp11;
##############练习##################
#创建一个数据库
CREATE DATABASE IF NOT EXISTS test01_office CHARACTER SET 'utf8';
USE test01_office;
CREATE TABLE dept01(
id INT(7),
`name` VARCHAR(25)
);
DESC dept01;
CREATE TABLE dept02
AS
SELECT *
FROM atguigudb.departments;
DESC dept02;
CREATE TABLE emp01(
id INT(7),
first_name VARCHAR(25),
last_name VARCHAR(25),
dept_id INT(7)
);
ALTER TABLE emp01
MODIFY last_name VARCHAR(50);
CREATE TABLE emp02
AS
SELECT *
FROM atguigudb.employees;
SHOW TABLES;
DROP TABLE emp01;#无法回滚
#alter table emp02 rename to emp01;
RENAME TABLE emp02 TO emp01;
ALTER TABLE emp01 ADD test_column VARCHAR(10);
DESC emp01;
ALTER TABLE dept02 ADD test_cloumn VARCHAR(10);
ALTER TABLE emp01
DROP COLUMN IF EXISTS dept_id;
####################练习2###################
CREATE DATABASE IF NOT EXISTS test02_market CHARACTER SET 'utf8';
USE test02_market;
SHOW DATABASE test02_market;
CREATE TABLE IF NOT EXISTS customers(
c_num INT,
c_name VARCHAR(50),
c_contact VARCHAR(50),
c_city VARCHAR(50),
c_birth DATE
);
DESC customers;
ALTER TABLE customers
MODIFY c_contact VARCHAR(50) AFTER c_birth;
ALTER TABLE customers
MODIFY c_name VARCHAR(70);
ALTER TABLE customers
CHANGE c_contact c_phone VARCHAR(50);
ALTER TABLE customers
ADD c_gender CHAR(1) AFTER c_name;
RENAME TABLE customers
TO customers_info;
DESC customers_info;
ALTER TABLE customers_info
DROP COLUMN c_city;
第10章_创建和管理表
最新推荐文章于 2023-09-07 15:19:48 发布