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)

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

3.什么是数据库管理系统(DataBase Management System)

在了解了Data与DB的概念后,如何科学组织和存储数据,如何高效获取和维护数据成了关键
这就用到了一个系统软件-->数据库管理系统
如MySql,Oracle,SQLite,Access,MS SQL Server
MySql主要用于大型门户,例如搜狗,新浪等,它主要的优势就是开放源代码,因为开放源代码这个数据库是免费,他现在是甲骨文公司的产品
Oracle主要用于银行,铁路,飞机场等,该数据库功能强大,软件费用高,也是甲骨文公司的产品
SQL Server是微软公司的产品,主要应用打中型企业,如 联想,方正等
View Code

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”组合。
View Code

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 服务已经启动成功。

(4).在cmd中输入MySql进入MySql环境,执行\s,显示如下信息,表示成功:

posted @ 2018-10-15 17:39  骑驴老神仙  阅读(315)  评论(0)    收藏  举报