第十九章:Linux中安装MySQL

news2024/10/6 16:27:27

第十九章:Linux中安装MySQL

19.1:卸载MySQL

  1. 查看是否安装过MySQL

    # 如果你是用rpm安装,检查一下RPM PACKAGE
    rpm -qa | grep -i mysql
    # 检查 mysql service
    systemctl status mysqld.service
    # CentOS6和CentOS7在MySQL的使用中的区别
    # 防火墙:6是iptables,7是firewalld
    # 启动服务的命令:6是service,7是systemctl
    
  2. MySQL卸载

    • 关闭,ysql服务

      systemctl stop mysqld.service
      
    • 查询当前mysql安装状态

      rpm -qa | grep -i mysql
      yum list installed | grep mysql
      
    • 卸载上述命令【任意一条就行】查询出的已安装程序

      yum remove mysql-xxx mysql-xxx mysql-xxx mysqk-xxx
      

      注意:务必卸载干净,反复执行rpm -qa | grep -i mysql确认是否有卸载残留。

    • 删除mysql相关文件

      # 查找相关文件
      find / -name mysql
      # 删除上述命令查找出的相关文件
      rm -rf xxx
      
    • 删除my.cnfMySQL的配置文件】

      rm -rf /etc/my.cnf
      

19.2:MySQl的Liunx版本安装

  1. 检查/tmp临时目录权限

    chmod -R 777 /tmp
    
  2. 安装前,检查依赖

    rpm -qa | grep libaio
    rpm -qa | grep net-tools
    

  1. 将安装程序拷贝到/opt目录下

    mysql的安装文件目录下执行:(必须按照顺序执行)

    # 安装mysql5.7就把版本号换成5.7的
    rpm -ivh mysql-community-common-8.0.25-1.el7.x86_64.rpm
    # 安装mysql5.7没有这个文件
    rpm -ivh mysql-community-client-plugins-8.0.25-1.el7.x86_64.rpm
    rpm -ivh mysql-community-libs-8.0.25-1.el7.x86_64.rpm
    rpm -ivh mysql-community-client-8.0.25-1.el7.x86_64.rpm
    rpm -ivh mysql-community-server-8.0.25-1.el7.x86_64.rpm
    
  2. 查看MySQL版本

    mysql --version
    mysqladmin --version
    
  3. 服务的初始化

    为了保证数据库目录与文件的所有者未MySQL登录用户,如果你是以root身份运行mysql服务,需要执行下面的命令初始化。

    # --initialize选项默认以"安全模式"来初始化,则会为root用户生成一个密码并将该密码标记为过期
    # 登录后你需要设置一个新的密码。生成的临时密码会往日志中记录一份
    mysqld --initialize --user=mysql
    
    # 查看密码
    cat /var/log/mysqld.log
    
  4. 启动MySQL

    # 启动:
    systemctl start mysqld.service
    # 关闭:
    systemctl stop mysqld.service
    # 重启:
    systemctl restart mysqld.service
    # 查看状态:
    systemctl status mysqld.service
    
  5. 查看MySQL服务是否自启动

    # 默认是enabled(enabled是自启动)
    systemctl list-unit-files | grep mysqld.service
    # 如果不是enabled,可以运行如下命令设置自启动
    systemctl enable mysqld.service
    # 如果希望不进行自启动,运行如下命令
    systemctl disable mysqld.service
    

19.3:MySQL登录

  1. MySQL登录

    # 首次登录
    mysql -hlocalhost -P3306 -uroot -p初始化密码
    
  2. 修改密码

    # 因为初始化密码默认是过期的,一些sql操作会报错
    ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';
    
  3. 设置远程登录

    • 当前问题

      在用SQLyogNavicat中配置远程连接MySQL数据库时遇到如下报错信息,这是由于MySQL配置了不支持远程连接引起的。
      在这里插入图片描述

    • 确认网络

      1. 在远程机器上使用ping ip地址保证网络畅通
      2. 在远程机器上使用telnet命令保证端口号开放访问
      telent ip地址 端口号
      

