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提取视频文件中的音频

《详解如何使用Python提取视频文件中的音频》在多媒体处理中,有时我们需要从视频文件中提取音频,本文为大家整理了几种使用Python编程语言提取视频文件中的音频的方法,大家可以根据需要进行选择... 目录引言代码部分方法扩展引言在多媒体处理中,有时我们需要从视频文件中提取音频,以便进一步处理或分析。本文

python多种数据类型输出为Excel文件

《python多种数据类型输出为Excel文件》本文主要介绍了将Python中的列表、元组、字典和集合等数据类型输出到Excel文件中,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一.列表List二.字典dict三.集合set四.元组tuplepython中的列表、元组、字典

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

VSCode配置Anaconda Python环境的实现

《VSCode配置AnacondaPython环境的实现》VisualStudioCode中可以使用Anaconda环境进行Python开发,本文主要介绍了VSCode配置AnacondaPytho... 目录前言一、安装 Visual Studio Code 和 Anaconda二、创建或激活 conda

pytorch+torchvision+python版本对应及环境安装

《pytorch+torchvision+python版本对应及环境安装》本文主要介绍了pytorch+torchvision+python版本对应及环境安装,安装过程中需要注意Numpy版本的降级,... 目录一、版本对应二、安装命令(pip)1. 版本2. 安装全过程3. 命令相关解释参考文章一、版本对

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

MySQL中COALESCE函数示例详解

《MySQL中COALESCE函数示例详解》COALESCE是一个功能强大且常用的SQL函数,主要用来处理NULL值和实现灵活的值选择策略,能够使查询逻辑更清晰、简洁,:本文主要介绍MySQL中C... 目录语法示例1. 替换 NULL 值2. 用于字段默认值3. 多列优先级4. 结合聚合函数注意事项总结C