黑马就业班(01.JavaSE Java语言基础\12.MySQL数据库)——part1:MySQL数据库基础

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.151)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位,小数点后面占23. 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. 起别名:	
	* asas也可以省略

  基础查询的示例代码如下

/*首先,我们创建一张新表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 '%德%';
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值