在这里插入图片描述
在这里插入图片描述

  • 关闭防火墙或开放端口

    1. 方式一:关闭防火墙

      # 开启防火墙
      systemctl start firewalld.service
      # 查看防火墙状态
      systemctl status firewalld.service
      # 关闭防火墙
      systemctl stop firewalld.service
      #设置开机启用防火墙
      systemctl enable firewalld.service
      #设置开机禁用防火墙
      systemctl disable firewalld.service
      
    2. 方式二:开放端口

      # 查看开放的端口
      firewall-cmd --list-all
      # 设置开放的端口
      firewall-cmd --add-service=http --permanent
      firewall-cmd --add-port=3306/tcp --permanent
      # 重启防火墙
      firewall-cmd --reload
      
  • Linux下修改配置

    use mysql;
    select Host,User from user;
    /* 查询结果
    +-------------+------------------+
    |    Host     |     User         |
    +-------------+------------------+
    |  localhost  |  mysql.session   |
    +-------------+------------------+
    |  localhost  |  mysql.ysy       |
    +-------------+------------------+
    |  localhost  |  root            |
    +-------------+------------------+
    */
    # Host列指定了允许用户登录所使用的IP,user=root, Host=localhost,表示只能通过本机客户端去访问。
    # 而百分号是通配符,如果Host=192.168.1.%,那么就表示只要是IP地址前缀为192.168.1.的客户端都可以连接。
    # 如果Host=%,表示所有IP都有连接权限
    update user set host = '%' where user ='root';
    # 刷新权限
    flush privileges;
    
  • 字符集错误【MySQL8.0会出现,MySQL5.7不会出现】
    在这里插入图片描述

    ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
    

