DBMS
DBMS数据库管理系统的简称,我们常见的DBMS由以下几种,并且它们各自的优缺点如下:
Oracle
Oracle是一种关系型数据库管理系统。它的特点是:运行稳定、功能齐全、性能优异;主要应用在大型的企业数据库领域。
DB2
DB2由IBM公司研发。它的特点是:具有较好的可伸缩性;主要应用于大型应用系统,可支持从大型机到单用户环境。
SQL Server
SQL Server由Microsoft研发。它的特点是:界面友好、操作简单;主要应用于电子商务,企业的ERP,进销存等软件
MySQL
MySQL属于瑞典MySQL AB的产品。MySQL所使用的SQL 语言是用于访问数据库的最常用标准化语言;它的特点是:体积小、速度快、成本低;主要于中小型应用系统。
一般企业用的MySQL比较多,成本低,所以我们就来学习MySQL。
安装教程自行百度吧。
SQL简介
sql是数据库语言标准,它具有以下的特点:
- 简单易学,具有很强的操作性;
- 绝大多数重要的数据库管理系统均支持SQL;
- 高度非过程化;用SQL操作数据库时大部分的工作由DBMS自动完成。
sql的分类由以下几种:
- DDL
数据定义语言,用来操作数据库/表/列,create alter drop; - DML
数据操作语言,用来操作数据库表的数据,insert update delete; - DCL
数据控制语言,用来操作访问权限和操作级别,grant deny; - DQL
数据查询语言,用来查询数据,select;
DDL和DML的区别在于DDL操作的是数据库或者表或者列,而DML操作的具体的数据,相对而言DDL级别更高,我们来一次学习一下。
DDL数据定义语言
它的代表语法:create alter drop。
1. 对数据库操作
// 创建数据库
create database dbName;
// 创建数据库并指定字符集
create database dbName character set utf8;
// 查询数据库
show create database dbName;
// 查询所有数据库
show databases;
// 删除数据库
drop database dbName;
// 修改数据库
alter database dbName character set gbk;
// 切换到数据库
use dbName;
// 查看当前使用的数据库
select database();
2. 对表操作
//创建表格式
create table tableName(
字段名称1 类型,
字段名称2 类型,
字段名称3 类型,
字段名称4 类型,
字段名称5 类型
);
//创建一个学生表
create table student_info(
id int,
user_name varchar(10),
age int,
birthday date
);
// 显示当前数据库中所有表
show tables;
// 修改表的名字
rename table oldTable to newTable;
// 删除表
drop table tableName;
// 查询表字段信息
describe tableName;
desc tableName; //简写
// 修改表的字符集
alter table tableName character set gbk;
3. 对列操作
// 为表增加列,为表增加一个类型为int的列sex;
alter table student_info add column sex int;
alter table student_info add sex int; //简写
// 修改表的列名,oldName改为newName
alter table student_info change oldName newName varchar(20);
// 删除列,删除列sex
alter table student_info drop sex;
DML数据操作语言
它的代表语法:insert update delete。
1. 插入操作:insert
INSERT INTO 表名 (列名1,列名2…)VALUE (值1,值2…);
要注意这几点:
- 列名与列值的类型、个数、顺序要一一对应;
- 列值不要超出列定义的长度;
- 如果插入空值,请使用null;
- 插入的日期和字符需用引号括起来,例如:’sun’、’2016-09-04’;
例子:
// 插入一条数据,id,student_name值确定
insert into student(id,student_name) values(1, '戚继光');
//插入多条数据
insert into student(id,student_name) values
(2, '戚薇'), (3, '戚继光');
2. 修改操作:update
UPDATE 表名 SET 列名1=列值1,列名2=列值2 WHERE 列名=值;
例子:
// 将student_name的值‘戚继光’改为‘英雄’
update student set student_name='英雄' where student_name='戚继光';
// 将列birthday所有的值都改为'1992-08-05'
update student set birthday='1992-08-05';
3. 删除操作:delete
// 删除某一条数据
delete from tableName where id=1;
// 删除表中的所有数据但表还存在,可以找回数据
delete from tableName;
// 删除表中所有数据,数据不可找回,速度比delete快
truncate table tableName;
DCL数据控制语言
DCL用来定义访问权限和安全级别。
// 创建用户语法
create user 用户名@IP地址 identified by 密码;
// 创建一个'qdl'用户 密码为'123456'
create user qdl@localhost identified by '123456';
// 创建新用户后需要更新权限表
flush privileges;
// 给用户授权语法
grant 权限1,权限2...权限n on 数据库名.* to 用户名@ip地址 identified by 密码;
// 将所有权限授予用户
grant all on 数据库名.* to 用户名@ip地址 identified by 密码;
// 给用户qdl添加数据库mydatabase的所有权限
grant all on mydatabase.* to qdl@localhost identified by '123456';
// 撤销权限
revoke 权限1,权限2,...权限n on 数据库名.* from 用户名@ip地址;
// 撤销用户qdl的所有权限
revoke all on mydatabase.* from 用户名@ip地址;
// 查询用户权限
show grants for qdl@localhost;
// 删除用户
drop user qdl@localhost;
DQL数据查询语言
由于DQL的重要性,我们应该另起一篇来探讨。