Python2.7编程中SQLite3基本操作方法示例


Posted in Python onAugust 09, 2017

本文实例讲述了Python2.7中SQLite3基本操作方法。分享给大家供大家参考,具体如下:

1、基本操作

# -*- coding: utf-8 -*-
#!/usr/bin/env python
import sqlite3
def mykey(x):
  return x[3]
conn=sqlite3.connect("D:\\demo\\my_db.db")
sql = "CREATE TABLE IF NOT EXISTS mytb ( a char , b int , c real, d DATE)"
# a char , b int , c real 表示该表有三个字段,
# a 是字符串类型, b 是整数类型, c 是实数类型。
conn.execute( sql )
cs = conn.cursor()
#cs.execute("DELETE FROM mytb WHERE A='张三' ")
cs.execute("DELETE FROM mytb  ")
#删除所有记录
'''''
cs.execute( "INSERT INTO mytb ( a,b,c,d ) values('Zhang San',25, 120, '2014-03-04')" )
cs.execute( "INSERT INTO mytb ( a,b,c,d ) values( 'Wang Wu',24, 110, '2014-05-01')" )
cs.execute( "INSERT INTO mytb ( a,b,c,d ) values( 'Li Si',23, 130, '2014-04-06')" )
'''
#批量注入,batchdata是一个列表,列表里每一个元素都是一个元组
batchdata=[('Zhang San',25, 120, '2014-03-04'),
      ( 'Wang Wu',24, 110, '2014-05-01'),
      ( 'Li Si',23, 130, '2014-04-06')]
cs.executemany('INSERT INTO mytb values (?,?,?,?)',batchdata)
conn.commit() #将加入的记录保存到磁盘,非常重要!
cs.execute("SELECT name, sql FROM sqlite_master WHERE type='table'")
recs = cs.fetchall( )
print ( recs )
cs.execute( "SELECT * FROM mytb ")#打开数据表
recs = cs.fetchall()#取出所有记录
print ( "there is ", len(recs)," notes." )
print recs
recs.sort(key = mykey)
print recs
cs.close()
conn.close()

2、删除一条记录,使用sql字符串变量可以实现带参数的删除

sql="DELETE FROM my_table WHERE number='" + my_num + "'"
cs.execute(sql)

3、查询某一条或多条记录

如果SQLite3查找的数据库记录中含有中文,取出到Python时要对数据进行decode处理。当时我上网查的时候说要用GBK解码,但我自己却解码失败了,换成utf-8解码才成功显示。 另外,如果只查询一条可以用fetchone语句,或者fetchall之后再通过python把它找出来。

sql="SELECT name FROM my_table WHERE number ='" + my_num + "'"
cs.execute(sql)
the_name=(cs.fetchall())[0][0].decode('utf-8')

4、避免重复注入

有时候我们会有重复的记录,为了避免把相同的记录多次插入到数据库,可以使用如下语句:

sql="INSERT OR REPLACE INTO "+my_table+" values (?,?,?,?,?,?,?) "
#假设my_table有7项

5、插入中文记录至SQLite3

Python是unicode编码,但数据库对中文是使用GBK编码,比如stock_name变量含有中文,则需要做unicode(name, "gbk")处理

batch=[(stock_num, unicode(stock_name, "gbk") )]
cs.executemany( "INSERT OR REPLACE INTO my_table values (?,?) ",batch)

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python基础教程之循环介绍
Aug 29 Python
菜鸟使用python实现正则检测密码合法性
Jan 05 Python
python中Pycharm 输出中文或打印中文乱码现象的解决办法
Jun 16 Python
Python实现获取nginx服务器ip及流量统计信息功能示例
May 18 Python
Python3.5实现的三级菜单功能示例
Mar 25 Python
Python除法之传统除法、Floor除法及真除法实例详解
May 23 Python
Pytorch之Variable的用法
Dec 31 Python
Python中用pyinstaller打包时的图标问题及解决方法
Feb 17 Python
python selenium操作cookie的实现
Mar 18 Python
python对XML文件的操作实现代码
Mar 27 Python
python实现五子棋程序
Apr 24 Python
使用python将微信image下.dat文件解密为.png的方法
Nov 30 Python
Django 前后台的数据传递的方法
Aug 08 #Python
关于python pyqt5安装失败问题的解决方法
Aug 08 #Python
利用Python自带PIL库扩展图片大小给图片加文字描述的方法示例
Aug 08 #Python
利用python打印出菱形、三角形以及矩形的方法实例
Aug 08 #Python
Python正则表达式非贪婪、多行匹配功能示例
Aug 08 #Python
关于Python 3中print函数的换行详解
Aug 08 #Python
Python tkinter模块中类继承的三种方式分析
Aug 08 #Python
You might like
php面向对象全攻略 (十一)__toString()用法 克隆对象 __call处理调用错误
2009/09/30 PHP
php中的比较运算符详解
2013/10/28 PHP
如何写php守护进程(Daemon)
2015/12/30 PHP
非常漂亮的JS代码经典广告
2007/10/21 Javascript
Javascript 加载和执行-性能提高篇
2012/12/28 Javascript
Jquery插件分享之气泡形提示控件grumble.js
2014/05/20 Javascript
JavaScript-RegExp对象只能使用一次问题解决方法
2014/06/23 Javascript
js使用split函数按照多个字符对字符串进行分割的方法
2015/03/20 Javascript
javascript日期计算实例分析
2015/06/29 Javascript
js跨域请求的5中解决方式
2015/07/02 Javascript
深入探究AngularJS框架中Scope对象的超级教程
2016/01/04 Javascript
jQuery获取剪贴板内容的方法
2016/06/16 Javascript
Bootstrap CDN和本地化环境搭建
2016/10/26 Javascript
JavaScript验证知识整理
2017/03/24 Javascript
JS实现线性表的顺序表示方法示例【经典数据结构】
2017/04/11 Javascript
thinkjs 文件上传功能实例代码
2017/11/08 Javascript
使用Phantomjs和Node完成网页的截屏快照的方法
2019/07/16 Javascript
使用python删除nginx缓存文件示例(python文件操作)
2014/03/26 Python
Python复制目录结构脚本代码分享
2015/03/06 Python
Python 列表排序方法reverse、sort、sorted详解
2016/01/22 Python
Python有序查找算法之二分法实例分析
2017/12/11 Python
使用matplotlib画散点图的方法
2018/05/25 Python
解决python报错MemoryError的问题
2018/06/26 Python
python使用epoll实现服务端的方法
2018/10/16 Python
python中如何实现将数据分成训练集与测试集的方法
2019/09/13 Python
python二维图制作的实例代码
2020/12/03 Python
俄罗斯美容和健康网上商店:Созвездие Красоты
2019/07/23 全球购物
C++是不是类型安全的
2014/02/18 面试题
初中生三年学习生活的自我评价
2013/11/03 职场文书
工厂采购员岗位职责
2014/04/08 职场文书
个性婚礼策划方案
2014/05/17 职场文书
服务标语大全
2014/06/18 职场文书
入党积极分子学习优秀共产党员先进事迹思想汇报
2014/09/13 职场文书
2015年学校政教处工作总结
2015/05/26 职场文书
Golang全局变量加锁的问题解决
2021/05/08 Golang
《艾尔登法环》1.03.3补丁上线 碎星伤害调整
2022/04/06 其他游戏