Python连接MySQL数据库之pymysql模块
pymysql 在python3.x 中用于连接MySQL服务器的一个库;Python2中则使用mysqldb
pymysql的模块的基本的使用
# 导入pymysql模块
import pymysql
# 连接database
conn = pymysql.connect(host=“你的数据库地址”, user=“用户名”,password=“密码”,database=“数据库名”,charset=“utf8”)
# 得到一个可以执行SQL语句的光标对象
cursor = conn.cursor()
# 定义要执行的SQL语句
sql = """
CREATE TABLE USER1 (
id INT auto_increment PRIMARY KEY ,
name CHAR(10) NOT NULL UNIQUE,
age TINYINT NOT NULL
)ENGINE=innodb DEFAULT CHARSET=utf8;
"""
# 执行SQL语句
cursor.execute(sql)
# 关闭光标对象
cursor.close()
# 关闭数据库连接
conn.close()
如果想要返回的是字典格式的数据,则光标
# 得到一个可以执行SQL语句并且将结果作为字典返回的游标
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
2. SQL注入问题
1. SQL语句在程序中是字符串,动态拼接的字符串,拿用户输入的内容去拼接字符串
拿用户输入的内容去拼接字符串,会造成一下的问题: --(在SQL语句中表示注释)


2. 不要自己拼接字符串
例子:用数据库来练习登录
import pymysql # # 用数据库来做登录的练习;
#
# username = input("请输入用户名")
# password = input("请输入密码")
#
#
# 连接数据库,获得连接;
conn = pymysql.connect(
host="127.0.0.1", #数据库的id;
port=3306, #数据库的端口号,是int类型的;
user="root", #登录数据库的用户名;
password="123456", #登录数据库的密码;
database="userinfo", #登录后要查看哪个数据库;
charset="utf8" #编码没有-;
)
#
# 获得一个可以执行 SQL语句 的光标对象(cursor);
# cursor = conn.cursor()
# 指定一个具体的光标,返回数据为字典的格式;
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) # # 定义要执行的sql语句;
# sql = "select * from info where username=%s and password=%s;" #%s 只是用来占位;
# #数据库可以按照条件来寻找,
#
# #真正的执行sql语句;
# ret = cursor.execute(sql,[username,password])
# #这里让pyMySQL 帮我们传入参数,为了不让我们自己拼接,从而造成 sql注入;
#
#
# # ret 为返回结果,如果输入的用户名和密码在数据库里面能找到的话,就返回这一行的数据,即返回值不为空;
# # 找不到,则为空;
# if ret:
# print("登录成功")
# else:
# print("登录失败") # 批量操作;
# sql = "insert into user_info(username, password) value(%s,%s);"
sql = "select * from user_info"
cursor.execute(sql) #返回的不是具体的数据,而是受影响的行数; ret = cursor.fetchmany(3) #获得指定数量的数据;fetchone获得一条数据;
print(ret)
# cursor.scroll(1,mode="absolute") #绝对移动,写多少就是移到多少
cursor.scroll(-1,mode="relative") #相对定位,就是相对 光标 当前的位置,整数 是向下移动, 负数 是向上移动;
# # 根据光标取值,取光标下面的值;
ret = cursor.fetchall() #获得所有的数据;
print(ret) # data = [("alex","18"),("egn","22"),("yuan","22")]
# # executemany就是同时执行对个数据,传入的数据必须是 可迭代的
# cursor.executemany(sql,data) #内部实现for循环;
# conn.commit() # 执行SQL语句的时候,报错的话,把它捕捉起来;
# try:
# cursor.executemany(sql,data) #内部实现for循环;
#
# for i in [("a",18),("b"),("c",16)]:
# cursor.execute(sql,i)
# # 改变表里面的数据的时候,需要提交数据;
# conn.commit()
#
# except Exception:
# #有异常,也就是有错误的时候,SQL语句全部都不执行,就像事件一样, # conn.rollback() #回滚
# 一组sql语句批量执行, 要么全部执行成功,要么全部执行失败
cursor.close()
conn.close()
Python连接MySQL数据库之pymysql模块的更多相关文章
- Mysql(九):Python连接MySQL数据库之pymysql模块使用
Python3连接MySQL 本文介绍Python3连接MySQL的第三方库--PyMySQL的基本使用. PyMySQL介绍 PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服 ...
- Python连接MySQL数据库之pymysql模块使用
安装PyMySQL pip install pymysql PyMySQL介绍 PyMySQL是在python3.x版本中用于连接MySQL服务器的一个库,2中则使用mysqldb. Django中也 ...
- python 连接mysql数据库:pymysql
示例:import pymysql conn=pymysql.connect( host="127.0.0.1", #数据库IP port=3306, #数据库端口 user=&q ...
- pymysql模块使用---Python连接MySQL数据库
pymysql模块使用---Python连接MySQL数据库 浏览目录 pymysql介绍 连接数据库 execute( ) 之 sql 注入 增删改查操作 进阶用法 一.pymysql介绍 1.介绍 ...
- Python 3.5 连接Mysql数据库(pymysql 方式)
由于 MySQLdb 模块还不支持 Python3.x,官方的Mysql连接包只支持到3.4,所以 Python3.5 如果想连接MySQL需要安装 pymysql 模块. pymysql 模块可以通 ...
- Python连接MySQL数据库的多种方式
上篇文章分享了windows下载mysql5.7压缩包配置安装mysql 后续可以选择 ①在本地创建一个数据库,使用navicat工具导出远程测试服务器的数据库至本地,用于学习操作,且不影响测试服务器 ...
- python入门(十七)python连接mysql数据库
mysql 数据库:关系型数据库mysql:互联网公司 sqllite:小型数据库,占用资源少,手机里面使用oracle:银行.保险.以前外企.sybase:银行+通信 互联网公司key:valuem ...
- 0x09 Python连接MySQL数据库
本文介绍Python3连接MySQL的第三方库--PyMySQL的基本使用. PyMySQL介绍 PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中 ...
- python连接mysql数据库,并进行添加、查找数据
1.删除MySQL数据表中的记录 DELETE FROM table_name WHERE condition; python操作mysql1数据库 import pymysql # 连接mysql数 ...
随机推荐
- JsonPath如何获取JSON数据中的值
场景: 发送接口请求后,得到请求结果值是Json数据, 需要从Json数据信息中提取字段值. 响应值字符与字符之间有空格,导致用正则表达式方法提取比较麻烦,于是用java的JsonPath方法提取快速 ...
- css实现三角形相关
1.css样式面包屑导航条实现矩形和三角箭头拼接 .cssTest { font-family: PingFangSC-Regular; font-size: 16px; color: #333333 ...
- 使用纳米 Protocol buffers 作为序列化数据
使用纳米 Protocol buffers 作为序列化数据 Protocol Buffers 是 Google 公司开发的一种数据描述语言,类似于XML能够将结构化数据序列化. 但是它更小, 更快, ...
- [svc]tcp三次握手四次挥手&tcp的11种状态(半连接)&tcp的time-wait
TCP的状态转化过程(11种状态)以及TIME_WAIT状态 高性能网络 | 你所不知道的TIME_WAIT和CLOSE_WAIT 我相信很多都遇到过这个问题.一旦有用户在喊:网络变慢了.第一件事情就 ...
- Median
#include <stdio.h> #include <stdlib.h> #include <math.h> #define MAXSIZE 1000 int ...
- linux安装软件时提示找不到镜像的问题:Couldn't resolve host 'mirrorlist.centos.org'
问题:[root@cddserver2 ~]# yum -y install gcc-*Loaded plugins: fastestmirror, prestoCould not retrieve ...
- 一位数组的最大子数组(debug版)
package 数组; import java.util.Arrays; import java.util.Scanner; public class Sum { public static void ...
- C++模板的要点
1.函数模板与普通函数的区别: 普通函数可以进行自动类型转化,而函数模板不可以. 举个例子 //函数模板 template<class T> void show(T a,T b){ cou ...
- 用requests库和BeautifulSoup4库爬取新闻列表
import requests from bs4 import BeautifulSoup url='http://news.gzcc.cn/html/xiaoyuanxinwen/' res=req ...
- 【JavaScript】常用的数据类型的处理方式
写这篇文章的目的,是在学习过程中反复查找如何对这三种数据类型进行转换的方法,所以干脆总结在一起. 一.字符串 0.includes:string.includes(),查找当前string中是否包含某 ...