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 random模块(获取随机数)常用方法和使用例子
May 13 Python
Python+微信接口实现运维报警
Aug 27 Python
Unicode和Python的中文处理
Mar 19 Python
python中单例常用的几种实现方法总结
Oct 13 Python
python实现顺时针打印矩阵
Mar 02 Python
关于PyTorch 自动求导机制详解
Aug 18 Python
解决python多行注释引发缩进错误的问题
Aug 23 Python
100行Python代码实现每天不同时间段定时给女友发消息
Sep 27 Python
Python Sphinx使用实例及问题解决
Jan 17 Python
django创建超级用户时指定添加其它字段方式
May 14 Python
Python3创建Django项目的几种方法(3种)
Jun 03 Python
详解python UDP 编程
Aug 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
php 什么是PEAR?(第三篇)
2009/03/19 PHP
php使用qr生成二维码的示例分享
2014/01/20 PHP
PHP使用redis实现统计缓存mysql压力的方法
2015/11/14 PHP
Adnroid 微信内置浏览器清除缓存
2016/07/11 PHP
浅谈PHP中如何实现Hook机制
2017/11/14 PHP
TP - 比RBAC更好的权限认证方式(Auth类认证)
2021/03/09 PHP
JS简单的图片放大缩小的两种方法
2013/11/11 Javascript
Javascript:为input设置readOnly属性(示例讲解)
2013/12/25 Javascript
jquery数组封装使用方法分享(jquery数组遍历)
2014/03/25 Javascript
页面刷新时记住滚动条的位置jquery代码
2014/06/17 Javascript
基于javascript实现判断移动终端浏览器版本信息
2014/12/09 Javascript
JavaScript原生对象之String对象的属性和方法详解
2015/03/13 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
2016/10/10 Javascript
原生js更改css样式的两种方式
2017/03/15 Javascript
JavaScript错误处理和堆栈追踪详解
2017/04/18 Javascript
AngularJS实现根据不同条件显示不同控件
2017/04/20 Javascript
vue router下的html5 history在iis服务器上的设置方法
2017/10/18 Javascript
微信小程序仿RadioGroup改变样式的处理方案
2018/07/13 Javascript
Vue.js 十五分钟入门图文教程
2018/09/12 Javascript
微信小程序如何使用globalData的方法
2019/06/06 Javascript
简单了解常用的JavaScript 库
2020/07/16 Javascript
[01:00:30]TFT vs VGJ.T Supermajor 败者组 BO3 第一场 6.5
2018/06/06 DOTA
Python实现的基于优先等级分配糖果问题算法示例
2018/04/25 Python
python读取与处理netcdf数据方式
2020/02/14 Python
pycharm如何使用anaconda中的各种包(操作步骤)
2020/07/31 Python
基于HTML5 audio元素播放声音jQuery小插件
2011/05/11 HTML / CSS
5 个强大的HTML5 API 函数推荐
2014/11/19 HTML / CSS
HTML5 移动页面自适应手机屏幕四类方法总结
2017/08/17 HTML / CSS
财务部绩效考核方案
2014/05/04 职场文书
一般基层干部群众路线教育实践活动个人对照检查材料
2014/11/04 职场文书
企业承诺书格式范文
2015/04/28 职场文书
考生诚信考试承诺书(2016版)
2016/03/25 职场文书
Java移除无效括号的方法实现
2021/08/07 Java/Android
zabbix配置nginx监控的实现
2022/05/25 Servers
java实现自定义时钟并实现走时功能
2022/06/21 Java/Android
Tomcat安装使用及部署Web项目的3种方法汇总
2022/08/14 Servers