mysql 安装与基本管理

MySQL介绍

  1. MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司。
  2. MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System
  3. 关系数据库管理系统) 应用软件之一。
  • mysql是什么

  1. mysql就是一个基于socket编写的C/S架构的软件客户端软件  mysql自带:如mysql命令,mysqldump命令等  python模块:如pymysql
  • 数据库管理软件分类

  1. #分两大类:  
  2. 关系型:如sqllitedb2oracleaccesssql serverMySQL,注意:sql语句通用  
  3. 非关系型:mongodbredismemcache可以简单的理解为: 关系型数据库需要有表结构 非关系型数据库是key-value存储的,没有表结构

下载安装

  • Linux版本

  1. #二进制rpm包安装yum -y install mysql-server mysql
  2. 1.解压tar
  3. cd /software
  4. tar -xzvf mysql-5.6.21-linux-glibc2.5-x86_64.tar.gz
  5. mv mysql-5.6.21-linux-glibc2.5-x86_64 mysql-5.6.21
  6. 2.添加用户与组
  7. groupadd mysql
  8. useradd -r -g mysql mysql
  9. chown -R mysql:mysql mysql-5.6.21
  10. 3.安装数据库
  11. su mysql
  12. cd mysql-5.6.21/scripts
  13. ./mysql_install_db --user=mysql --basedir=/software/mysql-5.6.21 --datadir=/software/mysql-5.6.21/data
  14. 4.配置文件
  15. cd /software/mysql-5.6.21/support-files
  16. cp my-default.cnf /etc/my.cnf
  17. cp mysql.server /etc/init.d/mysql
  18. vim /etc/init.d/mysql #若mysql的安装目录是/usr/local/mysql,则可省略此步
  19. 修改文件中的两个变更值
  20. basedir=/software/mysql-5.6.21
  21. datadir=/software/mysql-5.6.21/data
  22. 5.配置环境变量
  23. vim /etc/profile
  24. export MYSQL_HOME="/software/mysql-5.6.21"
  25. export PATH="$PATH:$MYSQL_HOME/bin"
  26. source /etc/profile
  27. 6.添加自启动服务
  28. chkconfig --add mysql
  29. chkconfig mysql on
  30. 7.启动mysql
  31. service mysql start
  32. 8.登录mysql及改密码与配置远程访问
  33. mysqladmin -u root password 'your_password' #修改root用户密码
  34. mysql -u root -p #登录mysql,需要输入密码
  35. mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'your_password' WITH GRANT OPTION; #允许root用户远程访问
  36. mysql>FLUSH PRIVILEGES; #刷新权限
  • 源码安装mariadb
  1. 1. 解压
  2. tar zxvf mariadb-5.5.31-linux-x86_64.tar.gz
  3. mv mariadb-5.5.31-linux-x86_64 /usr/local/mysql //必需这样,很多脚本或可执行程序都会直接访问这个目录
  4. 2. 权限
  5. groupadd mysql //增加 mysql 属组
  6. useradd -g mysql mysql //增加 mysql 用户 并归于mysql 属组
  7. chown mysql:mysql -Rf /usr/local/mysql // 设置 mysql 目录的用户及用户组归属。
  8. chmod +x -Rf /usr/local/mysql //赐予可执行权限
  9. 3. 拷贝配置文件
  10. cp /usr/local/mysql/support-files/my-medium.cnf /etc/my.cnf //复制默认mysql配置 文件到/etc目录
  11. 4. 初始化
  12. /usr/local/mysql/scripts/mysql_install_db --user=mysql //初始化数据库
  13. cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql //复制mysql服务程序 到系统目录
  14. chkconfig mysql on //添加mysql 至系统服务并设置为开机启动
  15. service mysql start //启动mysql
  16. 5. 环境变量配置
  17. vim /etc/profile //编辑profile,将mysql的可执行路径加入系统PATH
  18. export PATH=/usr/local/mysql/bin:$PATH
  19. source /etc/profile //使PATH生效。
  20. 6. 账号密码
  21. mysqladmin -u root password 'yourpassword' //设定root账号及密码
  22. mysql -u root -p //使用root用户登录mysql
  23. use mysql //切换至mysql数据库。
  24. select user,host,password from user; //查看系统权限
  25. drop user ''@'localhost'; //删除不安全的账户
  26. drop user root@'::1';
  27. drop user root@127.0.0.1;
  28. select user,host,password from user; //再次查看系统权限,确保不安全的账户均被删除。
  29. flush privileges; //刷新权限
  30. 7. 一些必要的初始配置
  31. 1)修改字符集为UTF8
  32. vi /etc/my.cnf
  33. 在[client]下面添加 default-character-set = utf8
  34. 在[mysqld]下面添加 character_set_server = utf8
  35. 2)增加错误日志
  36. vi /etc/my.cnf
  37. 在[mysqld]下面添加:
  38. log-error = /usr/local/mysql/log/error.log
  39. general-log-file = /usr/local/mysql/log/mysql.log
  40. 3) 设置为不区分大小写,linux下默认会区分大小写。
  41. vi /etc/my.cnf
  42. 在[mysqld]下面添加:
  43. lower_case_table_name=1
  44. 修改完重启:#service mysql restart
  • Window版本

  1. #1、下载:MySQL Community Server 5.7.16http://dev.mysql.com/downloads/mysql/
  2. #2、解压如果想要让MySQL安装在指定目录,那么就将解压后的文件夹移动到指定目录,如:C:\mysql-5.7.16-winx64
  3. #3、添加环境变量【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》
  4. 【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【将MySQLbin目录路径追加到变值值中,用 分割】
  5. #4、初始化mysqld --initialize-insecure
  6. #5、启动MySQL服务mysqld
  7. # 启动MySQL服务#6、启动MySQL客户端并连接MySQL服务 mysql -u root -p
  8. # 连接MySQL服务器
  • 上一步解决了一些问题,但不够彻底,因为在执行【mysqd】启动MySQL服务器时,当前终端会被hang住,

    那么做一下设置即可解决此问题,即将MySQL服务制作成windows服务
  1. 注意:--install前,必须用mysql启动命令的绝对路径
  2. # 制作MySQL的Windows服务,在终端执行此命令:"c:\mysql-5.7.16-winx64\bin\mysqld" --install
  3. # 移除MySQL的Windows服务,在终端执行此命令:"c:\mysql-5.7.16-winx64\bin\mysqld" --remove注册成服务之后,
  4. 以后再启动和关闭MySQL服务时,仅需执行如下命令:
  5. # 启动MySQL服务net start mysql# 关闭MySQL服务net stop mysql
  6. #安装问题
  7. # 操作系统的问题
  8. # 缺失dll文件 (360卫视修复一下,或下个补丁)
  9. # 安装路径
  10. # 不能有空格
  11. # 不能有中文
  12. # 不能带着有转义的特殊字符开头的文件夹名 (建议直接存到c盘或d盘的根目录下)
  13. # 安装之后发现配置有问题
  14. # 再修改配置往往不能生效
  15. # 卸载之后重装
  16. # mysqld remove (cmd命令框删除指令)
  17. # 把所有的配置、环境变量修改到正确的样子
  18. # 重启计算机 - 清空注册表
  19. # 再重新安装

