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中数字以及算数运算符的相关使用
Oct 12 Python
python常用函数详解
Sep 13 Python
Python编程把二叉树打印成多行代码
Jan 04 Python
python3.6实现学生信息管理系统
Feb 21 Python
python实现将文件夹内的每张图片批量分割成多张
Jul 22 Python
python 使用socket传输图片视频等文件的实现方式
Aug 07 Python
python自动化测试无法启动谷歌浏览器问题
Oct 10 Python
浅谈python累加求和+奇偶数求和_break_continue
Feb 25 Python
Python3开发环境搭建详细教程
Jun 18 Python
python将字典内容写入json文件的实例代码
Aug 12 Python
python实现批量提取指定文件夹下同类型文件
Apr 05 Python
python如何利用cv2.rectangle()绘制矩形框
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
Dedecms V3.1 生成HTML速度的优化办法
2007/03/18 PHP
php版微信小店API二次开发及使用示例
2016/11/12 PHP
PHP htmlspecialchars()函数用法与实例讲解
2019/03/08 PHP
javascript 获取网页参数系统
2008/07/19 Javascript
ExtJS 工具栏 分页事件参数
2010/03/05 Javascript
基于jquery的分页控件(C#)
2011/01/06 Javascript
javascript禁用键盘功能键让右击及其他键无效
2013/10/09 Javascript
jQuery Mobile 导航栏代码
2013/11/01 Javascript
jquery中的查找parents与closest方法之间的区别
2013/12/02 Javascript
js控制分页打印、打印分页示例
2014/02/08 Javascript
node.js中使用q.js实现api的promise化
2014/09/17 Javascript
javascript显示倒计时控制按钮的简单实现
2016/06/07 Javascript
详解Js模板引擎(TrimPath)
2016/11/22 Javascript
Javascript 两种刷新方法以及区别和适用范围
2017/01/17 Javascript
一篇看懂vuejs的状态管理神器 vuex状态管理模式
2017/04/20 Javascript
JavaScript面向对象精要(下部)
2017/09/12 Javascript
详解Angular结合zTree异步加载节点数据
2018/01/20 Javascript
基于Vuex无法观察到值变化的解决方法
2018/03/01 Javascript
vue axios封装及API统一管理的方法
2019/04/18 Javascript
Python文件操作,open读写文件,追加文本内容实例
2016/12/14 Python
使用WingPro 7 设置Python路径的方法
2019/07/24 Python
PIL对上传到Django的图片进行处理并保存的实例
2019/08/07 Python
Python面向对象实现方法总结
2020/08/12 Python
Python根据URL地址下载文件并保存至对应目录的实现
2020/11/15 Python
纯CSS实现的大小渐变、渐远效果
2014/04/15 HTML / CSS
详解Html5中video标签那些属性和方法
2019/07/01 HTML / CSS
英国男士时尚购物网站:Stuarts London
2017/10/22 全球购物
Gap工厂店:Gap Factory
2017/11/02 全球购物
百思买加拿大:Best Buy Canada
2018/03/20 全球购物
瑞典在互联网上最大的宠物商店:Animail
2020/10/31 全球购物
毕业生自荐材料范文
2014/12/30 职场文书
刑事上诉状(无罪)
2015/05/23 职场文书
中学教师教学工作总结
2015/08/13 职场文书
2016秋季幼儿园开学寄语
2015/12/03 职场文书
大学军训通讯稿(2016最新版)
2015/12/21 职场文书
spring项目中切面及AOP的使用方法
2021/06/26 Java/Android