【python-sql】sql操作时遇到的坑
针对python的sql语句的封装以及调用:
python的db操作类:
# -*- coding: utf-8 -*-
# coding=utf-8 import MySQLdb class Database(object): [_db_handler, _cursor] = (None, None)
def __init__(self, host=HOST, port=PORT, user='user', passwd='passwd', db_name='mydb'):
try:
self._db_handler = MySQLdb.connect(host, user, passwd, db_name)
self._cursor = self._db_handler.cursor()
except Exception, e:
print e def query(self, table, condition=None, column='*',log=""):
try:
cmd = 'SELECT %s from %s ' % (column, table)
if condition:
cmd = cmd + "WHERE %s" % condition
cmd = cmd + ';'
log.info(cmd)
self._cursor.execute('set NAMES utf8')
self._cursor.execute(cmd)
resultset = self._cursor.fetchall()
rowcount = self._cursor.rowcount
return [resultset, rowcount]
except:
log.error("Error: unable to fecth data") def execute(self, command, parameters,log):
try:
cmd = command % parameters
cmd = cmd + ';'
log.info(cmd)
self._cursor.execute('set NAMES utf8')
rowcount = self._cursor.execute(cmd)
self._db_handler.commit()
return rowcount
except Exception, e:
log.error('error:%s' % str(e))
log.error('execute db error,rollback')
self._cursor.rollback() def batchMysqlOpr(self, sqldata, rsdb):
try:
for item in range(len(sqldata)):
rs = self.query(sqldata[item][1], sqldata[item][2], column=sqldata[item][3])
rsdb.setdefault(sqldata[item][0], rs)
except Exception, e:
print e
return def singleMysqlOpr(self,key,command,paramters,rsdb):
try:
rowcount = self.execute(command, paramters)
if key:
rsdb.setdefault(key, rowcount)
return rowcount
except Exception, e:
print e
return if __name__ == '__main__':
pass
通过以上代码进行具体操作的时候,比如insert操作,如果我的表中第一个字段是自增的,需要insert into biao(ziduan1, ziduan2, ziduan3) values(value1, value2, value3) ,把具体字段写清楚,而不能直接通过insert into biao values(ziduan1, ziduan2, ziduan3)的这种方式来调用
并且,在调用的时候,如果插入的内容是string类型的,则sql的命令需要按照:
sql_command = 'insert into a (ziduan1, ziduan2, ziduan3) values("%s", "%s", "%s")'
#注意sql的命令行语句本身就是str型的,通过''括起来的,values里面的%s就需要通过""双引号括起来,如果外面是双引号,则里面的%s就写成单引号,能区分开就可以
parameters = (string_bianliang1, stringbianliang2, string_bianliang3)
之后进行db.execute(sql_command, paramters),才可以正常运行
这里已经踩过坑了,一定要注意~~~
【python-sql】sql操作时遇到的坑的更多相关文章
- Python文本文件读写操作时的字符编码问题
说明:文本文件的字符编码问题只存在t模式中,如:open('a.txt', mode='rt') 编码(encode): 我们输入的任何字符想要以文件(如.txt)的形式保存在计算机的硬盘上, 必须先 ...
- R和python连接SQL sever 数据库操作
在R的使用中,为了方便提取数据, 我们经常要进行数据库进行操作,接下来我们尝试使用R进行连接数据. 这里我们使用R中的RODBC进行操作, 首先,我们需要先配置ODBC资源管理器 通过任务管理器或者w ...
- python模拟SQL语句操作文件
1.需求 在文本界面输入SQL语句,查询相应的数据,例如输入下面的语句 print(''' 支持大小写的SQL语句查询,大写或者小写都可以 1. select * from db1.emp 2. se ...
- web实践小项目<一>:简单日程管理系统(涉及html/css,javascript,python,sql,日期处理)
暑假自学了些html/css,javascript和python,苦于学完无处练手几乎过目即忘...最后在同学的建议下做了个简单日程管理系统.借第一版完成之际,希望能将实践期间犯过的错误和获得的新知进 ...
- python 连接sql server
linux 下pymssql模块的安装 所需压缩包:pymssql-2.1.0.tar.bz2freetds-patched.tar.gz 安装: tar -xvf pymssql-2.1.0.tar ...
- Python和SQL Server 2017的强大功能
Python和SQL Server 2017的强大功能 摘要: 源:https://www.red-gate.com/simple-talk/sql/sql-development/power-pyt ...
- Python和SQL 2017的强大功能
Python和SQL Server 2017的强大功能 原文来自:https://www.red-gate.com/simple-talk/sql/sql-development/power-py ...
- Django中使用mysql数据库并使用原生sql语句操作
Django自身默认使用sqlite3这个轻量级的数据库,但是当我们开发网站时,sqlite3就没有mysql好,sqlite3适合一些手机上开发使用的数据库. 准备的软件mysql数据库,版本5.7 ...
- HIVE的sql语句操作
Hive 是基于Hadoop 构建的一套数据仓库分析系统,它提供了丰富的SQL查询方式来分析存储在hadoop 分布式文件系统中的数据,可以将结构 化的数据文件映射为一张数据库表,并提供完整的SQL查 ...
随机推荐
- ejs 用到的语法
1.ejs 服务端渲染模板 2.语法: 01. <%= 变量名 %> -原样输出,不解析标签 02. <% js代码 %> 03. <%- 变量名%> -解析标签 ...
- deploy service on swarm
转自:https://www.cnblogs.com/jsonhc/p/7852530.html swarm集群配置完成后,查看一些基本的信息: [root@manager1 ~]# docker-m ...
- Unable to locate Spring NamespaceHandler for XML schema namespace
1. 问题 本文将讨论Spring中最常见的配置问题 —— Spring的一个命名空间的名称空间处理程序没有找到. 大多数情况下,是由于一个特定的Spring的jar没有配置在classpath下,让 ...
- C++多态,虚函数,虚函数表,纯虚函数
1.多态性 指相同对象收到不同消息或不同对象收到相同消息时产生不同的实现动作. C++支持两种多态性:编译时多态性,运行时多态性. a.编译时多态性:通过重载函数实现 ,模板(2次编译) ...
- C语言中插入汇编nop指令
工作过程中,有的时候需要打桩cycle,想在C语言中插入nop指令,可以采取的方法是 头文件中加入#inlude <stdio.h> 定义一个内联函数,然后调用这个函数,不过得测一下平台调 ...
- [Apache]网站页面静态化与Apache调优(图)
---------------------------------------------------------------------------------------------------- ...
- ArcGIS案例学习笔记-点群密度统计
ArcGIS案例学习笔记-点群密度统计 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:对于点群,统计分布密度 数据: 方法: 1. 生成格网 2. 统计个数, ...
- proxool连接sqlerver
原先proxool连接sqlserver,用的是sqljdbc,不知道怎么回事,怎么也连接不上.下面的代码既不报错也不执行下去,应该是驱动出了问题,网上也很难找到sqljdbc什么版本. if (_c ...
- UIApplication 的学习
1.0 URL 的组成 == 协议头://主机名/路径 从iOS7 开始,系统提供了两种管理状态栏的方式,默认交给控制器去管理 2.0 旋转事件----> UIApplication --- ...
- 吴裕雄 python 机器学习-NBYS(1)
import numpy as np def loadDataSet(): postingList=[['my', 'dog', 'has', 'flea', 'problems', 'help', ...