登录设置密码

  1. 初始状态下,管理员root,密码为空,默认只允许从本机登录localhost设置密码[root@gkf ~]
  2. # mysqladmin -uroot password "123" 设置初始密码 由于原密码为空,因此-p可以不用[root@gkf ~]
  3. # mysqladmin -uroot -p"123" password "456" 修改mysql密码,因为已经有密码了,
  4. 所以必须输入原密码才能设置新密码命令格式:[root@gkf~]
  5. # mysql -h172.31.0.2 -uroot -p456[root@gkf~]# mysql -uroot -p[root@gkf~]
  6. # mysql 以root用户登录本机,密码为空

破解密码

  • linux平台下,破解密码的两种方式

  • 方法一:删除授权库mysql,重新初始化

  1. [root@xxxx ~]# rm -rf /var/lib/mysql/mysql #所有授权信息全部丢失!!![root@xxxx ~]
  2. # systemctl restart mariadb[root@xxxx ~]# mysql
  • 方法二:启动时,跳过授权库

  1. [root@xxxx ~]# vim /etc/my.cnf
  2. #mysql主配置文件[mysqld]skip-grant-table[root@xxxx ~]
  3. # systemctl restart mariadb[root@xxxx ~]
  4. # mysqlMariaDB [(none)]> update mysql.user set password=password("123") where user="root" and host="localhost";MariaDB [(none)]> flush privileges;MariaDB [(none)]> \q[root@xxxx ~]
  5. #打开/etc/my.cnf去掉skip-grant-table,然后重启[root@xxxx ~]
  6. # systemctl restart mariadb[root@xxxx ~]# mysql -u root -p123
  7. #以新密码登录
  • windows平台下,5.7版本mysql,破解密码的两种方式:

  • 方式一

  1. #1 关闭 mysql
  2. #2 在cmd中执行:mysqld --skip-grant-tables
  3. #3 在cmd中执行:mysql
  4. #4 执行如下sql:update mysql.user set authentication_string=password('') where user = 'root';flush privileges;
  5. #5 tskill mysqld #或taskkill -f /PID 7832#6 重新启动mysql
  • 方式二
  1. #1. 关闭mysql,可以用tskill mysqld将其杀死
  2. #2. 在解压目录下,新建mysql配置文件my.ini
  3. #3. my.ini内容,指定[mysqld]skip-grant-tables
  4. #4.启动mysqld
  5. #5.在cmd里直接输入mysql登录,然后操作update mysql.user set authentication_string=password('') where user='root and host='localhost';flush privileges;
  6. #6.注释my.ini中的skip-grant-tables,然后启动myqsld,然后就可以以新密码登录了

