MySql开始了
一.MySql的前戏
想一下登陆注册案例,当时我们把用户信息存储到一个文件中
#用户名 | 密码 wahaha | 123 shuangww | 234
上面文件内容的规则是我自己定义的,你想要用我的程序就必须遵守我的规则,但凡不是这个规则,就没有交流的余地,在一开始的时候文件格式的规定是没有规范的,后面学到模块的时候逐渐知道了目录规则,我们会把文件放到db目录下,类似下面这种目录结构:
对于上面目录中的db,是可以存放多个文件的,并且文件中可以有多行数据,而MySql就是用于管理我们文件的一个软件
那么对于MySql这个软件来说有两个软件
服务器软件
socket服务器
本地文件操作
解析指令(mysql语句)
客户端软件
socket客户端
发送指令
解析指令(mysql语句)
注释:
对于服务器软件中的socket服务器是一直开着,客户端得需要连接,并且还有创建文件,删除文件等等操作
对于客户端软件中的socket客户端,我们得需要发送指令去命令socket服务端对文件进行操作
就如FTP的项目,上传项目和下载项目的命令是不一样的,那么对于mysql中的客户端和服务端也会有些指令的操作,那么在这两端中应该是由解析指令的过程,这个指令就有mysql这个软件知道,这种指令就是mysql语句
再想想我们写的HTML,CSS,JS这些好比就是我们客户端写好的语法,然后浏览器充当了服务端的角色去解析我们的语法,最后渲染出来的结果
二.数据库的概述
1.什么是数据(Data)
描述事物的符号记录称为数据,描述事物的符号既可以是数字,也可以文字,图片,声音,等,数据由多种表现形式,它们都可以经过数字化后存入计算机 在计算机中描述一个事物,就需要抽取这一个事物的典型特征,组成一条记录,就相当于文件里的一行内容,如: 1 wahaha,male,20,1998,山东,计算机系,2018
单纯的一条记录并没有任何意义,如果我们按逗号作为分隔,依次定义各个字段的意思,相当于定义表的标题
这样通过表格我们很清楚的知道了某个人的详细信息
2.什么是数据库(DataBase,简称DB)

数据库即存放数据的仓库,只不过这个仓库是在计算机存储设备上,而且数据是按一定的格式存放的
过去人们将数据存放在文件柜里,现在数据量庞大,已经不再适用
数据库是长期存放在计算机内,有组织,可共享的数据即可
数据库中的数据按一定的数据模型组织,描述和存储,具有较小的冗余度,较高的数据独立性和易扩展性,并可为各种用户共享
3.什么是数据库管理系统(DataBase Management System)

在了解了Data与DB的概念后,如何科学组织和存储数据,如何高效获取和维护数据成了关键 这就用到了一个系统软件-->数据库管理系统 如MySql,Oracle,SQLite,Access,MS SQL Server MySql主要用于大型门户,例如搜狗,新浪等,它主要的优势就是开放源代码,因为开放源代码这个数据库是免费,他现在是甲骨文公司的产品 Oracle主要用于银行,铁路,飞机场等,该数据库功能强大,软件费用高,也是甲骨文公司的产品 SQL Server是微软公司的产品,主要应用打中型企业,如 联想,方正等
4.数据库服务器,数据管理系统,数据库,表与记录的关系(重点理解!!)
记录:1 XXX 32232323 22 (多个字段的信息组成一条记录,即文件中的一行内容)
表:student,scholl,class_list(即文件)
数据库:wahaha_stu(即文件夹)
数据库管理系统:如mysql(是一个软件)
数据库服务器:一台计算机(对内存要求比较高)
(1).总结:
数据库服务器:运行数据库管理软件
数据库管理软件:管理数据库
数据库:即文件,用来组织文件/表
表:即文件,用来存放多行内容/多条记录
三.MySql的安装和基本管理
MySql是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于Oracle旗下公司,MySql最流行的关系型数据库管理系统,在WEB应用方面MySql是最好的RDBMS(Relational Database Management System, 关系数据库管理系统)应用软件之一
MySql是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有的数据放在一个大仓库内,这样就增加了速度并提高了灵活性
- MySql是开源的,所以你不需要支付额外的费用
- MySql支持大型的数据库,可以处理拥有上千万条记录的大型数据库
- MySql使用标准的SQL数据语言形式
- MySql可以允许多个系统上,并且支持多种语言,这些编程语言包括C,C++,Python,Java,Perl,PHP,Eiffel,Ruby和Tcl等
- MySql对PHP有很好的支持,PHP是目前最流行的Web开发语言
- MySql支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可支持4GB,64位系统支持最大的表文件为8TB
- MySql是可以定制的,采用GPL协议,你可以修改源码来开发自己的MySql系统
由于其他社区版的性能卓越,搭配Apache和PHP以及Python,可组成良好的开发环境
1.应用环境

