web-数据库五(MYSQL)

1.数据库的基本概念

1.数据库的英文单词:DataBase 简称:DB

2.什么是数据库?

用于存储和管理数据的仓库。

3.特点:

1.持久化存储数据。其实数据库就是一个文件系统。

2.方便存储和管理数据。

3.使用了统一的方式操作数据库。

4.常见数据库软件

1.Oracle

2.MySQL

3.SQL Server

4.PostgreSQL

5.MongoDB

6.Cassandra

7.Microsoft Access

8.Redis

9.SQLite

10.DB2

5.MYSQL:开源免费的数据库,小型的数据库,已经被Oracle收购了,MySQl6.x开始收费,在web应用中,使用最多的就是MySQL数据库,原因:

1.开源、免费

2.功能强大,足以应付web应用开发(最高支持千万级别的并发访问)

2.Mysql数据库软件

1.安装

*《MySQL基础.pdf》

2.卸载

1.去mysql的安装目录找到my.ini文件

datadir="E:/MySql/MySQLServer5.0/Data/"

2.卸载MySQL

3.删除"E:/MySql“目录下的MySQL文件夹---/MySQLServer5.0/

3.配置

MySQL服务

1.手动

2.cmd-->services.msc 打开服务的窗口

3.使用管理员打开cmd

net start mysql:启动MySQL服务

net stop myql:关闭Mysql服务。

MySQL登录

1.mysql -uroot -proot

2.mysql -h127.0.0.1 -uroot -proot

3.mysql --host=127.0.0.1 --user=root --password=root

MySQL退出

1.exit

2.quit

MySQL目录结构

1.MySQL安装目录

配置文件:my.ini

2.MySQL数据目录

数据库:文件夹

表:文件

数据:文件中的数据

3.SQL

1.什么是SQL?

Structured Query Language :结构化查询语言

其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式不一样的地方,称为-- 方言。

2.SQL通用语法:

1.SQL语句可以单行或多行,以;结尾。

2.可以使用空格和缩进来增强语句的可读性。

3.MySQL数据库的SQL语句不区分大小写。关键字建议大写。

4.三种注释

1.单行注释:-- 或#(mysql特有的) 注释内容。

2.多行注释:/* 注释 */

3.SQL分类

1) Data Definition Language (DDL 数据定义语言) 如:建库,建表

2) Data Manipulation Language(DML 数据操纵语言),如:对表中的记录操作增删改

3) Data Query Language(DQL 数据查询语言),如:对表中的查询操作

4) Data Control Language(DCL 数据控制语言),如:对用户权限的设置

DDL:操作数据库、表

1.操作数据库:CRUD

C Create:创建

* 创建数据库:

* create database 数据库名称;

* 创建数据库,判断不存在,再创建:

* create database if not exists 数据库名称;

* 创建数据库,并指定字符集

* create database 数据库名称 character set 字符集名;

* 练习: 创建db4数据库,判断是否存在,并制定字符集为gbk

* create database if not exists db4 character set gbk;

R Retrieve: 查询

* 查询所有数据库的名称:

* show databases;

* 查询某个数据库的字符集:查询某个数据库的创建语句

* show create database 数据库名称;

U Update:修改

* 修改数据库的字符集

* alter database 数据库名称 character set 字符集名称;

D Delete:删除

* 删除数据库

* drop database 数据库名称;

* 判断数据库存在,存在再删除

* drop database if exists 数据库名称;

使用数据库

* 查询当前正在使用的数据库名称

* select database();

* 使用数据库

* use 数据库名称;

2.操作表

1. C(Create):创建

1. 语法:

create table 表名(

列名1 数据类型1,

列名2 数据类型2,

....

列名n 数据类型n

);

* 注意:最后一列,不需要加逗号(,)

* 数据库类型:

int ,double,varchar,date,datetime,timestamp

1. int:整数类型

* age int,

2. double:小数类型

* score double(5,2)

3. date:日期,只包含年月日,yyyy-MM-dd