统一字符编码

  • 强调:配置文件中的注释可以有中文,但是配置项中不能出现中文
  1. #在mysql的解压目录下,新建my.ini,然后配置
  2. #1. 在执行mysqld命令时,下列配置会生效,即mysql服务启动时生效[mysqld];skip-grant-tablesport=3306character_set_server=utf8default-storage-engine=innodbinnodb_file_per_table=1#解压的目录basedir=E:\mysql-5.7.19-winx64#data目录datadir=E:\my_data
  3. #在mysqld --initialize时,就会将初始数据存入此处指定的目录,在初始化之后,启动mysql时,就会去这个目录里找数据
  4. #2. 针对客户端命令的全局配置,当mysql客户端命令执行时,下列配置生效[client]port=3306default-character-set=utf8user=rootpassword=123
  5. #3. 只针对mysql这个客户端的配置,2中的是全局配置,而此处的则是只针对mysql这个命令的局部配置[mysql];
  6. port=3306;default-character-set=utf8user=gkfpassword=4573
  7. #!!!如果没有[mysql],则用户在执行mysql命令时的配置以[client]为准
  • 统一字符编码
  1. #1. 修改配置文件[mysqld]default-character-set=utf8 [client]default-character-set=utf8 [mysql]default-character-set=utf8#mysql5.5以上:
  2. 修改方式有所改动[mysqld]character-set-server=utf8collation-server=utf8_general_ci[client]default-character-set=utf8[mysql]default-character-set=utf8
  3. #2. 重启服务
  4. #3. 查看修改结果:\sshow variables like '%char%'

mysql参数配置

  1. [mysql]
  2. # 设置mysql客户端默认字符集
  3. default-character-set=utf8
  4. [mysqld]
  5. #设置3306端口
  6. port = 3306
  7. # 设置mysql的安装目录>安装完的点击mysql-5.6.44-winx64文件夹的第一层目录的地址
  8. basedir=D:\mysql-5.6.44-winx64
  9. # 设置mysql数据库的数据的存放目录>进入bin目录的地址
  10. datadir=D:\mysql-5.6.44-winx64\data
  11. # 允许最大连接数
  12. max_connections=200
  13. # 服务端使用的字符集默认为8比特编码的latin1字符集
  14. character-set-server=utf8
  15. # 创建新表时将使用的默认存储引擎
  16. default-storage-engine=INNODB

mysql 常用指令

  1. # mysqld install 安装数据库服务
  2. # net start mysql 启动数据库的server端(不要分号)
  3. # net stop mysql (停止服务)(不要分号)
  4. # server net stop mysql 停止(windows没有重启指令)
  5. # mysql -u用户名 -p密码 (登录-uroot -p 不加分号,密码不输)
  6. # mysql中的用户和权限
  7. # 在安装数据库之后,有一个最高权限的用户root
  8. # mysql 192.168.12.87 gkf/123 #eve为账户/123为密码
  9. # mysql -h192.168.12.87 -uroot -p123 #最高权限/管理员
  10. # mysql>select user(); # 查看当前用户是谁
  11. # mysql>set password = password('密码') # 设置密码
  12. # create user 'gkf'@'192.168.12.%' identified by '123';# 创建用户
  13. # mysql -us21 -p123 -h192.168.12.87
  14. # grant all on day.* to 's21'@'192.168.12.%';# 授权
  15. # grant all on day.* to 'gandan'@'%' identified by '123';# 授权并创建用户
  16. # show databases; # 查看文件夹
  17. # create database day; # 创建文件夹/库
  18. # 客户端可以是python代码也可以是一个程序
  19. # 我们的mysql客户端不仅可以连接本地的数据库
  20. # 也可以连接网络上的某一个数据库的server端
  21. # mysql.exe是一个客户端 安装好,mysql-5.6.44-winx64目录有这个程序
  22. # mysql -u用户名 -p密码 5.6版本可以不用密码登录
  23. #mysql命令不区分大小写
  24. #\q 退出 \c 此条语句作作废