19.4:字符集的相关操作

  1. 修改MySQL5.7字符集

    • 修改步骤

      ​ 在MySQL8.0版本之前,默认字符集为latinlutf8字符集指向的是utf8mb3。网站开发人员在数据库设计时候往往会将编码修改为utf8字符集。如果遗忘修改默认的编码,就会出现乱码的问题。从MySQL8.0开始,数据库的默认编码将改为utf8mb4,从而避免上述乱码的问题。

    • 查看默认使用的字符集

      show variables like 'character%';
      show variables like '%char%';
      
    • 修改字符集

      # 编辑配置文件
      vim /etc/my.cnf
      # 在MySQL5.7或之前的版本中,在文件最后加上中文字符集配置
      character_set_server=utf8
      # 重启mysql服务器
      systemctl restart mysqld
      
    • 已有库、表字符集的变更

      # 修改已创建数据库的字符集
      alter database 数据库名 character set 'utf8';
      # 修改已创建数据库的字符集
      alter table 表名 convert to character set 'utf8';
      
  2. 各级别的字符集

    MySQL有4个级别的字符集和比较规则,分别是服务器级别数据库级别表级别列级别

    show variables like 'character%';
    /*
    +------------------------------+---------------------------------------+
    |   character_set_client       |     utf8mb4                           |    服务器解码请求时使用的字符集    
    +------------------------------+---------------------------------------+
    |  character_set_connection    |     utf8mb4                | 服务器处理请求时会把请求字符串从client转为connection
    +------------------------------+---------------------------------------+
    |  character_set_database      |     utf8mb4                           |    当前数据的字符集
    +------------------------------+---------------------------------------+
    |  character_set_filesystem    |     binary                            |
    +------------------------------+---------------------------------------+
    |  character_set_results       |     utf8mb4                           |   服务器向客户端返回数据式使用的字符集
    +------------------------------+---------------------------------------+
    |  character_set_server        |     utf8mb4                           |    服务器级别的字符集
    +------------------------------+---------------------------------------+
    |  character_set_system        |     utf8mb3                           |
    +------------------------------+---------------------------------------+
    |  character_sets_dir          |     /usr/share/mysql-8.0/charsets/    |
    +------------------------------+---------------------------------------+
    */
    
    • 服务器级别

      # 我们可以在服务器程序时通过启动选项或者在服务器程序运行过程中使用 SET 语句修改这两个变量的值。
      # 当服务器启动的时候读取这个配置文件后者两个系统变量的值便修改了
      character_set_server=gbk  # 默认字符集
      collation_server=gbk_chinese_ci  #对应的默认的比较规则
      
    • 数据库级别

      # 创建数据库时指定字符集和比较规则
      CREATE DATABASE 数据库名
       [[DEFAULT] CHARACTER SET 字符集名称]
       [[DEFAULT] COLLATE 比较规则名称];
      
      # 修改数据库的字符集和比较规则
      ALTER DATABASE 数据库名
       [[DEFAULT] CHARACTER SET 字符集名称]
       [[DEFAULT] COLLATE 比较规则名称];
      
    • 表级别

      # 创建表时指定字符集和比较规则
      CREATE TABLE 表名 (列的信息)
       [[DEFAULT] CHARACTER SET 字符集名称]
       [COLLATE 比较规则名称]]
      
      # 修改表的字符集和比较规则
      ALTER TABLE 表名
       [[DEFAULT] CHARACTER SET 字符集名称]
       [COLLATE 比较规则名称]
      

      ​ 如果创建和修改表的语句中没有指明字符集和比较规则,将使用该表所在数据库的字符集和比较规则作为该表的字符集和比较规则。

    • 列级别

      ​ 对于存储字符串的列,同一个表中的不同列也可以有不同的字符集和比较规则。我们在创建和修改列定义的时候可以指定该列的字符集和比较规则。

      # 创建表时指定列的字符集和比较规则
      CREATE TABLE 表名(
      	列名 字符串类型 [CHARACTER SET 字符集名称] [COLLATE 比较规则名称],
          其他列...
      );
      
      # 修改表中的列字符集和比较规则
      ALTER TABLE 表名 MODIFY 列名 字符串类型 [CHARACTER SET 字符集名称] [COLLATE 比较规则名称];
      

      ​ 对于某个列来说,如果在创建和修改的语句中没有指明字符集和比较规则,将使用该列所在的表的字符集和比较规则作为该列的字符集和比较规则。

  3. 字符集比较规则

    utf8字符集表示一个字符需要使用1~4个字节,但是我们经常的一些字符使用1~3字节就可以表示了。而字符集表示一个字符所用的最大字节长度,在某些方面会影响系统的存储和性能,所以设计MySQL的设计者偷偷的定义了两个概念。

    • utf8mb3:阉割过的utf8字符集,只使用1~3个字节表示字符。
    • utf8mb4:正宗的utf8字符集,使用1~4个字节表示字符。
  4. 比较规则

    MySQL版本一共支持41种字符集,其中的Default collation列表示这种字符集中的一种默认的比较规则,里面包含着该比较规则主要作用于哪种语言,比如utf8_polish_ci表示以波兰语的规则比较,utf8_spanish_ci是以西班牙语的规则比较,utf8_general_ci是一种通用的比较规则。

    后缀表示该比较规则是否区分语言中的重音、大小写。

    后缀英文释义描述
    _aiaccent insensitive不区分重音
    _asaccent sensitive区分重音
    _cisase insensitive不区分大小写
    _cscase sensitive区分大小写
    _binbinary以二进制方式比较

    最后一列Maxlen,它代表该种字符集表示一个字符最多需要几个字节。

    #查看GBK字符集的比较规则
    SHOW COLLATION LIKE 'gbk%';
    #查看UTF-8字符集的比较规则
    SHOW COLLATION LIKE 'utf8%';
    
    #查看服务器的字符集和比较规则
    SHOW VARIABLES LIKE '%_server';
    #查看数据库的字符集和比较规则
    SHOW VARIABLES LIKE '%_database';
    #查看具体数据库的字符集
    SHOW CREATE DATABASE dbtest1;
    #修改具体数据库的字符集
    ALTER DATABASE dbtest1 DEFAULT CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';
    
    #查看表的字符集
    show create table employees;
    #查看表的比较规则
    show table status from atguigudb like 'employees';
    #修改表的字符集和比较规则
    ALTER TABLE emp1 DEFAULT CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';
    
  5. 请求到响应过程中字符集的变化

    系统变量描述
    character_set_client服务器解码请求时使用的字符集
    character_set_connection服务器处理请求时会把请求字符串从character_set_client转为character_set_connection
    character_set_results服务器向客户端返回数据时使用的字符集
    使用操作系统的字符集编码请求字符串
    使用操作系统的字符集解码响应的字符串
    客户端
    从character_set_client转换为character_set_connection
    从character_set_connection转换为具体的列使用的字符集
    将查询结果从具体的列上使用的字符集转换为character_set_results