与其他的大型数据库例如 Oracle、DB2、SQL Server等相比,MySQL [1] 自有它的不足之处,但是这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于 MySQL是开放源码软件,因此可以大大降低总体拥有成本。 Linux作为操作系统,Apache 或Nginx作为 Web 服务器,MySQL 作为数据库,PHP/Perl/Python作为服务器端脚本解释器。由于这四个软件都是免费或开放源码软件(FLOSS),因此使用这种方式不用花一分钱(除开人工成本)就可以建立起一个稳定、免费的网站系统,被业界称为“LAMP“或“LNMP”组合。
2.MySql是什么?
通俗来讲:MySql就是基于socket编写的C/S架构的软件
3.数据库管理软件分类
分为两大类: 关系型:如sqllite,db2,oracle,access,sql,server,MySQL,注意:SQL语句通用 非关系型:mongodb,redis,memcache 总结两句话: 关系型数据库需要有表结构 非关系型数据库是key-value存储的,没有表结构 所以,现在我们使用关系型数据库管理系统(RDBMS)来存储和管理的大数据量,所谓的关系型数据库,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据 RDBMS即关系数据库管理系统(Relational Database Management System)的特点 1.数据以表格的形式出现 2.每行为各种记录名称 3.每列为记录名称所对应的数据域 4.许多的行和列组成的一张表单 5.若干的表单组成database RDBMS 术语 在我们开始学习MySql数据库钱,让我们先了解一下RDBMS的一些术语: 数据库:数据库是一些关联表的集合 数据表:表示数据的矩阵,在一个数据库中的表看起来像一个简单的电子表格 列:一列(数据元素)包含了相同的数据,例如一条用户订阅的数据 行:一行(=元组 或记录)是一组相关的数据,例如一条用户订阅的数据 冗余:存储两倍数据,冗余降低了性能,但提高了数据的安全性 主键:主键是唯一的,一个数据表中只能包含一个主键,你可以使用主键来查询数据 外键:外键用于关联两个表 复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引 索引:使用索引可以快速访问数据库表中的特定信息,索引是对数据库表中一列或多列的值进行排序的一种结构,类似于书籍的目录 参照完整性:参照的完整性要求关系中不允许引用不存在的实体,与实体完整性是关系模型必须满足的完整性约束条件,目的是保证数据的一致性
4.MySql的下载安装
想要使用MySql来存储并保存数据,则需要做几件事情:
a.安装MySql服务端
b.安装MySql客户端
c.[客户端]链接[服务端]
d.[客户端]发送命令给[服务端MySql]服务的接受命令执行相应操作(增删改查等)
下载地址: https://dev.mysql.com/downloads/mysql/
5.window版本
(1).官网去下载
(2).针对操作系统的不同,下载不同的版本
(3).解压
如果想要让MySql安装在指定目录,那么就将解压后的文件移动到指定目录,如:D:\mysql-5.6.40-winx64
(4).添加环境变量
右键计算机->属性->高级系统设置->高级->环境变量->在第二个内容框中找到名为Path的一行,双击->将MySql的bin目录路径追加到变值中,用;分割
(5).初识化
mysqld --initialize-insecure
(6).启动MySql服务
mysqld #启动MySql服务
(7).启动mysql客户端并连接mysql服务端(新开一个cmd窗口)
mysql -uroot -p #连接MySql服务器
上一步解决了一些问题,但不够彻底,因为在执行MySql启动MySql服务器时,当前终端会被hang住,那么做一下设置即可解决此问题,即将MySQL服务器制作成windows服务
注意: --install前,必须用MySQL启动命令的绝对路径 #制作MySQL的Windows服务,在终端执行命令: mysql --install #移除MySQL的Windows服务,在终端执行命令: mysql --remove 注册成服务后,以后再启动和关闭MySQL服务时,仅需要执行如下命令: #启动MySQL服务 net start mysql #关闭MySQL服务 net stop mysql
(8).Windows下登录设置密码
打开终端,输入mysql
输入mysql提供的函数:select user(); #查看当前登录的账号
当前登录的默认账号为ODBC@localhost
如果想切换到root账号登录
执行命令:
mysql -uroot -p
再查看当前用户:
select user();
管理员为root(拥有最高权限,管理员账号),密码为空,以无密码的方式登录了管理员账号,是非常危险的一件事情,所以要为管理员账号设置密码
设置管理员root账号密码为123
C:\Users\mjj>mysqladmin -uroot -p password "123" #设置初始密码 由于原密码为空,因此-p可以不用 注意这句话不起作用,请使用update mysql.user set authentication_string =password('') where User='root';
ps: 不用管它。翻译为:在命令行界面使用密码不安全,暴露在终端当中。
然后再次登录账号,不输入密码则会出现如下结果:
再次执行如下操作:
再查看一下当前登录的账号:
如果想将原始密码123,设置新密码为456
C:\Users\mjj>mysqladmin -uroot -p"123" password "456" #修改mysql密码,因为已经有密码了,所以必须输入原密码才能设置新密码
依次执行如下操作:
mysql -uroot -p456 select user();
(9).密码忘记 --> 破解密码
跳过授权方式,直接登录!!
a.以管理员身份打开cmd
b.停掉MySQL服务端
C:\WINDOWS\system32>net stop mysql
MySQL 服务正在停止.
MySQL 服务已成功停止。
c.执行如下命令跳过授权表
#跳过授权表 C:\WINDOWS\system32>mysqld --skip-grant-tables 2018-06-09 17:12:38 0 [Warning] Insecure configuration for --secure-file-priv: Current value does not restrict location of generated files. Consider setting it to a valid, non-empty path. 2018-06-09 17:12:38 0 [Note] mysqld (mysqld 5.6.40) starting as process 6052 ...4.
d.再次查看
e.现在可以任意的更改密码,执行如下命令
update mysql.user set authentication_string =password('') where User='root';
f.刷新权限,执行命令
flush privileges;
g.退出MySQL, 执行命令:exit
h.让用户去加载权限,以管理员身份进入cmd,查看当前mysql进程
tasklist |findstr mysql #查看当前mysql的进程
i.杀死当前的进程,执行如下命令
taskkill /F /PID 6052 # 杀死当前的进程pid
j. 再次执行如下操作,还原
6.统一字符编码
进入MySql客户端,执行\s
为了统一字符编码,请执行如下操作:
(1).my.ini文件是MySql的配置文件
在D:\mysql-5.6.40-winx64文件下创建my.ini文件
(2).将如下代码拷贝保存
[mysqld] # 设置mysql的安装目录 **后面的路径一定是安装sql的目录(自己电脑的)** basedir=C:\mysql-5.7.22-winx64\mysql-5.7.22-winx64 # 设置mysql数据库的数据的存放目录,必须是data datadir=C:\mysql-5.7.22-winx64\mysql-5.7.22-winx64\data sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES # mysql端口 port=3306 # 字符集 [mysqld] character-set-server=utf8 collation-server=utf8_general_ci [client] default-character-set=utf8 [mysql] default-character-set=utf8
(3).以管理员身份重启服务,执行如下命令
C:\Windows\system32>net stop MySQL MySQL 服务正在停止.. MySQL 服务已成功停止。 C:\Windows\system32>net start MySQL MySQL 服务正在启动 . MySQL 服务已经启动成功。