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开发之字符串string操作方法实例详解
Nov 12 Python
用Pygal绘制直方图代码示例
Dec 07 Python
python定向爬虫校园论坛帖子信息
Jul 23 Python
Python读取YUV文件,并显示的方法
Dec 04 Python
Python利用字典破解WIFI密码的方法
Feb 27 Python
python解压TAR文件至指定文件夹的实例
Jun 10 Python
基于Tensorflow使用CPU而不用GPU问题的解决
Feb 07 Python
python用pip install时安装失败的一系列问题及解决方法
Feb 24 Python
浅谈keras.callbacks设置模型保存策略
Jun 18 Python
Python爬取网页信息的示例
Sep 24 Python
python时间time模块处理大全
Oct 25 Python
用python获取txt文件中关键字的数量
Dec 24 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
phpMyAdmin安装并配置允许空密码登录
2015/07/04 PHP
jQuery 改变CSS样式基础代码
2010/02/11 Javascript
javascript算法题 求任意一个1-9位不重复的N位数在该组合中的大小排列序号
2012/07/21 Javascript
node.js中的fs.readlink方法使用说明
2014/12/17 Javascript
JavaScript分秒倒计时器实现方法
2015/02/02 Javascript
jquery动态添加删除(tr/td)
2015/02/09 Javascript
JS+CSS实现自动切换的网页滑动门菜单效果代码
2015/09/14 Javascript
JS实现的自定义网页拖动类
2015/11/06 Javascript
javascript新闻跑马灯实例代码
2020/07/29 Javascript
jquery zTree异步加载简单实例讲解
2016/02/25 Javascript
AngularJS中如何使用echart插件示例详解
2016/10/26 Javascript
JavaScript仿微博发布信息案例
2016/11/16 Javascript
Nodejs回调加超时限制两种实现方法
2017/06/09 NodeJs
vuejs选中当前样式active的实例
2018/08/22 Javascript
Vuex mutitons和actions初使用详解
2019/03/04 Javascript
微信小程序返回箭头跳转到指定页面实例解析
2019/10/08 Javascript
[01:13:01]2018DOTA2亚洲邀请赛 4.4 淘汰赛 TNC vs VG 第三场
2018/04/05 DOTA
Python代码调试的几种方法总结
2015/04/15 Python
Python程序中使用SQLAlchemy时出现乱码的解决方案
2015/04/24 Python
python 爬虫出现403禁止访问错误详解
2017/03/11 Python
python shell根据ip获取主机名代码示例
2017/11/25 Python
python编写分类决策树的代码
2017/12/21 Python
Win10下python3.5和python2.7环境变量配置教程
2018/09/18 Python
python使用百度文字识别功能方法详解
2019/07/23 Python
python如何将多个PDF进行合并
2019/08/13 Python
python如何对链表操作
2020/10/10 Python
HTML5 Canvas的事件处理介绍
2015/04/24 HTML / CSS
戴尔荷兰官方网站:Dell荷兰
2020/10/04 全球购物
创伤外科专业推荐信范文
2013/11/19 职场文书
学校党的群众路线教育实践活动整改措施
2014/10/25 职场文书
2014年高中班主任工作总结
2014/11/08 职场文书
英语通知范文
2015/04/22 职场文书
jQuery实现影院选座订座效果
2021/04/13 jQuery
SQL Server作业失败:无法确定所有者是否有服务器访问权限的解决方法
2021/06/30 SQL Server
Apache Pulsar集群搭建部署详细过程
2022/02/12 Servers
Python内置数据类型中的集合详解
2022/03/18 Python