19.5:SQL大小写规范

  1. WindowsLinux平台区别

    ​ 在SQL中,关键字和函数名是不用区分字母大小写的,不过在SQL中,你还是要确认大小写的规范,因为在LinuxWindows环境下,你可能会遇到不同的大小写问题。Windows系统默认大小写不敏感,但是Linux系统是大小写敏感的。

    SHOW VARIABLES LIKE '%lower_case_table_names%';
    # windows系统值为1,linux系统值为0
    # 默认为0,大小写敏感
    # 设置1,大小写不敏感。创建的表,数据库都是以小写形式存放在磁盘上,对于sql语句都是转换为小写对表和数据库进行查找。
    # 设置2,创建的表和数据库依据语句上格式存放,凡是查找都是转换为小写进行。
    

    MySQLLinux下数据库名、表名、列名、别名大小写规则如下:

    • 数据库名、表名、表的别名、变量名是严格区分大小写。
    • 关键字、函数名称在SQL中部分大小写。
    • 列名(或字段名)与列的别名(或字段别名)在所有的清下下均是忽略大小写的。
  2. Linux下大小写规则设置

    当想设置为大小写不敏感时,要在my.cnf这个配置文件[mysqld]中加入lower_case_table_names=1,然后重启服务器。

    • 但是要在重启数据库实例之前就需要将原来的数据库和表转换为小写,否则将找不到数据库名。

    • 此参数适用于MySQL5.7。在MySQL 8下禁止在重新启动 MySQL 服务时将lower_case_table_names设置成不同于初始化MySQL 服务时设置的lower_case_table_names值。如果非要将MySQL8设置为大小写不敏感,具体步骤为:

      停止MySQL服务
      删除数据目录,即删除 /var/lib/mysql 目录
      在MySQL配置文件( /etc/my.cnf )中添加 lower_case_table_names=1
      启动MySQL服务
      
  3. SQL编写建议

    如果你的变量名命名规范没有统一,就可能产生错误。这里有一个命名规范的建议:

    • 关键字和函数名称全部大写。
    • 数据库名、表名、表别名、字段名、字段别名等全部小写。
    • SQL语句必须以分号结尾。

19.6:sql_mode的合理设置

  1. 宽松模式 VS 严格模式

    • 宽松模式

      如果设置的是宽松模式,那么我们在插入数据的时候,即便给了一个错误的数据,也可能会被接受,并且不报错。

      应用场景:通过设置sql_mode为宽松模式,来保证大多数sql符合标准的sql语法,这样应用在不同数据库之间进行迁移时,则不需要对业务sql进行较大的修改。

    • 严格模式

      出现宽松模式的错误,应该报错才对,所以MySQL5.7版本就将sql_mode默认值改为了严格模式。所以在生产等环境中,我们必须采用严格模式,进而开发、测试环境的数据库也必须要设置,这样在开发测试阶段就可以发现问题。

      开发经验MySQL等数据库总想把关于数据的所有操作都自己包揽下来,包括数据的效验,其实开发中,我们应该在自己开发的项目程序级别将这些校验给做了,虽然写项目的时候麻烦了一些步骤,但是这样做之后,我们在进行数据迁移或者在项目的迁移时,就会方便很多。

      改为严格模式可能会存在的问题:若设置模式中包含了NO_ZERO_DATE,那么MySQL数据库不允许插入零日期,插入零日期会抛出错误而不是警告。

  2. 设置查看和设置

    • 查看当前的sql_mode

      select @@session.sql_mode
      select @@global.sql_mode
      show variables like 'sql_mode';
      
    • 临时设置方式:设置当前窗口中设置sql_mode

      SET GLOBAL sql_mode = 'modes....'; # 全局
      SET SESSION sql_mode = 'modes....'; # 当前会话
      
    • 永久设置方式

      # 在my.cnf文件(windows系统是my.ini文件),新增:
      # 在真正文件删除下面的换行符,这里只是为了看得清楚
      sql_mode=
      ONLY_FULL_GROUP_BY,
      STRICT_TRANS_TABLES,
      NO_ZERO_IN_DATE,
      NO_ZERO_DATE,
      ERROR_FOR_DIVISION_BY_ZERO,
      NO_ENGINE_SUBSTITUTION
      # 然后重启MySQL
      

      注意:

      ​ 当然生产环境上是禁止重启MySQL服务的,所以采用临时设置方式 + 永久设置方式来解决线上的问题,那么即便是有一天真的重启了MySQL服务,也会永久生效了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/742863.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

