032-MySQL、创建表、修改表、约束类型、

1. MySQL与Oracle的区别

MySQL与Oracle有哪些区别?

①实例区别

MySQL 是轻量型数据库,开源免费。Oracle 是收费的而且价格非常高。

MySQL 一个实例可以操作多个库,而 Oracle 一个实例只能对应一个库。

MySQL 安装完后 300M 而 Oracle 有 3G 左右。

②操作区别

主键: MySQL 一般使用自动增长类型,而 Oracle 则需要使用序列对象。

单引号的处理: MySQL 里可以用双引号包起字符串,ORACLE 里只可以用单引号包起字符串。

分页的 SQL 语句: MYSQL 用 LIMIT,而 Oracle 需要使用内建视图和 rownum 伪列。

事务处理:MySQL 默认是自动提交,而 Oracle 默认不自动提交,需要用户 CTL 语言进行事务提交。

2. 创建数据库

(1) 在MySQL中创建数据库语句的语法结构是什么?

CREATE DATABASE 数据库名 DEFAULT CHARACTER SET 字符编码;

(2) 在MySQL中查看数据库的语句是什么?

show databases;

(3) 在MySQL中查看数据库编码的语句是什么?

select schema_ name,default_character_set_name from information_ schema.schemata where schemaname = ‘数据库名’;

(4) 删除数据库的语句是什么?

Drop database 数据库名称;

3. 选择数据库

在MySQL中选择数据库的语句是什么?

use 数据库名;

4. MySQL数据类型

(1) 在MySQL中有哪些数据类型?

①数值类型

Tinyint(m)-1个字节,范围(-128-127)

Smallint(m)-2个字节,范围(-32768-32767)

Mediumint(m)-3个字节,范围(-8388608-8388607)

Int(m)-4个字节,范围(-2147483648-2147483847)

Bigint(m)-8个字节,范围(+—9.22*10的18次方)

数值类型中的长度 m 是指显示长度,并不表示存储长度,只有字段指定 zerofill 时有用。

例如:int(3),如果实际值是 2,如果列指定了 zerofill,查询结果就是 002,左边用 0 来

填充。

②浮点型

Float(m,d)-单精度浮点型,8位精度(4字节),m:总个数,d:小数位。

Double(m,d)-双精度浮点型,16位精度(8字节),m:总个数,d:小数位。

③字符串型

Char(n)-固定长度,最多255个字符

Varchar(n)-可变长度,最多65535个字符

Tinytext-可变长度,最多255个字符

Text-可变长度,最多65535个字符

Mediumtext-可变长度,最多2的24次方-1个字符

Longtext-可变长度,最多2的32次方-1个字符

④日期类型

Date-日期‘年-月-日’

Time-时间‘时:分:秒’

Datetime-日期时间‘年-月-日 时:分:秒’

Timestamp-自动存储记录修改时间

⑤二进制数据

BLOB 和 TEXT 存储方式不同,TEXT 以文本方式存储,英文存储区分大小写,而 Blob是以二进制方式存储,不分大小写。

BLOB 存储的数据只能整体读出。

TEXT 可以指定字符集,BLOB 不用指定字符集。

(2) CHAR与VARCHAR有什么区别?

①char(n) 若存入字符数小于 n,则以空格补于其后,查询之时再将空格去掉。所以 char类型存储的字符串末尾不能有空格,varchar 不限于此。

②char 类型的字符串检索速度要比 varchar 类型的快。

(3) VARCHAR与TEXT有什么区别?

①varchar 可指定 n,text 不能指定,内部存储 varchar 是存入的实际字符数 +1 个字节(n<=255)或 2 个字节(n>255),text 是实际字符数 +2 个字节。

②text 类型不能有默认值。

③varchar 可直接创建索引,text 创建索引要指定前多少个字符。varchar 查询速度快于 text, 在都创建索引的情况下,text 的索引似乎不起作用。

5. 创建表

(1) MySQL中创建表的语句语法格式是什么?

