Python开发SQLite3数据库相关操作详解【连接,查询,插入,更新,删除,关闭等】

本文实例讲述了Python开发SQLite3数据库相关操作。分享给大家供大家参考,具体如下:

'''SQLite数据库是一款非常小巧的嵌入式开源数据库软件,也就是说
没有独立的维护进程,所有的维护都来自于程序本身。
在python中,使用sqlite3创建数据库的连接,当我们指定的数据库文件不存在的时候
连接对象会自动创建数据库文件;如果数据库文件已经存在,则连接对象不会再创建
数据库文件,而是直接打开该数据库文件。
  连接对象可以是硬盘上面的数据库文件,也可以是建立在内存中的,在内存中的数据库
  执行完任何操作后,都不需要提交事务的(commit)
  创建在硬盘上面: conn = sqlite3.connect('c:\\test\\test.db')
  创建在内存上面: conn = sqlite3.connect('"memory:')
  下面我们一硬盘上面创建数据库文件为例来具体说明:
  conn = sqlite3.connect('c:\\test\\hongten.db')
  其中conn对象是数据库链接对象,而对于数据库链接对象来说,具有以下操作:
    commit()      --事务提交
    rollback()     --事务回滚
    close()       --关闭一个数据库链接
    cursor()      --创建一个游标
  cu = conn.cursor()
  这样我们就创建了一个游标对象:cu
  在sqlite3中,所有sql语句的执行都要在游标对象的参与下完成
  对于游标对象cu,具有以下具体操作:
    execute()      --执行一条sql语句
    executemany()    --执行多条sql语句
    close()       --游标关闭
    fetchone()     --从结果中取出一条记录
    fetchmany()     --从结果中取出多条记录
    fetchall()     --从结果中取出所有记录
    scroll()      --游标滚动
'''

下面是我做的demo,在demo中,我做了很详细的注释和功能的演示,详情如下:

SHOW_SQL = False的时候:

Python 3.3.2 (v3.3.2:d047928ae3f6, May 16 2013, 00:03:43) [MSC v.1600 32 bit (Intel)] on win32
Type "copyright", "credits" or "license()" for more information.
>>> ================================ RESTART ================================
>>>
show_sql : False
删除数据库表测试...
硬盘上面:[c:\test\hongten.db]
删除数据库表[student]成功!
创建数据库表测试...
硬盘上面:[c:\test\hongten.db]
创建数据库表[student]成功!
保存数据测试...
硬盘上面:[c:\test\hongten.db]
查询所有数据...
硬盘上面:[c:\test\hongten.db]
(1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
(2, 'Tom', '男', 22, '美国旧金山', '15423****63')
(3, 'Jake', '女', 18, '广东省广州市', '18823****87')
(4, 'Cate', '女', 21, '广东省广州市', '14323****32')
##################################################
查询一条数据...
硬盘上面:[c:\test\hongten.db]
(1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
##################################################
更新数据...
硬盘上面:[c:\test\hongten.db]
查询所有数据...
硬盘上面:[c:\test\hongten.db]
(1, 'HongtenAA', '男', 20, '广东省广州市', '13423****62')
(2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
(3, 'HongtenCC', '女', 18, '广东省广州市', '18823****87')
(4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
##################################################
删除数据...
硬盘上面:[c:\test\hongten.db]
查询所有数据...
硬盘上面:[c:\test\hongten.db]
(2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
(4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
>>>

SHOW_SQL = True的时候:

Python 3.3.2 (v3.3.2:d047928ae3f6, May 16 2013, 00:03:43) [MSC v.1600 32 bit (Intel)] on win32
Type "copyright", "credits" or "license()" for more information.
>>> ================================ RESTART ================================
>>>
show_sql : True
删除数据库表测试...
硬盘上面:[c:\test\hongten.db]
执行sql:[DROP TABLE IF EXISTS student]
删除数据库表[student]成功!
创建数据库表测试...
硬盘上面:[c:\test\hongten.db]
执行sql:[CREATE TABLE `student` (
             `id` int(11) NOT NULL,
             `name` varchar(20) NOT NULL,
             `gender` varchar(4) DEFAULT NULL,
             `age` int(11) DEFAULT NULL,
             `address` varchar(200) DEFAULT NULL,
             `phone` varchar(20) DEFAULT NULL,
              PRIMARY KEY (`id`)
            )]
创建数据库表[student]成功!
保存数据测试...
硬盘上面:[c:\test\hongten.db]
执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(1, 'Hongten', '男', 20, '广东省广州市', '13423****62')]
执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(2, 'Tom', '男', 22, '美国旧金山', '15423****63')]
执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(3, 'Jake', '女', 18, '广东省广州市', '18823****87')]
执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(4, 'Cate', '女', 21, '广东省广州市', '14323****32')]
查询所有数据...
硬盘上面:[c:\test\hongten.db]
执行sql:[SELECT * FROM student]
(1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
(2, 'Tom', '男', 22, '美国旧金山', '15423****63')
(3, 'Jake', '女', 18, '广东省广州市', '18823****87')
(4, 'Cate', '女', 21, '广东省广州市', '14323****32')
##################################################
查询一条数据...
硬盘上面:[c:\test\hongten.db]
执行sql:[SELECT * FROM student WHERE ID = ? ],参数:[1]
(1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
##################################################
更新数据...
硬盘上面:[c:\test\hongten.db]
执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenAA', 1)]
执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenBB', 2)]
执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenCC', 3)]
执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenDD', 4)]
查询所有数据...
硬盘上面:[c:\test\hongten.db]
执行sql:[SELECT * FROM student]
(1, 'HongtenAA', '男', 20, '广东省广州市', '13423****62')
(2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
(3, 'HongtenCC', '女', 18, '广东省广州市', '18823****87')
(4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
##################################################
删除数据...
硬盘上面:[c:\test\hongten.db]
执行sql:[DELETE FROM student WHERE NAME = ? AND ID = ? ],参数:[('HongtenAA', 1)]
执行sql:[DELETE FROM student WHERE NAME = ? AND ID = ? ],参数:[('HongtenCC', 3)]
查询所有数据...
硬盘上面:[c:\test\hongten.db]
执行sql:[SELECT * FROM student]
(2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
(4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
>>>

具体代码:

#python sqlite
#Author : Hongten
#Create : 2013-08-09
#Version: 1.0
#DB-API 2.0 interface for SQLite databases
import sqlite3
import os
'''SQLite数据库是一款非常小巧的嵌入式开源数据库软件,也就是说
没有独立的维护进程,所有的维护都来自于程序本身。
在python中,使用sqlite3创建数据库的连接,当我们指定的数据库文件不存在的时候
连接对象会自动创建数据库文件;如果数据库文件已经存在,则连接对象不会再创建
数据库文件,而是直接打开该数据库文件。
  连接对象可以是硬盘上面的数据库文件,也可以是建立在内存中的,在内存中的数据库
  执行完任何操作后,都不需要提交事务的(commit)
  创建在硬盘上面: conn = sqlite3.connect('c:\\test\\test.db')
  创建在内存上面: conn = sqlite3.connect('"memory:')
  下面我们一硬盘上面创建数据库文件为例来具体说明:
  conn = sqlite3.connect('c:\\test\\hongten.db')
  其中conn对象是数据库链接对象,而对于数据库链接对象来说,具有以下操作:
    commit()      --事务提交
    rollback()     --事务回滚
    close()       --关闭一个数据库链接
    cursor()      --创建一个游标
  cu = conn.cursor()
  这样我们就创建了一个游标对象:cu
  在sqlite3中,所有sql语句的执行都要在游标对象的参与下完成
  对于游标对象cu,具有以下具体操作:
    execute()      --执行一条sql语句
    executemany()    --执行多条sql语句
    close()       --游标关闭
    fetchone()     --从结果中取出一条记录
    fetchmany()     --从结果中取出多条记录
    fetchall()     --从结果中取出所有记录
    scroll()      --游标滚动
'''
#global var
#数据库文件绝句路径
DB_FILE_PATH = ''
#表名称
TABLE_NAME = ''
#是否打印sql
SHOW_SQL = True
def get_conn(path):
  '''获取到数据库的连接对象,参数为数据库文件的绝对路径
  如果传递的参数是存在,并且是文件,那么就返回硬盘上面改
  路径下的数据库文件的连接对象;否则,返回内存中的数据接
  连接对象'''
  conn = sqlite3.connect(path)
  if os.path.exists(path) and os.path.isfile(path):
    print('硬盘上面:[{}]'.format(path))
    return conn
  else:
    conn = None
    print('内存上面:[:memory:]')
    return sqlite3.connect(':memory:')
def get_cursor(conn):
  '''该方法是获取数据库的游标对象,参数为数据库的连接对象
  如果数据库的连接对象不为None,则返回数据库连接对象所创
  建的游标对象;否则返回一个游标对象,该对象是内存中数据
  库连接对象所创建的游标对象'''
  if conn is not None:
    return conn.cursor()
  else:
    return get_conn('').cursor()
###############################################################
####      创建|删除表操作   START
###############################################################
def drop_table(conn, table):
  '''如果表存在,则删除表,如果表中存在数据的时候,使用该
  方法的时候要慎用!'''
  if table is not None and table != '':
    sql = 'DROP TABLE IF EXISTS ' + table
    if SHOW_SQL:
      print('执行sql:[{}]'.format(sql))
    cu = get_cursor(conn)
    cu.execute(sql)
    conn.commit()
    print('删除数据库表[{}]成功!'.format(table))
    close_all(conn, cu)
  else:
    print('the [{}] is empty or equal None!'.format(sql))
def create_table(conn, sql):
  '''创建数据库表:student'''
  if sql is not None and sql != '':
    cu = get_cursor(conn)
    if SHOW_SQL:
      print('执行sql:[{}]'.format(sql))
    cu.execute(sql)
    conn.commit()
    print('创建数据库表[student]成功!')
    close_all(conn, cu)
  else:
    print('the [{}] is empty or equal None!'.format(sql))
###############################################################
####      创建|删除表操作   END
###############################################################
def close_all(conn, cu):
  '''关闭数据库游标对象和数据库连接对象'''
  try:
    if cu is not None:
      cu.close()
  finally:
    if cu is not None:
      cu.close()
###############################################################
####      数据库操作CRUD   START
###############################################################
def save(conn, sql, data):
  '''插入数据'''
  if sql is not None and sql != '':
    if data is not None:
      cu = get_cursor(conn)
      for d in data:
        if SHOW_SQL:
          print('执行sql:[{}],参数:[{}]'.format(sql, d))
        cu.execute(sql, d)
        conn.commit()
      close_all(conn, cu)
  else:
    print('the [{}] is empty or equal None!'.format(sql))
def fetchall(conn, sql):
  '''查询所有数据'''
  if sql is not None and sql != '':
    cu = get_cursor(conn)
    if SHOW_SQL:
      print('执行sql:[{}]'.format(sql))
    cu.execute(sql)
    r = cu.fetchall()
    if len(r) > 0:
      for e in range(len(r)):
        print(r[e])
  else:
    print('the [{}] is empty or equal None!'.format(sql))
def fetchone(conn, sql, data):
  '''查询一条数据'''
  if sql is not None and sql != '':
    if data is not None:
      #Do this instead
      d = (data,)
      cu = get_cursor(conn)
      if SHOW_SQL:
        print('执行sql:[{}],参数:[{}]'.format(sql, data))
      cu.execute(sql, d)
      r = cu.fetchall()
      if len(r) > 0:
        for e in range(len(r)):
          print(r[e])
    else:
      print('the [{}] equal None!'.format(data))
  else:
    print('the [{}] is empty or equal None!'.format(sql))
def update(conn, sql, data):
  '''更新数据'''
  if sql is not None and sql != '':
    if data is not None:
      cu = get_cursor(conn)
      for d in data:
        if SHOW_SQL:
          print('执行sql:[{}],参数:[{}]'.format(sql, d))
        cu.execute(sql, d)
        conn.commit()
      close_all(conn, cu)
  else:
    print('the [{}] is empty or equal None!'.format(sql))
def delete(conn, sql, data):
  '''删除数据'''
  if sql is not None and sql != '':
    if data is not None:
      cu = get_cursor(conn)
      for d in data:
        if SHOW_SQL:
          print('执行sql:[{}],参数:[{}]'.format(sql, d))
        cu.execute(sql, d)
        conn.commit()
      close_all(conn, cu)
  else:
    print('the [{}] is empty or equal None!'.format(sql))
###############################################################
####      数据库操作CRUD   END
###############################################################
###############################################################
####      测试操作   START
###############################################################
def drop_table_test():
  '''删除数据库表测试'''
  print('删除数据库表测试...')
  conn = get_conn(DB_FILE_PATH)
  drop_table(conn, TABLE_NAME)
def create_table_test():
  '''创建数据库表测试'''
  print('创建数据库表测试...')
  create_table_sql = '''CREATE TABLE `student` (
             `id` int(11) NOT NULL,
             `name` varchar(20) NOT NULL,
             `gender` varchar(4) DEFAULT NULL,
             `age` int(11) DEFAULT NULL,
             `address` varchar(200) DEFAULT NULL,
             `phone` varchar(20) DEFAULT NULL,
              PRIMARY KEY (`id`)
            )'''
  conn = get_conn(DB_FILE_PATH)
  create_table(conn, create_table_sql)
def save_test():
  '''保存数据测试...'''
  print('保存数据测试...')
  save_sql = '''INSERT INTO student values (?, ?, ?, ?, ?, ?)'''
  data = [(1, 'Hongten', '男', 20, '广东省广州市', '13423****62'),
      (2, 'Tom', '男', 22, '美国旧金山', '15423****63'),
      (3, 'Jake', '女', 18, '广东省广州市', '18823****87'),
      (4, 'Cate', '女', 21, '广东省广州市', '14323****32')]
  conn = get_conn(DB_FILE_PATH)
  save(conn, save_sql, data)
def fetchall_test():
  '''查询所有数据...'''
  print('查询所有数据...')
  fetchall_sql = '''SELECT * FROM student'''
  conn = get_conn(DB_FILE_PATH)
  fetchall(conn, fetchall_sql)
def fetchone_test():
  '''查询一条数据...'''
  print('查询一条数据...')
  fetchone_sql = 'SELECT * FROM student WHERE ID = ? '
  data = 1
  conn = get_conn(DB_FILE_PATH)
  fetchone(conn, fetchone_sql, data)
def update_test():
  '''更新数据...'''
  print('更新数据...')
  update_sql = 'UPDATE student SET name = ? WHERE ID = ? '
  data = [('HongtenAA', 1),
      ('HongtenBB', 2),
      ('HongtenCC', 3),
      ('HongtenDD', 4)]
  conn = get_conn(DB_FILE_PATH)
  update(conn, update_sql, data)
def delete_test():
  '''删除数据...'''
  print('删除数据...')
  delete_sql = 'DELETE FROM student WHERE NAME = ? AND ID = ? '
  data = [('HongtenAA', 1),
      ('HongtenCC', 3)]
  conn = get_conn(DB_FILE_PATH)
  delete(conn, delete_sql, data)
###############################################################
####      测试操作   END
###############################################################
def init():
  '''初始化方法'''
  #数据库文件绝句路径
  global DB_FILE_PATH
  DB_FILE_PATH = 'c:\\test\\hongten.db'
  #数据库表名称
  global TABLE_NAME
  TABLE_NAME = 'student'
  #是否打印sql
  global SHOW_SQL
  SHOW_SQL = True
  print('show_sql : {}'.format(SHOW_SQL))
  #如果存在数据库表,则删除表
  drop_table_test()
  #创建数据库表student
  create_table_test()
  #向数据库表中插入数据
  save_test()
def main():
  init()
  fetchall_test()
  print('#' * 50)
  fetchone_test()
  print('#' * 50)
  update_test()
  fetchall_test()
  print('#' * 50)
  delete_test()
  fetchall_test()
if __name__ == '__main__':
  main()

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python常见数据库操作技巧汇总》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

(0)

相关推荐

  • Python操作sqlite3快速、安全插入数据(防注入)的实例

    table通过使用下面语句创建: 复制代码 代码如下: create table userinfo(name text, email text) 更快地插入数据 在此用time.clock()来计时,看看以下三种方法的速度. 复制代码 代码如下: import sqlite3import time def create_tables(dbname):      conn = sqlite3.connect(dbname)    cursor = conn.cursor()    cursor.e

  • Python Sqlite3以字典形式返回查询结果的实现方法

    sqlite3本身并没有像pymysql一样原生提供字典形式的游标. cursor = conn.cursor(pymysql.cursors.DictCursor) 但官方文档里已经有预留了相应的实现方案. def dict_factory(cursor, row): d = {} for idx, col in enumerate(cursor.description): d[col[0]] = row[idx] return d 使用这个函数代替conn.raw_factory属性即可.

  • Python实现读取TXT文件数据并存进内置数据库SQLite3的方法

    本文实例讲述了Python实现读取TXT文件数据并存进内置数据库SQLite3的方法.分享给大家供大家参考,具体如下: 当TXT文件太大,计算机内存不够时,我们可以选择按行读取TXT文件,并将其存储进Python内置轻量级splite数据库,这样可以加快数据的读取速度,当我们需要重复读取数据时,这样的速度加快所带来的时间节省是非常可观的,比如,当我们在训练数据时,要迭代10万次,即要从文件中读取10万次,即使每次只加快0.1秒,那么也能节省几个小时的时间了. #创建数据库并把txt文件的数据存进

  • Python简单操作sqlite3的方法示例

    本文实例讲述了Python简单操作sqlite3的方法.分享给大家供大家参考,具体如下: import sqlite3 def Test1(): #con =sqlite3.connect("D:\\test.db") con =sqlite3.connect(":memory:") #store in memory cur =con.cursor() try: cur.execute('create table score(id integer primary k

  • Python sqlite3事务处理方法实例分析

    本文实例讲述了Python sqlite3事务处理方法.分享给大家供大家参考,具体如下: sqlite3事务总结: 在connect()中不传入 isolation_level 事务处理: 使用connection.commit() #!/usr/bin/env python # -*- coding:utf-8 -*- '''sqlite3事务总结: 在connect()中不传入 isolation_level 事务处理: 使用connection.commit() 分析: 智能commit状

  • Python SQLite3数据库日期与时间常见函数用法分析

    本文实例讲述了Python SQLite3数据库日期与时间常见函数.分享给大家供大家参考,具体如下: import sqlite3 #con = sqlite3.connect('example.db') con = sqlite3.connect(":memory:") c = con.cursor() # Create table c.execute('''CREATE TABLE stocks (date text, trans text, symbol text, qty re

  • Python实用日期时间处理方法汇总

    原则, 以datetime为中心, 起点或中转, 转化为目标对象, 涵盖了大多数业务场景中需要的日期转换处理 步骤: 1. 掌握几种对象及其关系 2. 了解每类对象的基本操作方法 3. 通过转化关系转化 涉及对象 1. datetime 复制代码 代码如下: >>> import datetime >>> now = datetime.datetime.now() >>> now datetime.datetime(2015, 1, 12, 23, 9

  • python中日期和时间格式化输出的方法小结

    本文实例总结了python中日期和时间格式化输出的方法.分享给大家供大家参考.具体分析如下: python格式化日期时间的函数为datetime.datetime.strftime():由字符串转为日期型的函数为:datetime.datetime.strptime(),两个函数都涉及日期时间的格式化字符串,这里提供详细的代码详细演示了每一个参数的使用方法及范例. 下面是格式化日期和时间时可用的替换符号 %a 输出当前是星期几的英文简写 >>> import datetime >&

  • Python实现读写sqlite3数据库并将统计数据写入Excel的方法示例

    本文实例讲述了Python实现读写sqlite3数据库并将统计数据写入Excel的方法.分享给大家供大家参考,具体如下: src = 'F:\\log\\mha-041log\\rnd-log-dl.huawei.com\\test' # dst = sys.argv[2] dst = 'F:\\log\\mha-041log\\rnd-log-dl.huawei.com\\test\\mha-041log.db' # dst_anylyzed = sys.argv[3] dst_anylyze

  • Python2.7编程中SQLite3基本操作方法示例

    本文实例讲述了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

  • Windows平台Python连接sqlite3数据库的方法分析

    本文实例讲述了Windows平台Python连接sqlite3数据库的方法.分享给大家供大家参考,具体如下: 之前没有接触过sqlite数据库,只是听到同事聊起这个. 有一次,手机端同事让我帮着写个sql,后面说运行不了报错了,我问是什么数据库,同事说是sqlite,这才知道了还有sqlite这个数据库... 接下来说说Python连接sqlite数据库,非常简单,因为python中的sqlite模块也遵循了DB-API 2.0的规范,所以操作起来和sql server.MySQL.oracle

  • python操作数据库之sqlite3打开数据库、删除、修改示例

    复制代码 代码如下: #coding=utf-8__auther__ = 'xianbao'import sqlite3# 打开数据库def opendata():        conn = sqlite3.connect("mydb.db")        cur = conn.execute("""create table if not exists tianjia(id integer primary key autoincrement, user

随机推荐