Skr-Eric的Mysql课堂(七)——Mysql的用户管理、调优、与Python的交互

2024-03-14 03:10

本文主要是介绍Skr-Eric的Mysql课堂(七)——Mysql的用户管理、调优、与Python的交互,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL用户账户管理

  1、开启MySQL远程连接(改配置文件)

    1、sudo -i

    2、cd /etc/mysql/mysql.conf.d/

    3、cp mysqld.cnf mysqld.cnf.bak2

    4、vi mysqld.cnf

      #bind-address=127.0.0.1

      把前面 # 去掉,保存退出

      vi mysqld.cnf

      按a -> 改内容 -> 按ESC -> 按 shift + : -> wq

    5、/etc/init.d/mysql restart

  2、用root用户添加授权用户

    1、用root用户登录mysql

      mysql -uroot -p123456

    2、授权

      grant 权限列表 on 库名.表名

      to "用户名"@"%" identified by "密码"

      with grant option;

      权限列表 :all privileges、select、update

      库名.表名 :db4.* 、*.*(所有库的所有表)

    3、示例

      1、添加授权用户tiger,密码123,对所有库的所有表有所有权限,可从任何IP去连接

        grant all privileges on *.*

        to "tiger"@"%"

        identified by "123"

        with grant option;

      2、添加授权用户rabbit,密码123,对db4库所有表只有查询权限,可从任何IP去连接

        grant select on db4.*

        to "rabbit"@"%" identified by "123"

        with grant option;

 

MySQL调优

  1、创建索引

    在select、where、order by常涉及到的字段建立索引

  2、选择合适存储引擎

    1、读操作多 :MyISAM

    2、写操作多 :InnoDB

  3、SQL语句优化(避免全表扫描)

    1、where子句尽量不使用 != ,否则放弃索引全表扫描

    2、尽量避免NULL判断,全表扫描

      优化前:

        select number from t1 where number is null;

      优化后:

        在number字段设置默认值0,确保number字段无NULL

        select number from t1 where number=0;

    3、尽量避免用or连接条件,否则全表扫描

      优化前:

        select id from t1 where id=10 or id=20;

      优化后:

        select id from t1 where id=10

        union all

select id from t1 where id=20;

    4、模糊查询尽量避免使用前置 %,否则全表扫描

      select variable from t1 where name="secure%";

    5、尽量避免使用in和not in,否则全表扫描

      优化前 :

        select id from t1 where id in(1,2,3,4);

      优化后 :

        select id from t1 where id between 1 and 4;

    6、不能使用 select * ...

      用具体字段代替*,不要返回用不到的任何字段

 

与Python交互

  1、交互类型

    1、python3

      模块名 :pymysql

      安装 :

        1、在线 :sudo pip3 install pymysql

2、离线 :pymysql.tar.gz

  解压:setup.py

        python3 setup.py install

    2、python2

      模块名 :MySQLdb

      安装 :sudo pip install mysql-python

  2、pymysql使用流程

    1、建立数据库连接对象(db=pymysql.connect("root".

    2、创建游标对象cur(操作数据库的对象)

    3、游标对象:cur.execute("insert into sheng ...;")

    4、提交到数据库执行 :db.commit()

    5、关闭游标对象cur.close()

    6、关闭数据库连接对象db.close()

    示例 :01_pymysql示例.py

  3、connect连接对象

    1、db = pymysql.connect(参数列表)

      1、host :主机地址

      2、user :用户名

      3、password :密码

      4、database :库

      5、charset :编码方式,推荐utf8

      6、port :端口(3306)

    2、db (数据库连接对象) 的方法

      1、db.close() :断开连接

      2、db.commit() :提交到数据库执行

      3、db.cursor() :游标对象,用来执行SQL命令

      4、db.rollback() :回滚

    3、cursor 游标对象 的方法

      1、execute(SQL命令) :执行SQL命令

      2、close() :关闭游标对象

      3、fetchone() :获取查询结果的第1条数据

      4、fetchmany(n) :获取n条数据

      5、fetchall() :获取所有数据

      ## fetchmany(n) 和 fetchall() 得到的结果一定是一个大元组套着小元组 ((),(),())

 

 

想要看更多的课程请微信关注SkrEric的编程课堂

这篇关于Skr-Eric的Mysql课堂(七)——Mysql的用户管理、调优、与Python的交互的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807027

相关文章

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1