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基础之函数用法实例详解
Sep 10 Python
Python THREADING模块中的JOIN()方法深入理解
Feb 18 Python
python使用socket连接远程服务器的方法
Apr 29 Python
Perl中著名的Schwartzian转换问题解决实现
Jun 02 Python
基于Python代码编辑器的选用(详解)
Sep 13 Python
python实现批量按比例缩放图片效果
Mar 30 Python
Django 根据数据模型models创建数据表的实例
May 27 Python
Django rest framework工具包简单用法示例
Jul 20 Python
python学生信息管理系统实现代码
Dec 17 Python
Python爬取股票信息,并可视化数据的示例
Sep 26 Python
python 提高开发效率的5个小技巧
Oct 19 Python
Python 按比例获取样本数据或执行任务的实现代码
Dec 03 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
不用数据库的多用户文件自由上传投票系统(2)
2006/10/09 PHP
Windows Apache2.2.11及Php5.2.9-1的安装与配置方法
2009/06/08 PHP
ThinkPHP中使用ajax接收json数据的方法
2014/12/18 PHP
php输入数据统一类实例
2015/02/23 PHP
javascript一点特殊用法
2008/05/28 Javascript
解决jquery异步按一定的时间间隔刷新问题
2012/12/10 Javascript
图片轮换效果实现代码(点击按钮停止执行)
2013/04/12 Javascript
JavaScript中的undefined学习总结
2013/11/30 Javascript
网站接入QQ登录的两种方法
2014/07/22 Javascript
JavaScript中实现PHP的打乱数组函数shuffle实例
2014/10/11 Javascript
JavaScript中的ubound函数使用实例
2014/11/04 Javascript
jQuery通过Ajax返回JSON数据
2015/04/28 Javascript
JavaScript中的getDay()方法使用详解
2015/06/09 Javascript
jQuery简单实现input文本框内灰色提示文本效果的方法
2015/12/02 Javascript
JavaScript数组去重的几种方法效率测试
2016/10/23 Javascript
Node.js使用Express创建Web项目详细教程
2017/03/31 Javascript
vue2.0安装style/css loader的方法
2018/03/14 Javascript
详解Vue 动态组件与全局事件绑定总结
2018/11/11 Javascript
layui异步加载table表中某一列数据的例子
2019/09/16 Javascript
vue实现点击追加选中样式效果
2019/11/01 Javascript
微信小程序开发打开另一个小程序的实现方法
2020/05/17 Javascript
Python httplib,smtplib使用方法
2008/09/06 Python
Python OpenCV处理图像之图像直方图和反向投影
2018/07/10 Python
Python爬取新型冠状病毒“谣言”新闻进行数据分析
2020/02/16 Python
python中wheel的用法整理
2020/06/15 Python
英国最受欢迎的在线隐形眼镜商店:VisionDirect.co.uk
2018/12/06 全球购物
YSL圣罗兰美妆英国官网:Yves Saint Laurent Beauty UK
2019/08/03 全球购物
全球才华横溢工匠的家居装饰、珠宝和礼物:NOVICA
2021/01/22 全球购物
HSRP的含义以及如何工作
2014/09/10 面试题
大学学生会竞选演讲稿
2014/04/25 职场文书
采购员岗位职责范本
2015/04/07 职场文书
车间质检员岗位职责
2015/04/08 职场文书
个人售房合同协议书
2016/03/21 职场文书
详解Python小数据池和代码块缓存机制
2021/04/07 Python
雄兵连:第三季先行图公开,天使恶魔联合,银河之力的新力量
2021/06/11 国漫
Javascript webpack动态import
2022/04/19 Javascript