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中闭包Closure函数作为返回值的方法示例
Dec 17 Python
Python+tkinter使用40行代码实现计算器功能
Jan 30 Python
python3学生名片管理v2.0版
Nov 29 Python
对python产生随机的二维数组实例详解
Dec 13 Python
python 读取竖线分隔符的文本方法
Dec 20 Python
Python设计模式之观察者模式原理与用法详解
Jan 16 Python
python使用mitmproxy抓取浏览器请求的方法
Jul 02 Python
python点击鼠标获取坐标(Graphics)
Aug 10 Python
创建Shapefile文件并写入数据的例子
Nov 26 Python
python输出数学符号实例
May 11 Python
Python文件的操作示例的详细讲解
Apr 08 Python
深度学习详解之初试机器学习
Apr 14 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
深入了解php4(1)--回到未来
2006/10/09 PHP
经典的PHPer为什么被认为是草根?
2007/04/02 PHP
mysql,mysqli,PDO的各自不同介绍
2012/09/19 PHP
php判断一个数组是否为有序的方法
2015/03/27 PHP
PHP文件操作方法汇总
2015/07/01 PHP
php常用图片处理类
2016/03/16 PHP
PHP基于双向链表与排序操作实现的会员排名功能示例
2017/12/26 PHP
jquery实现兼容IE8的异步上传文件
2015/06/15 Javascript
深入解析Javascript闭包的功能及实现方法
2016/07/10 Javascript
AngularJS基础 ng-submit 指令简单示例
2016/08/03 Javascript
jQuery插件实现可输入和自动匹配的下拉框
2016/10/24 Javascript
js css自定义分页效果
2017/02/24 Javascript
JavaScript数据结构之双向链表定义与使用方法示例
2017/10/27 Javascript
jQuery获取随机颜色的实例代码
2018/05/21 jQuery
vue发送ajax请求详解
2018/10/09 Javascript
laypage.js分页插件使用方法详解
2019/07/27 Javascript
Element Carousel 走马灯的具体实现
2020/07/26 Javascript
[05:20]卡尔工作室_DOTA2新手教学_DOTA2超强新手功能
2013/04/22 DOTA
Python中的ctime()方法使用教程
2015/05/22 Python
python实现对指定字符串补足固定长度倍数截断输出的方法
2018/11/15 Python
python中的对数log函数表示及用法
2020/12/09 Python
万得城电器土耳其网站:欧洲第一大电子产品零售商
2016/10/07 全球购物
英国品牌男装折扣网站:Brown Bag
2018/03/08 全球购物
英国领先的露营和露营车品牌之一:OLPRO
2019/08/06 全球购物
德国的大型美妆个护电商:Flaconi
2020/06/26 全球购物
土木工程专业推荐信
2014/02/19 职场文书
经销商订货会主持词
2014/03/27 职场文书
写求职信有哪些注意事项
2014/05/08 职场文书
小学教师师德师风演讲稿
2014/08/22 职场文书
2014年领导班子专项整治整改方案
2014/09/28 职场文书
个人职业及收入证明
2014/10/13 职场文书
2014年体检中心工作总结
2014/12/23 职场文书
3.15消费者权益日活动总结
2015/02/09 职场文书
企业党支部工作总结2015
2015/05/21 职场文书
军事理论课感想
2015/08/11 职场文书
Python写情书? 10行代码展示如何把情书写在她的照片里
2022/04/21 Python