作 者:郭楷丰
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角 推荐一下。您的鼓励是博主的最大动力!
自 勉:生活,需要追求;梦想,需要坚持;生命,需要珍惜;但人生的路上,更需要坚强。带着感恩的心启程,学会爱,爱父母,爱自己,爱朋友,爱他人。

mysql 安装与基本管理的更多相关文章

  1. python 全栈开发,Day60(MySQL的前戏,数据库概述,MySQL安装和基本管理,初识MySQL语句)

    一.MySQL的前戏 在学习Mysql之前,我们先来想一下一开始做的登录注册案例,当时我们把用户的信息保存到一个文件中: #用户名 |密码 root|123321 alex|123123 上面文件内容 ...

  2. MySql安装和基本管理&mysql语句

    MySql安装和基本管理   本章内容: mysql的安装.启动 mysql破解密码 统一字符编码 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下 ...

  3. MySql安装和基本管理

    一.什么是数据库? mysql就是一个基于socket编写的C/S架构的软件 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司.MySQL 最流 ...

  4. mysql安装与基本管理

    一.MySQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司.MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是 ...

  5. Mysql初识数据库《四》mysql安装与基本管理

    一.MySQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司.MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是 ...

  6. mysql安装与基本管理,mysql密码破解

    一.MySQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司.MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是 ...

  7. 数据库介绍(MySQL安装 体系结构、基本管理)

    第1章 数据库介绍及mysql安装 1.1 数据库简介 数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新增.截取.更新.删除等操作. 所谓“数据库”系以一定方式 ...

  8. 【转】数据库介绍(MySQL安装 体系结构、基本管理)

    [转]数据库介绍(MySQL安装 体系结构.基本管理) 第1章 数据库介绍及mysql安装 1.1 数据库简介 数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新 ...

  9. mysql 更新(二)安装和基本管理

    03-MySql安装和基本管理   本节掌握内容: MySQL的介绍安装.启动 MySQL破解密码 MySQL中统一字符编码 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目 ...

随机推荐

  1. [web前端] react router4.0 登录后返回之前浏览页面(回到来源页)

    本文链接:https://blog.csdn.net/zeroyulong/article/details/81911704困扰了好久的问题,最终还是在官方文档上找到了答案(看英文文档真心难受啊~~) ...

  2. 初进python世界之数据类型

    文章来源: https://www.cnblogs.com/seagullunix/articles/7297946.html 基本运算符 常用数据类型: 字符串(Str) 数字(Digit) 列表( ...

  3. Microsoft Office Excel不能访问文件*.xls的解决方案

    Microsoft Office Excel不能访问文件‘xxxx.xls“可能的原因有:·文件名称或路径不存在,文件正被其他程序使用:您正要保存的工作簿与当前打开的工作簿同名. 解决方案 1.首先检 ...

  4. Python - Django - SweetAlert 插件的使用

    SweetAlert Github:https://github.com/lipis/bootstrap-sweetalert 下载完后放入 /static/ 目录下 sweetalert.html: ...

  5. base64方式显示控件

    data:,文本数据 data:text/plain,文本数据 data:text/html,HTML代码 data:text/html;base64,base64编码的HTML代码 data:tex ...

  6. [LeetCode] 49. Group Anagrams 分组变位词

    Given an array of strings, group anagrams together. For example, given: ["eat", "tea& ...

  7. [LeetCode] 186. Reverse Words in a String II 翻转字符串中的单词 II

    Given an input string, reverse the string word by word. A word is defined as a sequence of non-space ...

  8. Java之变量和数据类型

    变量 什么是变量 变量就是初中的代数的概念.例如一个简单的方程,x,y都是变量 y=x+1 在Java中,变量分为两种:基本类型的变量和引用类型的变量 在Java中,变量必须先定义后使用,在定义变量的 ...

  9. redis(1)---linux下的安装

    安装redis 照着官网一波操作即可:https://redis.io/download,如果不能正常编译能是少了gcc,如果能联网直接 yum install gcc再编译. 照着官网操作走一波 1 ...

  10. 安装 gearman

    准备:php 对应gearman插件包 https://pecl.php.net/package/gearman 1. 先安装依赖库 [root@VM_27_0_centos /]# yum inst ...