4. datetime:日期,包含年月日时分秒 yyyy-MM-dd HH:mm:ss

5. timestamp:时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss

* 如果将来不给这个字段赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值

6. varchar:字符串

* name varchar(20):姓名最大20个字符

* zhangsan 8个字符 张三 2个字符

* 创建表

create table student(

id int,

name varchar(32),

age int ,

score double(4,1),

birthday date,

insert_time timestamp

);

* 复制表:

* create table 表名 like 被复制的表名;

2. R(Retrieve):查询

* 查询某个数据库中所有的表名称

* show tables;

* 查询表结构

* desc 表名;

3. U(Update):修改

1. 修改表名

alter table 表名 rename to 新的表名;

2. 修改表的字符集

alter table 表名 character set 字符集名称;

3. 添加一列

alter table 表名 add 列名 数据类型;

4. 修改列名称 类型

alter table 表名 change 列名 新列别 新数据类型;

alter table 表名 modify 列名 新数据类型;

5. 删除列

alter table 表名 drop 列名;

4. D(Delete):删除

* drop table 表名;

* drop table if exists 表名

## DML:增删改表中数据

1. 添加数据:

* 语法:

* insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n);

* 注意:

1. 列名和值要一一对应。

2. 如果表名后,不定义列名,则默认给所有列添加值

insert into 表名 values(值1,值2,...值n);

3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来

2. 删除数据:

* 语法:

* delete from 表名 [where 条件]

* 注意:

1. 如果不加条件,则删除表中所有记录。

2. 如果要删除所有记录

1. delete from 表名; -- 不推荐使用。有多少条记录就会执行多少次删除操作

2. TRUNCATE TABLE 表名; -- 推荐使用,效率更高 先删除表,然后再创建一张一样的表。

3. 修改数据:

* 语法:

* update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];

* 注意:

1. 如果不加任何条件,则会将表中所有记录全部修改。

## DQL:查询表中的记录

查询语句:排序查询,聚合函数,分组查询,分页查询。

约束,多表之间的关系,范式(设计表时要遵守的规则),数据库的备份和还原。

1.排序查询

语法:order by

select * from user order by age;

order by asc;升序排序

order by desc;降序排序

注意:

如果有多个排序条件,当前边的条件值一样时,才会判断第二条件。

2.聚合函数:将一列数据作为一个整体,进行纵向计算。

count:计算个数

1.选择非空的列,如:主键

2.count(*)

max:计算最大值

min:计算最小值

sum:计算和

avg:计算平均值

注意:聚合函数的计算,排除null值。

解决方案:

1.选择不包含非空的列进行计算。

2.IFNULL函数。

3.分组查询:

1.语法:group by 分组字段;

2.注意:1.分组之后,查询的字段:分组字段、聚合函数。

2.where和having的区别?

1.where在分组之前进行限定,如果不满足这个条件不参与分组。having在分组之 后进行限定,如果不满足这个条件不会被查询出来。

2.where后不可以跟聚合函数,having可以进行聚合函数。

4.分页查询:

语法:limit 开始的索引,每页查询的条数。

公式:开始索引=(当前的页码-1)* 每页查询的数据。

SELECT * FROM USER LIMIT 0,2;

SELECT * FROM USER LIMIT 2,2;

limit是mysql的方言。

-------------------------------------------------------------------------

* select * from 表名;

1. 语法:

select

字段列表

from

表名列表

where

条件列表

group by

分组字段

having

分组之后的条件

order by

排序

limit

分页限定

2. 基础查询

1. 多个字段的查询

select 字段名1,字段名2... from 表名;

* 注意:

* 如果查询所有字段,则可以使用*来替代字段列表。

2. 去除重复:

* distinct

3. 计算列

* 一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)

* ifnull(表达式1,表达式2):null参与的运算,计算结果都为null

* 表达式1:哪个字段需要判断是否为null

* 如果该字段为null后的替换值。

4. 起别名:

