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

相关文章

Python实现Word转PDF全攻略(从入门到实战)

《Python实现Word转PDF全攻略(从入门到实战)》在数字化办公场景中,Word文档的跨平台兼容性始终是个难题,而PDF格式凭借所见即所得的特性,已成为文档分发和归档的标准格式,下面小编就来和大... 目录一、为什么需要python处理Word转PDF?二、主流转换方案对比三、五套实战方案详解方案1:

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

MySQL 索引简介及常见的索引类型有哪些

《MySQL索引简介及常见的索引类型有哪些》MySQL索引是加速数据检索的特殊结构,用于存储列值与位置信息,常见的索引类型包括:主键索引、唯一索引、普通索引、复合索引、全文索引和空间索引等,本文介绍... 目录什么是 mysql 的索引?常见的索引类型有哪些?总结性回答详细解释1. MySQL 索引的概念2

Linux权限管理与ACL访问控制详解

《Linux权限管理与ACL访问控制详解》Linux权限管理涵盖基本rwx权限(通过chmod设置)、特殊权限(SUID/SGID/StickyBit)及ACL精细授权,由umask决定默认权限,需合... 目录一、基本权限概述1. 基本权限与数字对应关系二、权限管理命令(chmod)1. 字符模式语法2.

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

使用Python的requests库调用API接口的详细步骤

《使用Python的requests库调用API接口的详细步骤》使用Python的requests库调用API接口是开发中最常用的方式之一,它简化了HTTP请求的处理流程,以下是详细步骤和实战示例,涵... 目录一、准备工作:安装 requests 库二、基本调用流程(以 RESTful API 为例)1.

Python清空Word段落样式的三种方法

《Python清空Word段落样式的三种方法》:本文主要介绍如何用python-docx库清空Word段落样式,提供三种方法:设置为Normal样式、清除直接格式、创建新Normal样式,注意需重... 目录方法一:直接设置段落样式为"Normal"方法二:清除所有直接格式设置方法三:创建新的Normal样

Python调用LibreOffice处理自动化文档的完整指南

《Python调用LibreOffice处理自动化文档的完整指南》在数字化转型的浪潮中,文档处理自动化已成为提升效率的关键,LibreOffice作为开源办公软件的佼佼者,其命令行功能结合Python... 目录引言一、环境搭建:三步构建自动化基石1. 安装LibreOffice与python2. 验证安装

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

Python按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和