主要知识点:python
1、数据库概述mysql
2、mysql安装与基本管理linux
1️⃣ 数据库概述redis
一、什么是数据(Data)?sql
描述事物的符号记录称为数据,描述事物的符号既能够是数字,也能够是文字、图片,图像、声音、mongodb
语言等,数据由多种表现形式,它们均可以通过数字化后存入计算机。数据库
二、什么是数据库(DataBase,简称DB)?vim
数据库即存放数据的仓库,只不过这个仓库是在计算机存储设备上,并且数据是按必定的格式存放的。windows
数据库是长期存放在计算机内、有组织、可共享的数据。服务器
数据库中的数据按必定的数据模型组织、描述和储存,具备较小的冗余度、较高的数据独立性和易扩展性,并可为各类 用户共享。
三、 什么是数据库管理系统(DataBase Management System 简称DBMS)?
了解了Data与DB的概念后,如何科学地组织和存储数据,如何高效获取和维护数据成了关键
这就用到了一个系统软件---数据库管理系统,如MySQL、Oracle、SQLite、Access、MS SQL Server
mysql主要用于大型门户,例如搜狗、新浪等,它主要的优点就是开放源代码,由于开放源代码这个数据库是免费的,他如今是甲骨文公司的产品。
oracle主要用于银行、铁路、飞机场等。该数据库功能强大,软件费用高。也是甲骨文公司的产品。
sql server是微软公司的产品,主要应用于大中型企业,如联想、方正等。
四、总结:
1、数据库服务器:运行数据库管理软件的计算机 2、数据库管理软件:mysql、oracle、db二、sqlserver 3、库:文件夹 4、表:文件 五、记录:事物一系列典型的特征,如:cc,male,21 6、数据:描述事物特征的符号 Mysql:关系型数据库管理软件,由瑞典MySQL公司开发,目前属于Oracle公司。
数据库服务器-:运行数据库管理软件
数据库管理软件:管理-数据库
数据库:即文件夹,用来组织文件/表
表:即文件,用来存放多行内容/多条记录
2️⃣ mysql安装与基本管理
一、MySQL是什么?
mysql就是一个基于socket编写的C/S架构的软件 客户端软件 mysql自带:如mysql命令,mysqldump命令等 python模块:如pymysql
二、数据库管理软件分类
分两大类: 关系型:如sqllite,db2,oracle,access,sql server,MySQL,注意:sql语句通用 非关系型:mongodb,redis,memcache 能够简单的理解为: 关系型数据库须要有表结构 非关系型数据库是key-value存储的,没有表结构
三、下载和安装
3.1 Linux下载和安装
#二进制rpm包安装 yum -y install mysql-server mysql
3.2 Windows下载和安装
#一、下载:MySQL Community Server 5.7.16 http://dev.mysql.com/downloads/mysql/ #二、解压 若是想要让MySQL安装在指定目录,那么就将解压后的文件夹移动到指定目录,如:C:\mysql-5.7.16-winx64 #三、添加环境变量 【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【将MySQL的bin目录路径追加到变值值中,用 ; 分割】 #四、初始化 mysqld --initialize-insecure #五、启动MySQL服务 mysqld # 启动MySQL服务 #六、启动MySQL客户端并链接MySQL服务 mysql -u root -p # 链接MySQL服务器
问题尚未完全解决,由于在执行【mysqd】启动MySQL服务器时,当前终端会被hang住,那么作一下设置便可解决此问题,即将MySQL服务制做成windows服务。
注意:--install前,必须用mysql启动命令的绝对路径 # 制做MySQL的Windows服务,在终端执行此命令: "c:\mysql-5.7.16-winx64\bin\mysqld" --install # 移除MySQL的Windows服务,在终端执行此命令: "c:\mysql-5.7.16-winx64\bin\mysqld" --remove 注册成服务以后,之后再启动和关闭MySQL服务时,仅需执行以下命令: # 启动MySQL服务 net start mysql # 关闭MySQL服务 net stop mysql
四、MySQL的启动与查看
4.1 Linux平台下查看
# systemctl start mariadb #启动 # systemctl enable mariadb #设置开机自启动 Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service. # ps aux |grep mysqld |grep -v grep #查看进程,mysqld_safe为启动mysql的脚本文件,内部调用mysqld命令 mysql 3329 0.0 0.0 113252 1592 ? Ss 16:19 0:00 /bin/sh /usr/bin/mysqld_safe --basedir=/usr mysql 3488 0.0 2.3 839276 90380 ? Sl 16:19 0:00 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mariadb/mariadb.log --pid-file=/var/run/mariadb/mariadb.pid --socket=/var/lib/mysql/mysql.sock # netstat -an |grep 3306 #查看端口 tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN # ll -d /var/lib/mysql #权限不对,启动不成功,注意user和group drwxr-xr-x 5 mysql mysql 4096 Jul 20 16:28 /var/lib/mysql
You must reset your password using ALTER USER statement before executing this statement.
安装完mysql 以后,登录之后,无论运行任何命令,老是提示这个 mac mysql error You must reset your password using ALTER USER statement before executing this statement. 解决方法: step 1: SET PASSWORD = PASSWORD('your new password'); step 2: ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER; step 3: flush privileges;
4.2 windows平台到服务中查看便可
初始状态下,管理员root,密码为空,默认只容许从本机登陆localhost 设置密码 [root@cc ~]# mysqladmin -uroot password "123" 设置初始密码 因为原密码为空,所以-p能够不用 [root@cc ~]# mysqladmin -uroot -p"123" password "456" 修改mysql密码,由于已经有密码了,因此必须输入原密码才能设置新密码 命令格式: [root@cc ~]# mysql -h172.31.0.2 -uroot -p456 [root@cc ~]# mysql -uroot -p [root@cc ~]# mysql 以root用户登陆本机,密码为空
五、破解密码
5.1 linux平台下,破解密码的两种方式
方法一:删除受权库mysql,从新初始化
[root@cc ~]# rm -rf /var/lib/mysql/mysql #全部受权信息所有丢失!!! [root@cc ~]# systemctl restart mariadb [root@cc ~]# mysql
方法二:启动时,跳过受权库
[root@cc ~]# vim /etc/my.cnf #mysql主配置文件 [mysqld] skip-grant-table [root@cc ~]# systemctl restart mariadb [root@cc ~]# mysql MariaDB [(none)]> update mysql.user set password=password("123") where user="root" and host="localhost"; MariaDB [(none)]> flush privileges; MariaDB [(none)]> \q [root@cc ~]# #打开/etc/my.cnf去掉skip-grant-table,而后重启 [root@cc ~]# systemctl restart mariadb [root@cc ~]# mysql -u root -p123 #以新密码登陆
5.2 windows平台下,5.6版本mysql,破解密码的两种方式:
方式一:
#1 关闭mysql #2 在cmd(管理员)中执行:mysqld --skip-grant-tables #3 在cmd中执行:mysql #4 执行以下sql: update mysql.user set password=password("cc233") where user="root" and host="localhost"; flush privileges; #5 查找mysql进程:tasklist |findstr mysql;杀死对应进程:tskill mysqld #或taskkill -f /PID 7832 #6 从新启动mysql(net start mysql),尝试使用新密码登陆
方式二:
#1. 关闭mysql,能够用tskill mysqld将其杀死 #2. 在解压目录下,新建mysql配置文件my.ini #3. my.ini内容,指定 [mysqld] skip-grant-tables #4.启动mysqld #5.在cmd里直接输入mysql登陆,而后操做 update mysql.user set authentication_string=password('') where user='root and host='localhost'; flush privileges; #6.注释my.ini中的skip-grant-tables,而后启动myqsld,而后就能够以新密码登陆了
六、统一字符编码
注意:配置文件中的注释能够有中文,可是配置项中不能出现中文
全局配置解析
#在mysql的解压目录下,新建my.ini,而后配置 #1. 在执行mysqld命令时,下列配置会生效,即mysql服务启动时生效 [mysqld] ;skip-grant-tables port=3306 character_set_server=utf8 default-storage-engine=innodb innodb_file_per_table=1 #解压的目录 basedir=E:\mysql-5.7.19-winx64 #data目录 datadir=E:\my_data #在mysqld --initialize时,就会将初始数据存入此处指定的目录,在初始化以后,启动mysql时,就会去这个目录里找数据 #2. 针对客户端命令的全局配置,当mysql客户端命令执行时,下列配置生效 [client] port=3306 default-character-set=utf8 user=root password=123 #3. 只针对mysql这个客户端的配置,2中的是全局配置,而此处的则是只针对mysql这个命令的局部配置 [mysql] ;port=3306 ;default-character-set=utf8 user=egon password=4573 #!!!若是没有[mysql],则用户在执行mysql命令时的配置以[client]为准
统一字符编码
#1. 修改配置文件 [mysqld] default-character-set=utf8 [client] default-character-set=utf8 [mysql] default-character-set=utf8 #mysql5.5以上:修改方式有所改动 [mysqld] character-set-server=utf8 collation-server=utf8_general_ci [client] default-character-set=utf8 [mysql] default-character-set=utf8 #2. 重启服务 #3. 查看修改结果: \s show variables like '%char%'