简介

数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种 用户或应用共享的数据集合。

数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软 件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。 用户通过数据库管理系统访问数据库中的数据。

数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。

数据库:存储、维护和管理数据的集合。

常见数据库管理系统

  • Oracle
    - MySQL (用的最多)
    - DB2 (用的很少)
    - Microsoft SQL Server

三大范式(规范)

第一范式:无重复的列 (没有重复的列)
第二范式:属性完全依赖于主键 [ 消除部分子函数依赖 ]。 第 二范式(2NF)要求数据库表中的每个实例或行必须可以被唯一地区分。 (每一行数据不能重复)
第三范式:属性不依赖于其它非主属性 [ 消除传递依赖 ] 。 第三范式(3NF)要求一个数据库表中不包含已在其 它表中已包含的非主关键字信息。 (多表时每个表之间不能有重复信息)

SQL语言

概述

SQL:Structure Query Language(结构化查询语言),SQL被美国国家标准局(ANSI)确定为关 系型数据库语言的美国标准,后来被国际化标准组织(ISO)采纳为关系数据库语言的国际标准。

各数据库厂商都支持ISO的SQL标准,普通话
各数据库厂商在标准的基础上做了自己的扩展,方言

SQL 是一种标准化的语言,它允许你在数据库上执行操作,如创建项目,查询内容,更新内容, 并删除条目等操作。

Create, Read, Update, and Delete 通常称为CRUD操作。

SQL语句分类

-DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等。

  • DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据)增删改。
  • DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别。

    • DQL(Data Query Language):数据查询语言,用来查询记录(数据)查询。

    注意: sql语句以; 结尾
    mysql中的关键字不区分大小写

DDL操作数据库

1 创建

CREATE DATABASE语句用于创建新的数据库:

//create database 数据库名
CREATE DATABASE mydb1;

//create database 数据库名 character set 编码方式 CREATE DATABASE mydb2 character SET GBK;

//create database 数据库名 set 编码方式 collate 排序规则 CREATE DATABASE mydb3 character SET GBK COLLATE gbk_chinese_ci;

2 查看数据库


查看当前数据库服务器中的所有数据库
show databases;

查看前面创建的mydb2数据库的定义信息
Show CREATE DATABASE mydb2;

3 修改数据库

alter database 数据库名 character set 编码方式

ALTER DATABASE mydb2 character SET utf8;

4 删除数据库

DROP DATABASE mydb3;

5 其他语句

查看当前使用的数据库
Select database();

切换数据库: use 数据库名
USE mydb2;

DDL操作表

创建新表

CREATE TABLE 表名( 列名1 数据类型 [约束], 列名2 数据类型 [约束], 列名n 数据类型 [约束] );

常用数据类型: image.png

其他表操作

DROP TABLE table_name; 删除表

show tables; 当前数据库中的所有表

desc 表名; 查看表的字段信息

alter table 表名 add 新列名 新的数据类型 ; 增加列

alter table 表名 change 旧列名 新列名 新的数据类型 ; 修改列

alter table 表名 drop 列名 ; 删除列,一次只能删一列。

alter table 旧表名 rename 新表名; 修改表名,表名改为user。

show create table 表名; 查看表格的创建细节

alter table 表名 character set 编码方式 ; 修改表的字符集为gbk

select * from 表名; 查询所有数据

DML操作

DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了

主要包括:INSERT 、UPDATE、 DELETE

小知识: 在mysql中,字符串类型和日期类型都要用单引号括起来。 空值:null

(1)插入操作:INSERT:

insert into 表名(列名) values(数据值);
insert into student(stuname,stuage,stusex,birthday) values(‘张三1’,18,’a’,’2000- 1-1’) ;

— 注意:1多列和多个列值之间使用逗号隔开 2.列名要和列值一一对应
— 非数值的列值两侧需要加单引号

  • 添加数据的时候可以将列名省略->当给所有列添加数据的时候
    — 此时列值的顺序按照数据表中列的顺序执行

    — 同时添加多行
    insert into 表名(列名) values(第一行数据),(第二行数据),(),();
    如果插入空值,请使用null

    sql中的运算符:
    (1)算术运算符:+,-,*,/(除法),求余(%)
    (2)赋值运算符:=
    (3) 逻辑运算符: and(并且),or(或者),not(取非) 作用:用于连接多个条件时使用
    (4) 关系运算符: >,<,>=,<=,!=(不等于),=(等于),<>(不等于)

(2)修改(更新)操作:UPDATE:

语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 … WHERE 列名=值 and 列名=值;

(3)删除操作:DELETE:

语法 : DELETE from 表名 【WHERE 列名=值】或者 delete from 表名;

注意:
- DELETE 删除表中的数据,表结构还在;删除后的数据可以找回
- truncate 删除是把表直接DROP掉,然后再创建一个同样的新表。
- 删除的数据不能找回。执行速度比DELETE快。

