TOC

当我们在写程序中需要使用到数据库的时候,尽量在代码层次实现一些限制,例如两张表,我们不再使用外键去关联表与表之间的关系,我们可以在程序层面修改其中的一张表,再去修改另一张表的数据,这样会减轻数据库的压力,代码层次可以实现的,就不要再去使用数据库。

pymysql的语法

import pymysql  # 下载并导入pymysql模块

# 建立连接,并产生一个连接会话对象
conn = pymysql.connect(
user='root',
password='123',
host='127.0.0.1',
port=3306, # 注意:端口号不需要用引号引起来
charset='utf8',
database='db1'
)
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) # 产生一个游标对象
# cursor=pymysql.cursors.DictCursor 将查询出来的结果制作成字典的形式返回
# 若不加,则返回的是括号加数据,例如:(1, 张三),不会显示表中的字段,很不方便
sql = 'select * from user_info' # 语句后可不加分号,pymysql会自动添加
res = cursor.execute(sql) # 执行sql语句
# print(res) # execute返回的是当前sql语句所影响的行数,并不是查询结构
# ret = cursor.fetchone() # 只获取查询的结果中的一条数据
# ret = cursor.fetchall() # 获取查询结果的全部数据
# ret = cursor.fetchmany(2) # 获取指定行数的数据,如果数字超了,也不会报错
# print(ret)
print(cursor.fetchone())
print(cursor.fetchone()) # 连续使用2次,并不会重复展示表中的第一条数据,执行一次取掉一次数据,执行第二次就取表中的第二行数据
# 相对移动
cursor.scroll(2, 'relative') # 基于指针所在的位置 往后偏移 # 绝对移动
cursor.scroll(1, 'absolute') # 基于起始位置,往后偏移

sql注入问题

利用特殊符号和注释语法 巧妙的绕过真正的sql校验

关键性的数据 不要自己手动去拼接 而是交由execute帮你去做拼接

采用手动拼接的情况

import pymysql

conn = pymysql.connect(
user='root',
password='123',
host='localhost',
port=3306,
charset='utf8',
database='db1'
) cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
username = input('username>>').strip()
password = input('password>>').strip()
sql = "select * from user_info where name = '%s' and password = '%s'" % (username, password)
# sql = 'select * from user_info where name = "%s" and password = "%s"' % (username, password)
# select * from user_info where name = "张三' -- fhjkasdhfkla" and password = "" 外层使用单引号出不来效果
print(sql)
cursor.execute(sql)
res = cursor.fetchall()
if res:
print(res)
else:
print('username or password error!')

解决办法:

交给pymysql中的execute进行处理

import pymysql

conn = pymysql.connect(
user='root',
password='123',
host='localhost',
port=3306,
charset='utf8',
database='db1'
) cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
username = input('username>>').strip()
password = input('password>>').strip()
# sql = "select * from user_info where name = '%s' and password = '%s'" % (username, password)
# sql = 'select * from user_info where name = "%s" and password = "%s"' % (username, password)
# select * from user_info where name = "张三' -- fhjkasdhfkla" and password = "" 外层使用单引号出不来效果
sql = "select * from user_info where name = %s and password = %s"
print(sql)
# cursor.execute(sql)
cursor.execute(sql, (username, password))
res = cursor.fetchall()
if res:
print(res)
else:
print('username or password error!')

数据的增删查改

尝试进行增操作:

import pymysql

conn = pymysql.connect(
user='root',
password='123',
host='localhost',
port=3306,
charset='utf8',
database='db1'
) cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
sql = 'insert into user_info(name, password) value("刘和平", 17)'
res = cursor.execute(sql)
print(res)

让我们去表中看看,是否增加上去:

显然,并没有新增一条数据。

在pymysql中,如果进行增删改等操作,对于这些执行重要程度偏高的语句,需要有一步确认操作(commit):

import pymysql

conn = pymysql.connect(
user='root',
password='123',
host='localhost',
port=3306,
charset='utf8',
database='db1'
) cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
sql = 'insert into user_info(name, password) value("刘和平", 17)'
res = cursor.execute(sql)
conn.commit() # 提交
print(res)

观察表中的数据:

最新文章

  1. Genesis2000使用c#开发脚本
  2. Ecshop 最小起订量如何设置
  3. Codeforces Round #246 (Div. 2)——D题
  4. Android之开发杂记(二)
  5. 纯IPv6环境App适配的坑
  6. set用法总结
  7. hdu 4291 A Short problem(矩阵+取模循环节)
  8. maven打包配置
  9. js模块化开发——require.js的实战写法1
  10. mysql批量插入语句执行失败的话,是部分失败还是全部失败
  11. spring boot集成netty-服务端和客户端demo
  12. FastStone Capture激活码
  13. windows下创建启动脚本bat
  14. scrapy splash 之一二
  15. 登录rabbitmq报错User can only log in via localhost
  16. Kubernetes报错Failed to get system container stats for "/system.slice/kubelet.service"
  17. whatweb.rb 未完待续
  18. slave库写redo、binlog不实时丢数据的场景
  19. Java并发编程--1.Thread和Runnable
  20. sql server 里的文件和文件组使用

热门文章

  1. jQuery 源码分析(十三) 数据操作模块 DOM属性 详解
  2. Docker开启Remote API 访问 2375端口
  3. 敏捷软件开发_设计原则<三>
  4. Unity API学习笔记(2)-GameObject的3种Message消息方法
  5. JavaScript 正则表达式 初探
  6. SQLMAP之tamper详解
  7. IDEA下新建Vue项目
  8. CSS 轻松搞定标签(元素)居中问题
  9. Linux:使用LVM进行磁盘管理
  10. Windows文件夹共享和Unity的PersisterdataPath