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);