python_操作linux上的mysql
在编写初期,遇见一个问题,发现怎么连接不上mysql,一直报错1045;
最后发现,只要下面的,连接写正确,不会出现这个问题, 只要你保证你的user、pwd是正确的,

import pymysql
db_config = {
'user': 'root',
'password': 'qwe123',
'db': 'test',
'charset':'utf8'
}
# 连接mysql数据库
con = pymysql.connect(**db_config)
# 创建游标 , 利用游标来执行sql语句
cur = con.cursor()
基本连接是没有问题的。
那我在重复下基本操作命令:
1、建立连接:pymysql.connect(**dbconfig)
连接是不能操作数据库的,需要用连接生成游标来操作
2、创建游标: connection.cursor()
3、执行SQL语句:cursor.execute(sql)
4、获取结果:cur.fetchall()
5、事务的回滚: rollback()
6、事务的提交: commit()
这时,咱们在xshell_mysql 新建一些数据
新建表数据:
CREATE TABLE data_test(
id INT unique,
name VARCHAR(50),
age INT,
sex enum('男','女')
);
表内插入数据:
insert into data_test(id, name, age, sex) VALUES(1, '李牧', 18, '男'),(2, '栗子', 20, '女'),(3, '测试', 26, '男'),(4, '尕娃', 30, '女');
那么在xshell中查询结果如下:

那么我们在pycharm 怎么连接并查询数据呢?
import pymysql def tes_mysql():
db_config = {
'user': 'root',
'password': 'qwe123',
'db': 'test',
'charset':'utf8'
}
# 连接mysql数据库
con = pymysql.connect(**db_config)
# 创建游标 , 利用游标来执行sql语句
cur = con.cursor() try:
# 执行sql语句,不会返回结果,返回其影响的行数
executes = cur.execute("select * from data_test")
# 获取结果
values = cur.fetchall()
for value in values:
print(value) # 提交到数据库,真正把数据插入或者更新到数据
con.commit()
except Exception as e:
print(e)
# 发生了异常,回滚
con.rollback() finally:
# 在最后使用完关闭游标和连接
# 关闭游标
cur.close()
# 关闭连接
con.close()
再进行个参数化把,
定义 test_base.py
import pymysql def tes_mysql(sql):
db_config = {
'user': 'root',
'password': 'qwe123',
'db': 'test',
'charset':'utf8'
}
# 连接mysql数据库
con = pymysql.connect(**db_config)
# 创建游标 , 利用游标来执行sql语句
cur = con.cursor() try:
# 执行sql语句,不会返回结果,返回其影响的行数
executes = cur.execute(sql)
# 获取结果
values = cur.fetchall()
for value in values:
print(value) # 提交到数据库,真正把数据插入或者更新到数据
con.commit()
except Exception as e:
print(e)
# 发生了异常,回滚
con.rollback() finally:
# 在最后使用完关闭游标和连接
# 关闭游标
cur.close()
# 关闭连接
con.close()
run_select.py
from day.test_base import tes_mysql sql = "select * from data_test"
# 实例化
a = tes_mysql(sql)
运行结果:

简单记录一下。
作者:含笑半步颠√
博客链接:https://www.cnblogs.com/lixy-88428977
声明:本文为博主学习感悟总结,水平有限,如果不当,欢迎指正。如果您认为还不错,欢迎转载。转载与引用请注明作者及出处。
python_操作linux上的mysql的更多相关文章
- 怎样在 Ubuntu Linux 上安装 MySQL
		本教程教你如何在基于 Ubuntu 的 Linux 发行版上安装 MySQL.对于首次使用的用户,你将会学习到如何验证你的安装和第一次怎样去连接 MySQL. -- Sergiu MySQL 是一个典 ... 
- sqlyog连接Linux上的mysql报错误号码2013,错误号码1130的解决办法
		sqlyog连接Linux上的mysql报错误号码2013,错误号码1130的解决办法 1.报错误号码2013,可能是端口号不是默认的3306,需要改成对应的,检查命令是: [root@host et ... 
- Linux上通过MySQL命令访问MySQL数据库时常见问题汇总
		Linux上通过mysql命令访问MySQL数据库时常见问题汇总 1)创建登录账号 #创建用户并授权 #允许本地访问 create user 'test'@'localhost' identified ... 
