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中基础的socket编程实战攻略
Jun 01 Python
python字典多键值及重复键值的使用方法(详解)
Oct 31 Python
深入理解Python单元测试unittest的使用示例
Nov 18 Python
Python各类图像库的图片读写方式总结(推荐)
Feb 23 Python
对pandas中Series的map函数详解
Jul 25 Python
对tf.reduce_sum tensorflow维度上的操作详解
Jul 26 Python
python+ffmpeg批量去视频开头的方法
Jan 09 Python
python实现kmp算法的实例代码
Apr 03 Python
使用 Django Highcharts 实现数据可视化过程解析
Jul 31 Python
python matplotlib 画dataframe的时间序列图实例
Nov 20 Python
Python爬虫爬取新闻资讯案例详解
Jul 14 Python
python如何删除列为空的行
Jul 17 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学习笔记之二
2011/01/17 PHP
探讨:array2xml和xml2array以及xml与array的互相转化
2013/06/24 PHP
Laravel 5框架学习之模型、控制器、视图基础流程
2015/04/08 PHP
PHP获取ttf格式文件字体名的方法示例
2019/03/06 PHP
ThinkPHP3.2.3框架实现的空模块、空控制器、空操作,跳转到错误404页面图文详解
2019/04/03 PHP
PHP实现递归的三种方法
2020/07/04 PHP
nicejforms——美化表单不用愁
2007/02/20 Javascript
5款Javascript颜色选择器
2009/10/25 Javascript
jQuery Tips 为AJAX回调函数传递额外参数的方法
2010/12/28 Javascript
jquery ajax 同步异步的执行 return值不能取得的解决方案
2012/01/08 Javascript
浅析Js中的单引号与双引号问题
2013/11/06 Javascript
jquery使用append(content)方法注意事项分享
2014/01/06 Javascript
document.forms[].submit()使用介绍
2014/02/19 Javascript
js二维数组定义和初始化的三种方法总结
2014/03/03 Javascript
JS判断文本框内容改变事件的简单实例
2014/03/07 Javascript
JavaScript两种跨域技术全面介绍
2014/04/16 Javascript
jQuery产品间断向下滚动效果核心代码
2014/05/08 Javascript
jQuery 复合选择器应用的几个例子
2014/09/11 Javascript
jQuery实现单击和鼠标感应事件
2015/02/01 Javascript
JS实现简单的右下角弹出提示窗口完整实例
2016/06/21 Javascript
基于JavaScript实现瀑布流效果
2017/03/29 Javascript
Angular2使用Angular CLI快速搭建工程(一)
2017/05/21 Javascript
微信小程序自定义联系人弹窗
2020/05/26 Javascript
wxPython中文教程入门实例
2014/06/09 Python
Python中的对象,方法,类,实例,函数用法分析
2015/01/15 Python
Python数据结构与算法之图的广度优先与深度优先搜索算法示例
2017/12/14 Python
python使用生成器实现可迭代对象
2018/03/20 Python
numpy中的delete删除数组整行和整列的实例
2018/05/09 Python
python os.fork() 循环输出方法
2019/08/08 Python
python读写文件write和flush的实现方式
2020/02/21 Python
离线状态下在jupyter notebook中使用plotly实例
2020/04/24 Python
python把一个字符串切开的实例方法
2020/09/27 Python
德国50岁以上交友网站:Lebensfreunde
2020/03/18 全球购物
自主招生自荐信指南
2014/02/04 职场文书
反对形式主义、官僚主义、享乐主义和奢靡之风整改措施
2014/09/17 职场文书
2015年乡镇统计工作总结
2015/04/22 职场文书