React-Native学习,RN的容器Flex-Box布局

justify-content(在RN中属性名称为:justifyContent)在主轴上对齐方式 align-items(在RN中属性名称为:alignItems)在交叉轴上的对齐方式 在React Native中,当没有设置容器的主轴方向时&#xf…

Web-文件上传

需求 新增员工和修改员工的需求会需要上传对应的图像 先实现对应的新增需求吧 !!!RequestBody,因为传参是json格式,还是看对应接口文档!!! controller service mapper xml 对应代码 &…

Jstat命令解析

Jstat命令解析 Jstat是JDK自带的一个轻量级小工具。全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收…

单元测试与端到端测试——主要区别

目录 前言: 什么是单元测试? 单元测试生命周期 单元测试的好处 那么它有什么好处呢? 单元测试示例 单元测试的类型 单元测试工具 什么是端到端测试? 端到端测试 端到端测试的主要好处是什么? 端到端测试示…

Tauri 应用中发送 http 请求

最近基于 Tauri 和 React 开发一个用于 http/https 接口测试的工具 Get Tools,其中使用了 tauri 提供的 fetch API,在开发调试过程中遇到了一些权限和参数问题,在此记录下来。 权限配置 在 tauri 应用中,如果想要使用 http 或 fe…

小白到运维工程师自学之路 第四十九集 (正则表达式之grep)

一、概述 1、正则表达式(Regular Expression,简称为RegExp或Regex)是一种用于描述、匹配和操作文本的字符串模式的表达式。它提供了一种强大而灵活的方式来进行字符串的搜索、替换、提取和验证操作。 2、正则表达式可以用于各种编程语言和应…

SpringBoot第25讲:SpringBoot对TypeHandler的使用

SpringBoot第25讲:SpringBoot对TypeHandler的使用 本文是SpringBoot第25讲,SpringBoot对TypeHandler的使用,TypeHandler就是当SpringBoot 实体类中字段类型和数据库中字段类型不一致时进行使用。 文章目录 SpringBoot第25讲:Sprin…

基环树学习笔记

0.前言 只因环树学习笔只因。 如有错误欢迎指出。 1.基本概念 这名字读起来感觉有点矛盾,怎么可能树上面有一个环呢? 我们把它放到百度翻译里面看看。 顾名思义,基环树不是一棵树,而是一颗假树,他的定义是&#…

Acwing.861 二分图的最大匹配(匈牙利算法)

题目 给定一个二分图,其中左半部包含nq个点(编号1n1),右半部包含ng个点(编号1n2),二分图共包含m条边。 数据保证任意—条边的两个端点都不可能在同一部分中。请你求出二分图的最大匹配数。 给定一个二分图G,在G的一个子图M中&…

软件测试基础认知

日升时奋斗,日落时自省 目录 1、测试需求 2、测试用例 3、软件测试BUG 4、开发模型 4.1、软件的生命周期 4.2、瀑布模型(waterFall Model) 4.3、螺旋模型 4.4、 增量模型 4.4.1、增量开发 4.4.2、迭代开发 4.5、敏捷开发&#xf…