* as:as也可以省略

3. 条件查询

1. where子句后跟条件

2. 运算符

* > 、< 、<= 、>= 、= 、<>

* BETWEEN...AND

* IN( 集合)

* LIKE:模糊查询

* 占位符:

* _:单个任意字符

* %:多个任意字符

* IS NULL is

* and 或 &&

* or 或 ||

* not 或 !

-- 查询年龄大于20岁

SELECT * FROM student WHERE age > 20;

SELECT * FROM student WHERE age >= 20;

-- 查询年龄等于20岁

SELECT * FROM student WHERE age = 20;

-- 查询年龄不等于20岁

SELECT * FROM student WHERE age != 20;

SELECT * FROM student WHERE age <> 20;

-- 查询年龄大于等于20 小于等于30

SELECT * FROM student WHERE age >= 20 && age <=30;

SELECT * FROM student WHERE age >= 20 AND age <=30;

SELECT * FROM student WHERE age BETWEEN 20 AND 30;

-- 查询年龄22岁,18岁,25岁的信息

SELECT * FROM student WHERE age = 22 OR age = 18 OR age = 25

SELECT * FROM student WHERE age IN (22,18,25);

-- 查询英语成绩为null

SELECT * FROM student WHERE english = NULL; -- 不对的。null值不能使用 = (!=) 判断

SELECT * FROM student WHERE english IS NULL;

-- 查询英语成绩不为null

SELECT * FROM student WHERE english IS NOT NULL;

-- 查询姓马的有哪些? like

SELECT * FROM student WHERE NAME LIKE '马%';

-- 查询姓名第二个字是化的人

SELECT * FROM student WHERE NAME LIKE "_化%";

-- 查询姓名是3个字的人

SELECT * FROM student WHERE NAME LIKE '___';

-- 查询姓名中包含德的人

SELECT * FROM student WHERE NAME LIKE '%德%';

表的约束:

约束:

概念:对表中数据进行限定,保证数据的正确性、有效性和完整性。

分类:

1.主键约束:primary key

2.非空约束:not null

3.唯一约束:unique

4.外键约束:foreign key

非空约束:not null

1.创建表的时候,添加非空约束。

2.创建完表以后,添加非空约束。

ALTER TABLE baby MODIFY id INT NOT NULL;

3.删除非空约束。

ALTER TABLE baby MODIFY id;

唯一约束:unique

创建表时添加唯一约束:

CREATE TABLE baby3(

id INT,

phone_number VARCHAR(20) UNIQUE

);

删除唯一约束

ALTER TABLE baby2 DROP INDEX phone_number;

创建表后添加唯一约束:

ALTER TABLE baby2 MODIFY phone_number VARCHAR(20) UNIQUE;

主键约束:primary key

1.注意;

1.含义:非空且唯一

2.一张表只能有一个字段为主键

3.主键就是表中记录的唯一标识

2.创建表时,添加唯一约束:

CREATE TABLE baby3(

id INT PRIMARY KEY,

phone_number VARCHAR(20) UNIQUE

);

3.删除主键

ALTER TABLE baby2 DROP PRIMARY KEY;

4.创建完表后,添加主键

ALTER TABLE baby2 MODIFY id INT PRIMARY KEY;

5自动增长

概念:如果某一列是数组类型的,使用auto_increment可以来完成值的自动增长

自动增长只和上一条数据的id有关。

删除自动增长:ALTER TABLE baby3 MODIFY id INT;

外键约束:foreign key,让表与表产生关系,从而保证数据的正确性。

1.创建表时,可以添加外键

语法:

create table 表名(

...

外键列

constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)

);

删除外键

alter table employee drop foreign key emp_dept_fk;

在创建表之后,添加外键。

alter table employee add constraint 外键名称 foreign key 外键列名称 references 主表名称(主表列名称)

级联操作:

级联更新:

猜你喜欢

转载自blog.csdn.net/zcl_200886/article/details/106527159
今日推荐