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中字符串的常见操作技巧总结
Jul 28 Python
Python中shutil模块的学习笔记教程
Apr 04 Python
python生成圆形图片的方法
Mar 25 Python
Python对多属性的重复数据去重实例
Apr 18 Python
Mac下Anaconda的安装和使用教程
Nov 29 Python
Pythony运维入门之Socket网络编程详解
Apr 15 Python
一篇文章了解Python中常见的序列化操作
Jun 20 Python
python 如何去除字符串头尾的多余符号
Nov 19 Python
在Matplotlib图中插入LaTex公式实例
Apr 17 Python
python Django 反向访问器的外键冲突解决
May 20 Python
Python Tkinter图形工具使用方法及实例解析
Jun 15 Python
python munch库的使用解析
May 25 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编实现程动态图像的创建代码
2008/09/28 PHP
js关闭当前页面(窗口)的几种方式总结
2013/03/05 Javascript
超链接的禁用属性Disabled使用示例
2014/07/31 Javascript
深入分析JQuery和JavaScript的异同
2014/10/23 Javascript
node.js中的fs.readlink方法使用说明
2014/12/17 Javascript
jQuery中prependTo()方法用法实例
2015/01/08 Javascript
JS简单循环遍历json数组的方法
2016/04/22 Javascript
使用vue编写一个点击数字计时小游戏
2016/08/31 Javascript
AngularJS使用带属性值的ng-app指令实现自定义模块自动加载的方法
2017/01/04 Javascript
React Native使用Modal自定义分享界面的示例代码
2017/10/31 Javascript
Vue实现购物车场景下的应用
2017/11/27 Javascript
Vue的双向数据绑定实现原理解析
2020/02/17 Javascript
基于JavaScript或jQuery实现网站夜间/高亮模式
2020/05/30 jQuery
Javascript Symbol原理及使用方法解析
2020/10/22 Javascript
Python爬取网页中的图片(搜狗图片)详解
2017/03/23 Python
python简易远程控制单线程版
2018/06/20 Python
python linecache 处理固定格式文本数据的方法
2019/01/08 Python
python使用pygame模块实现坦克大战游戏
2020/03/25 Python
通过python实现随机交换礼物程序详解
2019/07/10 Python
Python pandas RFM模型应用实例详解
2019/11/20 Python
借助Paramiko通过Python实现linux远程登陆及sftp的操作
2020/03/16 Python
Python GUI编程学习笔记之tkinter界面布局显示详解
2020/03/30 Python
基于python实现计算且附带进度条代码实例
2020/03/31 Python
查看keras各种网络结构各层的名字方式
2020/06/11 Python
巴西最大的家电和百货零售商:Casas Bahia
2016/11/22 全球购物
德国圣伯纳德草药屋:Kräuterhaus Sanct Bernhard(有中文站)
2018/08/05 全球购物
Madewell澳大利亚官方网站:美国休闲服饰品牌
2019/07/18 全球购物
物流专业大学生的自我鉴定
2013/11/13 职场文书
企业管理培训感言
2014/01/27 职场文书
进口业务员岗位职责
2014/04/06 职场文书
听证通知书
2015/04/24 职场文书
金正昆讲礼仪观后感
2015/06/11 职场文书
Vue h函数的使用详解
2022/02/18 Vue.js
Ruby GDBM操作简介及数据存储原理
2022/04/19 Ruby
Sql Server 行数据的某列值想作为字段列显示的方法
2022/04/20 SQL Server
Apache POI操作批量导入MySQL数据库
2022/06/21 Servers