【PDFBox】PDFBox操作PDF文档之创建PDF文档、加载PDF文档、添加空白页面、删除页面、获取总页数、添加文本内容、PDFBox坐标系

这篇文章,主要介绍PDFBox操作PDF文档之创建PDF文档、加载PDF文档、添加空白页面、删除页面、获取总页数、添加文本内容、PDFBox坐标系。 目录 一、PDFBox组件 1.1、什么是PDFBox 1.2、创建PDF文档 1.3、加载PDF文档 1.4、添加空白页面 1.5、删除某个页面 1.6…

三分钟了解 SpringBoot 的启动流程

一、前言 背景:最近有位开发同学说面试被问到Spring Boot 的启动流程,以及被问到Spring Boot 的嵌入式Web容器是什么时候加载的。如何加载的。是怎么无缝切换的。 这些问题,其实回答起来也是比较复杂的。我们今天就从 SpringApplication.ru…

3D设计建模软件The Foundry Modo 16对Mac和Windows的系统要求

Foundry MODO是一款功能强大的三维建模、动画和渲染软件。它为艺术家和设计师提供了一套全面的工具,可以用来创建令人惊叹的视觉效果。无论是制作电影、电视节目、游戏还是其他数字媒体内容,MODO都可以满足您的需求。 MODO具有直观的用户界面&#xff0…

redis主从配置

从redis配置:redis6386.conf include /data/redis/redis6380.conf #主redis配置文件路径(这里是引用主配置文件里的配置在修改从配置) daemonize yes #在后台启动 protected-mode no #加密保护关闭 bind 192.168.3.*** requirepas…

云主机安全-私有密钥安全认证

场景描述 云主机凭借其性价比高、生配扩容便利、运维便捷、稳定性高等优势深受用户青睐,越来越多的企业开始租用云主机,将自己的服务器、业务系统等搭建或存储到云主机上。 用户痛点 用户租用或托管的云主机,运维端口(远程桌面&…

SSM框架最新整合保姆级教程(IDEA版)

SSM框架最新整合保姆级教程(IDEA版) 一、环境要求 ​ 环境: IDEAMySQL 5.7.19Tomcat 9Maven 3.6 要求: 需要熟练掌握MySQL数据库,Spring,JavaWeb及MyBatis知识,简单的前端知识; 完整代码:…

Openlayers实战:绘制带箭头的线

Openlayers地图中有的时候会用到这样的场景,连续画几段线段,但是要知道绘制的方向,给人以指引的提示作用。 怎么绘制呢? 在本实战中,主要的是处理线段的显示方式,在线段的拐点处附加上箭头图片,具体看实际的源代码。 效果图 源代码 /* * @Author: 大剑师兰特(xiaozhu…

4 生成全排列

4 生成全排列 作者: 赵晓鹏时间限制: 1S章节: 递归与分治 输入范例 : 无 输出范例 : Perm1(1):123 Perm1(2):123 Perm1(2):213 Perm1(2):321 Perm1(3):123 Perm1(3):132 Perm1(3):213 Perm1(3):231 Perm1(3):321 Perm1(3):312 Online Judge 1.0 #include<iostream> …

【全栈开发指南】数据权限使用配置

数据权限配置有两种方式&#xff1a; 通过系统配置界面&#xff0c;实时配置生效。 通过代码注解配置。 一、通过系统配置界面配置数据权限 系统配置的数据权限是通过系统配置界面将配置信息保存在数据库&#xff0c;然后系统启动时&#xff0c;将配置信息保存到Redis缓存来…

SpringCloud分布式搜索引擎、数据聚合、ES和MQ的结合使用、ES集群的问题

目录 数据聚合 聚合的分类 ​编辑 DSL实现Bucket聚合 ​编辑 DSL实现Metrics聚合​编辑 RestAPI实现聚合 对接前端接口​编辑 自定义分词器​编辑 Completion suggester查询 Completion suggester查询 酒店数据自动补全 实现酒店搜索框界面输入框的自动补全 数据同步问…