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中的多重装饰器
Apr 11 Python
Python操作使用MySQL数据库的实例代码
May 25 Python
Python编程实现粒子群算法(PSO)详解
Nov 13 Python
python3实现基于用户的协同过滤
May 31 Python
python中的字符串内部换行方法
Jul 19 Python
tensorflow 中对数组元素的操作方法
Jul 27 Python
python 实现敏感词过滤的方法
Jan 21 Python
Python编写一个验证码图片数据标注GUI程序附源码
Dec 09 Python
使用python实现CGI环境搭建过程解析
Apr 28 Python
python中前缀运算符 *和 **的用法示例详解
May 28 Python
Python 获取异常(Exception)信息的几种方法
Dec 29 Python
Python Pandas pandas.read_sql_query函数实例用法分析
Jun 21 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 获得汉字拼音首字母的函数
2009/08/01 PHP
php截取utf-8中文字符串乱码的解决方法
2010/03/29 PHP
php下删除一篇文章生成的多个静态页面
2010/08/08 PHP
基于Swoole实现PHP与websocket聊天室
2016/08/03 PHP
JS 去前后空格大全(IE9亲测)
2013/07/15 Javascript
JavaScript中读取和保存文件实例
2014/05/08 Javascript
Javascript中的getUTCHours()方法使用详解
2015/06/10 Javascript
JS onkeypress兼容性写法详解
2016/04/27 Javascript
详解Jquery的事件操作和文档操作
2016/12/19 Javascript
提高Web性能的前端优化技巧总结
2017/02/27 Javascript
JS判断一个数是否是水仙花数
2017/06/11 Javascript
在vue-cli中组件通信的方法
2017/12/16 Javascript
小程序实现左右来回滚动字幕效果
2018/12/28 Javascript
vue2.0实现列表数据增加和删除
2020/06/17 Javascript
vue自定义组件(通过Vue.use()来使用)即install的用法说明
2020/08/11 Javascript
[01:03:47]VP vs NewBee Supermajor 胜者组 BO3 第一场 6.5
2018/06/06 DOTA
python中字典dict常用操作方法实例总结
2015/04/04 Python
在Python程序中操作文件之flush()方法的使用教程
2015/05/24 Python
PHP网页抓取之抓取百度贴吧邮箱数据代码分享
2016/04/13 Python
python十进制和二进制的转换方法(含浮点数)
2018/07/07 Python
用Python实现校园通知更新提醒功能
2019/11/23 Python
Windows上安装tensorflow  详细教程(图文详解)
2020/02/04 Python
使用Numpy对特征中的异常值进行替换及条件替换方式
2020/06/08 Python
Python使用Pygame绘制时钟
2020/11/29 Python
5分钟让你掌握css3阴影、倒影、渐变小技巧(小编推荐)
2016/08/15 HTML / CSS
红领巾心向党广播稿
2014/01/19 职场文书
倡议书格式
2014/04/14 职场文书
人事专员岗位说明书
2014/07/29 职场文书
合同意向书范本
2014/07/30 职场文书
科学发展观演讲稿
2014/09/11 职场文书
2015年全国爱眼日活动方案
2015/05/05 职场文书
银行客户经理培训心得体会
2016/01/09 职场文书
大学生社会服务心得体会
2016/01/22 职场文书
2016国庆促销广告语
2016/01/28 职场文书
python unittest单元测试的步骤分析
2021/08/02 Python
python保存图片的四个常用方法
2022/02/28 Python