第10章_创建和管理表

#第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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值