python操作mysql方法和常见问题
来源:互联网 发布:windows api 参考手册 编辑:程序博客网 时间:2024/05/17 22:50
安装mysql模块
sudo easy_install mysql-python
连接数据库
1 #!/usr/bin/env python2 #coding=utf-83 import MySQLdb4 conn = MySQLdb.connect('localhost','root','rootpass','oj',charset='utf8')5 cur = conn.cursor()
连接数据库时要注意数据库编码,不然一堆编码问题很愁人的~最好统一使用utf8编码。
执行sql语句
1 sql_content = "select * from user"2 cur.execute(sql_content)3 data = cur.fetchall()4 for i in data:5 print i
可以用fetchone来获取一条结果。如果是插入数据,要执行commit操作,不然数据不会被写入数据库。最好是执行完所有的sql语句之后再commit,实践证明,这样会带来很大的速度提升。
重点讲讲插入和更新数据
插入或更新数据有两种方法
1.拼接sql语句:
sql_content = "insert into table(key1,key2,key3) values (%s,%s,%s)"%(value1,value2,value3)cur.execute(sql_content)
2.用问号替代
sql_content = "insert into table(key1,key2,key3) values (?,?,?)"cur.execute(sql_content,(value1,value2,value3))
如果value的值存在不确定性,那么上面两条语句存在sql注入风险。
例如,如果value是一段html代码,html代码中如果存在引号(但引号或者双引号),如果不加处理,那么sql语句就将被截断,将会引发插入错误。
如果value中存在英文逗号,将会造成前面的key和后面的value不对应,也不能正确插入数据。
如果value中存在反斜线\,那么在python中反斜线后面的数据将被转义,如果不处理插入的话将会造成字符丢失或者其他不可遇见的结果。
因为在sql中和在python中有好多含有特殊含义的符号,如果不能很好的处理的话将会出现好多问题,幸好MYSQLdb模块给我们提供了一个escape_string方法,用这个方法能自动处理好上面的问题,特别方便。
此外,不建议一次插入多个数据,因为一次插入多个数据有可能造成key和value不能对应,昨天因为这个问题纠结了一下午。最后将一条sql语句拆成多条语句,也就是一次插入一个value才将问题解决
<script type="text/javascript"><!--google_ad_client = "ca-pub-1944176156128447";/* cnblogs 首页横幅 */google_ad_slot = "5419468456";google_ad_width = 728;google_ad_height = 90;//--></script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
- python操作mysql方法和常见问题
- python操作mysql方法和常见问题
- python操作mysql方法和常见问题
- python链接mysql常见问题
- python mysql 常见问题汇总
- python操作MySQL和mongoDB
- Python常见问题和技巧
- python操作MySQL数据库的方法分享
- Python操作MySQL数据库方法小结
- python操作mysql的两个方法
- Mysql常见问题和错误
- python链接mysql常见问题汇总
- python链接mysql常见问题汇总
- 通过python操作mysql和orm操作mysql
- python 和mysql的简单操作
- 基于python和mysql的查询操作
- python通过sqlalchemy操作mysql和sqlserver
- [python]Python操作MySQL
- Reclaimable Storage -- 可回收表空间
- 黑马程序员——IO流-字符流&装饰设计模式
- HDU-2048神、上帝以及老天爷
- oracle学习之存储过程(1)语法
- git设置命令别名
- python操作mysql方法和常见问题
- Canny边缘检测算法原理及其VC实现详解(二)
- mybatis类和xml
- iOS学习笔记26—iPhone开发常识集锦
- winfrom实现闹钟
- strcpy_s和strcpy()
- QTcpSocket类 客户端/服务器模式
- zoj_3621 Factorial Problem in Base K
- 根据两点计算距离