create table 表名(列名1 类型,列名2 类型,···);

(2) 查看当前数据库中的表的语句是什么?

Show tables;

6. 删除表

在MySQL中删除表的语句是什么?

drop table 表名;

7. 在MySQL中删除表的语句是什么?

(1) 在MySQL中删除表的语句是什么?

drop table 表名;

(2) 在MySQL中修改表名的语句是什么?

Alter table 旧表名 rename 新表名;

(3) 在MySQL中修改列名的语句是什么?

Alter table 表名 change coulmn 旧列名 rename 新列名;

(4) 在MySQL中修改列类型的语句是什么?

Alter table 表名 modify 列名 新类型;

(5) 在MySQL中向表中添加新列的语句是什么?

Alter table 表名 add column 列名 类型;

(6) 在MySQL中删除表中的列的语句是什么?

Alter table 表名 drop column 列名;

8. 创建表时指定约束

(1) MySQL中的约束类型有哪些?

①非空约束(not null)

②唯一性约束(unique)

③主键约束(primary key) PK

④外键约束(foreign key) FK

(2) 如何查询表中的约束信息?

SHOW KEYS FROM 表名;

9. 修改表完成约束的添加与删除

(1) 为表添加主键约束的语句是什么?

ALTER TABLE 表名 ADD PRIMARY KEY(列名);

将 emp 表中的 employee_id 修改为主键且自动增长

添加主键:alter table emp add primary key(employee_id);

添加自动增长:alter table emp modify employee_id int auto_increment;

(2) 删除主键约束的语句是什么?

ALTER TABLE 表名 DROP PRIMARY KEY;

注意:删除主键时,如果主键列具备自动增长能力,需要先去掉自动增长,然后在删除

主键。

如:去掉自动增长: alter table emp modify employee_id int;

删除主键:alter table emp drop primary key;

(3) 添加唯一约束的语句是什么?

ALTER TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE(列名);

(4) 删除唯一约束的语句是什么?

ALTER TABLE 表名 DROP KEY 约束名;

(5) 添加外键约束的语句是什么?

ALTER TABLE 表 名 ADD CONSTRAINT 约 束 名 FOREIGN KEY( 列 名 )REFERENCES 参照的表名(参照的列名);

(6) 删除外键约束的语句是什么?

删除外键:ALTER TABLE 表名 DROP FOREIGN KEY 约束名;

删除外键索引(索引名与约束名相同):ALTER TABLE 表名 DROP INDEX 索引名;

(7) 添加非空约束

ALTER TABLE 表名 MODIFY 列名 类型 NOT NULL;

(8) 删除非空约束

ALTER TABLE 表名 MODIFY 列名 类型 NULL;

8. 向表中添加数据

(1) 在MySQL中向表中添加数据的语句是什么?

①选择插入INSERT INTO 表名(列名 1,列名 2,列名 3…..) VALUES(值 1,值 2,值 3……)。

②完全插入INSERT INTO 表名 VALUES(值 1,值 2,值 3……)如果主键是自动增长,需要使用 default 或者 null 或者 0 占位。

(2) 向departments表中添加一条数据,部门名称为market,工作地点ID为1。

insert into departments(department_name,location_id) values(“market”,1);

9. MySQL的自动增长

(1) 在MySQL中对于自动增长类型有哪些要求?

①一个表中只能有一个列为自动增长。

②自动增长的列的类型必须是整数类型。

③自动增长只能添加到具备主键约束与唯一性约束的列上。

④删除主键约束或唯一性约束,如果该列拥有自动增长能力,则需要先去掉自动增长然后在删除约束。

(2) 创建一个emp2表。包含id该列为主键,包含name,包含seq_num要求该列为具备唯一性约束,该列的值自动增长。

create table emp2(id int primary key ,name varchar(30),seq_num int unique auto_increment);

    原文作者:小七
    原文地址: https://zhuanlan.zhihu.com/p/66152111
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