1、数据库的基本概念
数据库相关基本概念如下:
1. 数据库的英文单词: DataBase 简称 : DB
2. 什么数据库?
* 用于存储和管理数据的仓库。(注意,存储到内存的数据是临时的数据,使用完之后就会被内存释放;而存储到硬盘的数据可以长时间存储)
3. 数据库的特点:
1. 持久化存储数据的。其实数据库就是一个文件系统,将数据存储到文件中(类似于硬盘)
2. 方便存储和管理数据
3. 使用了统一的方式操作数据库 -- SQL(SQL是操作数据库的方式),所有的关系型数据库都可以使用通用的 SQL 语句进行管理 DBMS DataBase Management System
4. 常见的数据库软件
* 参见《MySQL基础.pdf》
2、MySQL数据库软件
1. 安装
参见《MySQL基础.pdf》
2. 卸载
具体流程如下
1. 去mysql的安装目录找到my.ini文件
* 复制 datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/"
2. 卸载MySQL
3. 删除C:/ProgramData目录下的MySQL文件夹。
3. 配置
注意,我将自己的MySQL的密码设置为admin!!!
MySQL服务启动(所谓服务就是一些没有界面的应用程序,点击“计算机——右键点击服务——选择服务和应用程序——点击服务”,就可以看到我们Windows里面所有的服务列表)
一开始的时候cmd里面MySQL没有安装,在cmd中安装MySQL,可以参考文章添加链接描述 (其实这个部分只要一开始安装一次就可以,接下来不需要再次安装)
如果没办法启动或关闭MySQL,参考这篇文章来清除MySQL的残余线程:MySQL无法启动或者关闭
MySQL服务可以通过以下几种方式启动
1. 手动。(其实就是打开“服务”界面,手动打开MySQL)
2. cmd--> services.msc 可以直接打开服务的窗口,然后手动启动MySQL服务。(这种方法其实只是方便打开服务界面而已)
3. 使用管理员打开cmd (这个注意要在管理员窗口使用,在windows最下面搜索栏搜索cmd,右键以管理员身份打开即可)
* net start mysql : 启动mysql的服务
* net stop mysql:关闭mysql服务
MySQL登录
1. mysql -uroot -p密码 (本地数据库)
当然如果想使得密码不被别人看见,可以先 mysql -uroot -p ,然后再输入密码。
2. mysql -hip -uroot -p连接目标的密码 (连接指定IP地址数据库,当然之前在安装的时候要选择可以连接远程数据库)
3. mysql --host=ip --user=root --password=连接目标的密码 (这种比较麻烦)
MySQL退出
1. exit
2. quit
MySQL目录结构
1. MySQL安装目录:basedir="E:\MYSQL\installationpath" (各个文件的功能见视频5解析)
——bin(binary):放的是一些二进制的可执行文件:mysql.exe:用于登陆MySQL服务器
——data:数据目录,存放MySQL的日志文件、数据文件等等
——include:C语言的一些头信息
——lib:MySQL运行需要的一些库文件(类似于java的jar包)
——share:MySQL的一些错误信息
* 配置文件 my.ini (如果想修改MySQL的配置信息,就修改这个配置文件)
2. MySQL数据目录:datadir="C:\ProgramData\MySQL\MySQL Server 5.5\data"
* 几个概念
* 数据库:文件夹(可以有多个,数据目录下有“mysql”、“performance_schema”、“test”三个文件夹,就是说MySQL安装好后至少有3个数据库)
* 表:对应数据库文件夹里面的文件,比如数据目录下mysql数据库有很多个表(frm文件)
* 数据:表里面的数据
MySQL使用流程:“net start mysql”启动数据块——“mysql -uroot -proot”(注意使用的时候不要加分号,不然有可能报错)登陆本地数据库——使用——“exit”或者“quit”或者关闭cmd退出数据库登陆——“net stop mysql”关闭数据库。(数据库无法开启或者关闭则参考上面的文章清除进程)
4、SQL
什么是SQL:Structured Query Language:结构化查询语言。其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式存在不一样的地方,称为“方言”。
SQL通用语法
1. SQL 语句可以单行或多行书写,以分号结尾。(如果在 SQLyog 中不是必须加的)
2. 可使用空格和缩进来增强语句的可读性。
3. MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写。
4. 3 种注释
* 单行注释: “-- ”(注意是2杆加一个空格)注释内容 或 “#”(一个井号,可以加也可以不加空格)注释内容(mysql 特有)
* 多行注释: /* 注释 */
SQL分类
1) DDL(Data Definition Language)数据定义语言
用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter,show 等
2) DML(Data Manipulation Language)数据操作语言
用来对数据库中表的数据进行增删改。关键字:insert, delete, update 等
3) DQL(Data Query Language)数据查询语言
用来查询数据库中表的记录(数据)。关键字:select, where 等
4) DCL(Data Control Language)数据控制语言(了解)
用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE 等
5、DDL(数据定义语言):操作数据库、表
1. 操作数据库:CRUD
数据库的CRUD的操作如下
1. C(Create):创建
* 创建数据库:
* create database 数据库名称;
* 创建数据库,判断不存在,再创建:(如果不判断,万一数据库存在,我们继续创建就会出错)
* create database if not exists 数据库名称;
* 创建数据库,并指定字符集
* create database 数据库名称 character set 字符集名;
* 练习: 创建db4数据库,判断是否存在,并制定字符集为gbk
* create database if not exists db4 character set gbk;
2. R(Retrieve):查询
* 查询所有数据库的名称:
* show databases;
一开始创建数据库有4个文件夹,但是只显示3个,为什么?(第04节 数据库的CRUD操作-12-3.15)
1)information_schema——没显示的“information_schema”是用来描述数据库里面信息的,比如有哪一些表,哪一些库的名字。它里面存放的其实是视图,所以这个数据库并不存在真正对应的物理文件。
2) mysql——MySQL的核心数据库,存放了很多MySQL核心表文件
3)performance_schema——对MySQL性能进行提升的数据库,里面同样有很多表。
——以上3个数据库尽量不要动它
4)test——空数据库,一般我们也不会使用这个数据库,而会自己新建数据库使用。
* 查询某个数据库的字符集:查询某个数据库的创建语句
* show create database 数据库名称;
eg:show create database mysql; ——查询创建数据库mysql的语法(可以间接查看数据库的字符集)
3. U(Update):修改
* 修改数据库的字符集
* alter database 数据库名称 character set 字符集名称;
4. D(Delete):删除
* 删除数据库
* drop database 数据库名称;
* 判断数据库存在,存在再删除
* drop database if exists 数据库名称;(同样是为了防止删除不存在的数据库)
5. 使用数据库(我们现在处于数据库的数据目录,如果想操作某一个数据库,必须进入这个数据库里面)
* 查询当前正在使用的数据库名称
* select database();(注意database后加括号)
* 使用数据库
* use 数据库名称;(注意这里不需要再加database)这个命令相当于进入到数据库文件夹里面去。
2、操作表的CURD
表相应的CURD操作如下
1. C(Create):创建
1. 语法:
create table 表名(
列名1 数据类型1,
列名2 数据类型2,
....
列名n 数据类型n
);
* 注意:最后一列,不需要加逗号(,)
* 数据库类型:
1. int:整数类型(32位)
* age int,
2. double:小数类型(8字节64位)
* score double(5,2):小数一共有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(m):可变长度的字符串,使用几个字符就占用几个,m为 0~65535 之间的整数(注意这里指定的是字符,而不是字节)
* 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;
* 查询表结构 (这一句只是查询表的结构,最终显示的是表各列的名字,数据类型等属性,并不能查看表中存储的具体数据,想查看表中存储的具体数据,需要使用DML的“SELECT * FROM 表名;”语句)
* desc(description) 表名;(注意在查询表结构的时候不需要写table,与使用数据库 use 数据库名称 类似)
3. U(Update):修改 (如果要对列进行修改,必须先用alter选择要操作的表,因为表与列的所有操作都是基于表。并且,对列进行修改,只是改变列的结构,并不是修改列中的数据)
1. 修改表名
alter table 表名 rename to 新的表名;
这一句也可以写作:RENAME TABLE 表名 TO 新表名;
2. 修改表的字符集
alter table 表名 character set 字符集名称;(查看表的字符集 show create table 表名,实际上这句的功能是“查询某个表创建语句”)
3. 添加一列
alter table 表名 add 列名 数据类型;
4. 修改列名称 类型
alter table 表名 change 列名 新列别 新数据类型;(这个用来将一列换为新的一列)
alter table 表名 modify 列名 新数据类型;(这个用来修改一列的数据类型)
5. 删除列
alter table 表名 drop 列名;(注意删除列与删除数据库和删除表不同,必须先用alter选择要操作的表,因为列的所有操作都是基于表;同样,删除列与下面删除列的数据delete也不同)
4. D(Delete):删除
* drop table 表名;
* drop table if exists 表名 ;
上图是表的结构,我们在定义表的时候需要先指定表的名称,以及每一列的列名以及存储的数据类型。另外,SQL全部的数据类型如下:
3、SQLyog 图形化工具——客户端
(注意,我们在SQLyog里面运行单独运行的时候,不能点击分号后面,这样这一句可能执行不到,而应该点击分号前面的语句,这样指定的这一句才会单独运行。当然,我们也可以用鼠标选中这一行语句,再按执行就可以,这里可以参考视频里面的使用方法)
具体安装和操作参照视频(12.MySQL数据库\第05节 数据库表的CRUD操作\18)
使用:首先,新建一个连接(给连接取一个名字,如:本地)。接下来,指定你的主机,可以用ip地址,也可以使用主机名,如果连接自己的数据库,可以是127.0.0.1或者localhost。然后把用户名、密码、端口等输入,然后测试连接。测试成功后再点击连接。
连接成功后,就进入数据库的操作界面。(图形化界面可以简化很多操作,但是初学阶段我们建议还是使用语句操作,以方便记忆SQL语句)
5、DML(数据操作语言):增删改表中数据
添加数据
* 语法:
* insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n);(如果在添加的时候不知道某一列的具体值,我们可以使用NULL替代。同样,我们没有指定的列的值会默认写为NULL)
* 注意:
1. 列名和值要一一对应。(各类值的类型也应该与表定义的类型相对应)
2. 如果表名后,不定义列名,则默认给所有列添加值
insert into 表名 values(值1,值2,...值n);
3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来
删除数据:注意这里只会删除表的数据,并不会删除表。
* 语法:
* delete from 表名 [where 条件]
eg:如果我们要删除“INSERT INTO student VALUES (1 , '张怡宁' , 32 , 89.9 , '1996-10-28' , NULL);”这一行插入的数据,那么我们可以设置条件为“DELETE FROM student WHERE id = 1;”。(当然除了设置id属性为条件,我们也可以设置其他列为条件)
* 注意:
1. 如果不加条件,则删除表中所有记录。
2. 如果要删除所有记录
1. delete from 表名; -- 不推荐使用。有多少条记录就会执行多少次删除操作。
2. TRUNCATE TABLE 表名; -- 推荐使用,效率更高 先删除表,然后再创建一张一样的新表。(不管有多少条记录,这一句只会执行2次,一次是删除整张表,一次是创建一张新表)
delete from与truncate table这两句都只会删除表中的数据,删除后表还存在。
修改数据:
* 语法:
* update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];
eg:UPDATE student SET id = 5,NAME='郭德纲',age=66 WHERE id = 1; 这一句意思是修改id=1的数据行,其中各种数据按“id = 5,NAME='郭德纲',age=66”修改。
* 注意:
1. 如果不加任何条件,则会将表中所有记录全部修改。
基础查询表与操作表数据(DML)的示例
DESC student; -- 查询表student的结构
/*下面是添加、删除、修改和基本查询的示例代码*/
-- 下面先添加数据到student表中(这里对表中的所有字段都进行添加,因此不需要标列名)
INSERT INTO student VALUES (1 , '张怡宁' , 32 , 89.9 , '1996-10-28' , NULL);
INSERT INTO student VALUES (2 , '林康杰' , 34 , 87.4 , '2010-12-21' , NULL);
INSERT INTO student VALUES (3 , '李海燕' , 12 , 97.3 , '2013-08-12' , NULL);
INSERT INTO student VALUES (4 , '毛不易' , 42 , 43.2 , '1996-11-12' , NULL);
-- 查询整个表
SELECT * FROM student;
-- 查询多行id=1或者id=2的行(结合条件语句)
SELECT * FROM student WHERE id = 1 OR id = 2;
-- 查询多列age、score、name列
SELECT age,score,NAME FROM student;
-- 查询age列下id=1行多对应的单元格
SELECT age FROM student WHERE id = 1;
-- 查询多列age、score、name列在id=1行的单元格(一行的一部分)
SELECT age,score,NAME FROM student WHERE id = 1;
-- 查询age列下id=2,3的行的部分(一列的一部分)
SELECT age FROM student WHERE id = 2 OR id = 3;
-- 删除id=1的行的数据
DELETE FROM student WHERE id = 1;
-- 删除整个表的数据
TRUNCATE TABLE student;
-- 修改id=2行的name、age、score数据
UPDATE student SET NAME = '詹姆斯' , age = 35 , score = 100 WHERE id = 2;
6、DQL:查询表中的记录
相应查询的语法:
select
字段列表
from
表名列表
where
条件列表
group by
分组字段
having
分组之后的条件
order by
排序
limit
分页限定
基础查询
1. 多个字段的查询
select 字段名1,字段名2... from 表名;(既查询一个表内的多列)
* 注意:
* 如果查询所有字段,则可以使用*来替代字段列表。
2. 去除重复:
* distinct
3. 计算列
* 一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)
* ifnull(表达式1,表达式2):null参与的运算,计算结果都为null
* 表达式1:哪个字段需要判断是否为null
* 如果该字段为null后的替换值。
4. 起别名:
* as:as也可以省略
基础查询的示例代码如下
/*首先,我们创建一张新表stu,并插入数据*/
CREATE TABLE stu (
id INT,-- 编号
NAME VARCHAR(20), -- 姓名
age INT, -- 年龄
sex VARCHAR(5),-- 性别
address VARCHAR(100),-- 地址
math INT, -- 数学
english INT -- 英语
);
INSERT INTO stu(id,NAME,age,sex,address,math,english) VALUES (1,'马云',55,'男','
杭州',66,78),(2,'马化腾',45,'女','深圳',98,87),(3,'马景涛',55,'男','香港',56,77),(4,'柳岩
',20,'女','湖南',76,65),(5,'柳青',20,'男','湖南',86,NULL),(6,'刘德华',57,'男','香港',99,99),
(7,'马德',22,'女','香港',99,99),(8,'德玛西亚',18,'男','南京',56,65);
-- ----------------------------------------基础查询
SELECT * FROM stu; -- 查询整体新表
-- 查询姓名与年龄(查询这两列)
SELECT NAME,age FROM stu;
-- 查询地址
SELECT address FROM stu;
-- ----------------------------------------去除重复
# 我们发现地址重复,我们只想知道我们班的人来自哪里,需要去除重复的地址
-- 去除重复的结果集
SELECT DISTINCT address FROM stu;
# 我们发现除了香港,其他重复的去除了。香港之所以没有去除,是因为在添加数据的时候有一个“香港”后面多了一个空字符
/*
我们先删除表,然后重新创建stu表。这里使用的是drop table 的语句,是直接将整张表删除。
而前面的“delete from 表名”可以删除整张表里面的数据,并不是删除表。
而“truncate table 表名”虽然是删除整张表,但是还是会创建一张新的stu表。
如果我们使用“delete from 表名”或者“truncate table 表名”,就不能再创建stu,因为它已经存在,只能重新导入数据。
而我们“drop table stu”,再查询整张表会报错,因为stu已经被我们删除不存在了!
*/
/*
delete from stu;
truncate table stu;
*/
# drop table if exists stu;
#再重新去除重复地址值,发现香港也被我们去除重复
-- 我们想查询谁来自于哪一个地方,这个时候去除重复
SELECT DISTINCT NAME,address FROM stu;
#我们发现重复的地名也不会去除,只有2个列的结果完全一样的时候才会去除!
-- ----------------------------------------计算
-- 计算math与English的分数之和
SELECT NAME,math,english, math+english FROM stu;# 将2门之和相加,但是发现“柳青”行有异常
-- 如果有null参与的运算,计算结果都为null。
-- 那么我们需要用“ifnull()”条件语句判断一下,如果某一门分数为null,相加的时候将其指定为0
SELECT NAME,math,english, math+IFNULL(english,0) FROM stu;# 在相加的时候指定如果english值为null,我们使用0替代
#这样发现“柳青”行结果正常
-- ----------------------------------------起别名
-- 发现最后相加结果字段列名很难看,我们可以使用 as 语句给这一列其别名
SELECT NAME,math,english, math+IFNULL(english,0) AS '总分' FROM stu;# as可以省略
-- 当然也可以给其他列其别名
SELECT NAME,math AS '数学',english '英语',math+IFNULL(english,0) AS '总分' FROM stu;
#结果发现math列名变为“数学”,english列名变为“英语”
条件查询
1. where子句后跟条件
2. 运算符
* > 、< 、<= 、>= 、= 、<>
* BETWEEN...AND
* IN( 集合) :寻找某一个字段为某几个值的行
* LIKE:模糊查询
* 占位符:
* _:单个任意字符
* %:多个任意字符
* IS NULL :判断某一个字段值是否为null,不能使用=判断
* and 或 &&
* or 或 ||
* not 或 !
查询的相应示例如下:
/*首先,我们创建一张新表stu,并插入数据*/
CREATE TABLE stud (
id INT,-- 编号
NAME VARCHAR(20), -- 姓名
age INT, -- 年龄
sex VARCHAR(5),-- 性别
address VARCHAR(100),-- 地址
math INT, -- 数学
english INT -- 英语
);
INSERT INTO stud(id,NAME,age,sex,address,math,english) VALUES (1,'马云',55,'男','
杭州',66,78),(2,'马化腾',45,'女','深圳',98,87),(3,'马景涛',55,'男','香港',56,77),(4,'柳岩',20,'女','湖南',76,65),
(5,'柳青',20,'男','湖南',86,NULL),(6,'刘德华',57,'男','香港',99,99),
(7,'马德',22,'女','香港',99,99),(8,'德玛西亚',18,'男','南京',56,65);
-- ----------------------------------------基础查询
SELECT * FROM stud; -- 查询整体新表
-- ----------------------------------------条件查询
-- 查询大于20岁有哪一些人
SELECT * FROM stud WHERE age>20;
-- 查询大于等于20岁有哪一些人
SELECT * FROM stud WHERE age>=20;
-- 查询等于20岁有哪一些人(SQL里面没有“==”,只需要写“=”即可)
SELECT * FROM stud WHERE age=20;
-- 查询不等于20岁有哪一些人(SQL里面“!=”还可以表示为“<>”)
SELECT * FROM stud WHERE age != 20;
SELECT * FROM stud WHERE age <> 20;
-- 查询20岁到30岁之间有哪一些人
SELECT * FROM stud WHERE age>=20 && age<=30;
SELECT * FROM stud WHERE age>=20 AND age<=30;# SQL里面推荐使用AND
SELECT * FROM stud WHERE age BETWEEN 20 AND 30; # 这一句同样可以表示查询20到30岁
-- 查询年龄22岁,18岁,25岁的信息(查询某一些单个岁数的人)
SELECT * FROM stud WHERE age=22 OR age = 18 OR age = 25;
SELECT * FROM stud WHERE age IN (18,22,25);
-- 查询english成绩为null
SELECT * FROM stud WHERE english=NULL;# 发现查询不到。因为null值不能使用=或!=判断
SELECT * FROM stud WHERE english IS NULL;# 判断某一个值是否是null,必须使用is语句
-- 查询english成绩不为null
SELECT * FROM stud WHERE english IS NOT NULL;
-- ----------------------------------------模糊查询
# 模糊查询占位符:_单个任意字符;(表示替代单个字符) %:多个任意字符(表示替代多个字符,可以是0)
-- 查询姓马的有哪一些
SELECT * FROM stud WHERE NAME LIKE '马%';
-- 查询名字第二个字为化的人
SELECT * FROM stud WHERE NAME LIKE '_化%';
-- 查询姓名是三个字的人
SELECT * FROM stud WHERE NAME LIKE "___";# 用like的三个单占位符“_”表示姓名是三个字的人
-- 查询姓名包含德的人
SELECT * FROM stud WHERE NAME LIKE '%德%';