DCL 操作

1、创建用户:

create user 用户名@指定ip identified by ‘密码’;

create user 用户名@‘% ’ identified by ‘密码’ 任意IP均可登陆

2、用户授权:

grant 权限1,权限2,……..,权限n on 数据库名.* to ‘用户名’@IP;
给指定用户授予指定指定数据库指定权限

grant all on . to ‘用户名’@IP ;
给指定用户授予所有数据库所有权限

3、用户权限查询:

show grants for ‘用户名’@IP;

4、撤销用户权限:

revoke 权限1,权限2,……..,权限n on 数据库名.* from ‘用户名’@IP;

5、删除用户:

drop user 用户名@IP;
注意:创建和删除用户用户名不要引号;

DQL数据查询

简单查询

查询所有列 SELECT * FROM stu;
查询指定列 SELECT sid, sname, age FROM stu;

条件查询

条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字: =、!=、<>、<、<=、>、>=; BETWEEN…AND; IN(set); IS NULL; AND;OR; NOT;

(3)查询学号为S_1001,S_1002,S_1003的记录
列名 in (列值1,列值2) SELECT * FROM stu WHERE sid IN (‘S_1001’,’S_1002’,’S_1003’);

(6) 查询年龄在20到40之间的学生记录
或者:列名 between 开始值 and 结束值;

SELECT * FROM stu WHERE age BETWEEN 20 AND 40;

(8) 查询姓名不为null的学生记录
SELECT FROM stu WHERE NOT sname IS NULL;
或者
SELECT
FROM stu WHERE sname IS NOT NULL;

模糊查询

语法: 列名 like ‘表达式’ //表达式必须是字符串
通配符: _(下划线): 任意一个字符
%:任意0~n个字符,’张%’

字段控制查询

(1)去除重复记录

需要使用 distinct SELECT DISTINCT sal FROM emp;

(2)查看雇员的月薪与佣金之和

SELECT *,sal+comm FROM emp;

comm列有很多记录的值为NULL, 下面使用了把NULL转换成数值0的函数IFNULL:

SELECT *,sal+IFNULL(comm,0) FROM emp;

(3)给列名添加别名

SELECT *, sal+IFNULL(comm,0) AS total FROM emp;
as可以省略

排序

语法: order by 列名 asc/desc //asc 升序 desc 降序 默认不写的话是升序

(1) 查询所有学生记录,按年龄升序排序
select * from emp2 order by age asc;

(3) 查询所有雇员,按月薪降序排序,如果月薪相同时,按编号升序排序
多列排序:当前面的列的值相同的时候,才会按照后面的列值进行排序
SELECT * FROM emp ORDER BY sal DESC,empno ASC;

聚合函数 (纵向运算)

聚合函数是用来做纵向运算的函数:

COUNT(列名):统计指定列不为NULL的记录行数;
MAX(列名):计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;
MIN(列名):计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;
SUM(列名):计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;
AVG(列名):计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;

分组查询

当需要分组查询时需要使用GROUP BY子句,例如查询每个部门的工资和,这说明要使用部分来分组。

注意:如果查询语句中有分组操作,则select后面能添加的只能是聚合函数和被分组的列名

l 查询每个部门的部门编号和每个部门的工资和:
SELECT deptno, SUM(sal) FROM emp GROUP BY deptno;

查询每个部门的部门编号以及每个部门的人数:
SELECT deptno,COUNT(*) FROM emp GROUP BY deptno;

查询每个部门的部门编号以及每个部门工资大于1500的人数:
SELECT deptno,COUNT(*) FROM emp WHERE sal>1500 GROUP BY deptno;

HAVING子句

查询工资总和大于9000的部门编号以及工资和:
SELECT deptno, SUM(sal) FROM emp GROUP BY deptno HAVING SUM(sal) > 9000;

注:having与where的区别:
1.having是在分组后对数据进行过滤,where是在分组前对数据进行过滤
2.having后面可以使用分组函数(统计函数) where后面不可以使用分组函数。
WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分 组;而HAVING是对分组后数据的约束。

补充: 多列分组
— 统计出stu表中每个班级的男女生各多少人
select gradename,gender ,count(*) from stu group by gradename,gender ;

LIMIT

LIMIT用来限定查询结果的起始行,以及总行数。
limit 开始下标,显示条数;//开始下标从0开始
limit 显示条数;//表示默认从0开始获取数据

1.查询5行记录,起始行从0开始 SELECT * FROM emp LIMIT 0, 5;

分页查询

如果一页记录为10条,希望查看第3页记录应该怎么查呢?

pageIndex 页码值 pageSize 每页显示条数

limit (pageindex-1)*pagesize,pagesize;