- 【数据库开发】在Windows上和Linux上配置MySQL的过程
		[数据库开发]在Windows上和Linux上配置MySQL的过程 标签(空格分隔): [编程开发] 首先是在Windows上尝试用QT进行MySQL数据库开发,结果总出现driver不能load的错 ... 
- linux上安装 mysql
		一.linux 上安装 mysql 1.查看mysql是否安装 rpm -qa|grep mysql 2.卸载 mysql yum remove mysql mysql-server mysql-li ... 
- Linux上安装mysql,实现主从复制
		MYSQL(mariadb) MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可.开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的 ... 
- Linux 上从 MySQL 迁移到 MariaDB 的简单步骤
		大家好!这是一篇介绍如何在服务器或个人电脑上从MySQL迁移到MariaDB的教程.也许你会问为什么我们要将数据库管理从MySQL迁移到MariaDB.往下看我们告诉你为什么这样做.为什么要用Mari ... 
- linux上安装mysql,tomcat,jdk
		Linux 上安装 1 安装jdk 检测是否安装了jdk 运行 java –version 若有 需要将其卸载 a) 查看安装哪些jdk rmp –qa |grep java b) ... 
- linux上,mysql使用聚合函数group by 时报错:SELECT list is not in GROUP BY clause and contains nonaggre的问题
		之前在windows上测试是可以正常使用的,但是上传到Linux上后,就报错: Expression # of SELECT list is not in GROUP BY clause and co ... 
随机推荐
- cogs 943. [東方S3] 铃仙•优昙华院•稻叶
			二次联通门 : cogs 943. [東方S3] 铃仙•优昙华院•稻叶 /* cogs 943. [東方S3] 铃仙·优昙华院·稻叶 概率dp 貌似做麻烦了 邻接矩阵和链式前向星都用上了... dp[ ... 
- 【Python】[技术博客] 一些使用Python编写获取手机App日志的操作
			一些使用Python编写获取手机App日志的操作 如何获取手机当前打开的App的包名 如何获取当前App进程的PID 如何查看当前App的日志 如何将日志保存到文件 如何关闭进程 如何不显示命令行窗口 ... 
- tensorflow 2.0 的资料
			https://github.com/jtoy/awesome-tensorflow https://github.com/Amin-Tgz/awesome-tensorflow-2 https:// ... 
- SAS 获取系统选项设置的过程步 PROC OPTIONS OPTION=()
			PROC OPTIONS OPTION=(VALIDVARNAME LS);RUN; 
- HIVE-计算累计和
			eg:统计1-12月的累积销量,即1月为1月份的值,2月为1.2月份值的和,3月为123月份的和,12月为1-12月份值的和 SELECT month,SUM(amount) month_amou ... 
- clickhouse 19.14.m.n简单测试
			ClickHouse is a column-oriented database management system (DBMS) for online analytical processing o ... 
- Xmanager PowerSuite 6企业版详细安装破解教程,解决评估过期问题(附注册机,全网独家可用),非学校/家庭免费版
			title: "Xmanager PowerSuite 6企业版详细安装破解教程,解决评估过期问题(附注册机,全网独家可用),非学校/家庭免费版" categories: soft ... 
- Android之WebRTC介绍
			参考自:Introduction to WebRTC on AndroidAndroid之WebRTC介绍 WebRTC被誉为是web长期开源开发的一个新启元,是近年来web开发的最重要创新.WebR ... 
- jdk1.8使用枚举类
			package com.mq; import java.util.Arrays; import java.util.HashMap; import java.util.Map; public enum ... 
- tf.tile()函数理解
			转载:https://blog.csdn.net/tsyccnh/article/details/82459859 tensorflow中的tile()函数是用来对张量(Tensor)进行扩展的,其特 ... 
