对于数据库的操作,Python中可以通过下载一些对应的三方插件和对应的数据库来实现数据库的操作,但是这样不免使得Python程序变得更加复杂了。如果只是想要使用数据库,又不想下载一些不必要的插件和辅助软件,可以使用Python内置模块sqlite3。

sqlite3是Python对于sqlite数据库的支持,模块名称之所以是sqlite3而不是sqlite,是因为sqlite的版本中最流行的就是3.x的版本。

sqlite数据库教程:http://www.runoob.com/sqlite/sqlite-intro.html

sqlite GUI软件SQLiteSpy:https://www.yunqa.de/delphi/products/sqlitespy/index,数据库的可视化管理工具有很多,你也可以选择其他的软件,但是SQLiteSpy这个软件免费而且非常小,对于平常的sqlite数据库操作其实已经可以满足了。

常用API(方括号中为可选参数)

  • conn = sqlite3.connect(database[, optional_params]):连接(磁盘上的)数据库database,database是一个数据库文件,可以是相对路径,也可以是绝对路径,如果这个文件存在且连接成功则返回一个连接对象;如果文件不存在,则自动创建一个数据库文件。
  • csr = conn.cursor([optional_params]):获取去连接对象的游标对象,游标可以理解为存放SQL结果的缓冲区,也可以理解为指向SQL结果的光标。
  • csr.execute(sql[, optional_params]):执行SQL语句,返回值也是一个cursor游标对象。SQL语句可以使用问号“?”作为占位符,例如:csr.execute('INSERT INTO STUDENTS VALUES(?, ?, ?)', (1, 'Jason', 18)) ,其中表students有三个字段ID、NAME和AGE。
  • csr.executemany(sql, seq_of_parameters):对seq_of_parameters中的所有数据执行同一个sql。例如需要向数据库中插入大量数据时,sql中可以使用占位符,要插入的数据放入seq_of_parameters中。
  • conn.commit():提交事务。如果之前对数据库进行了修改,比如插入操作,就需要先commit()。
  • conn.close():关闭数据库连接。关闭数据库连接之前,如果对数据库进行了修改,就需要先commit,关闭的时候不会自动commit的,如果没有commit,那么所有的修改都会被丢失。
  • csr.fetchone():获取查询结果集中的下一行,返回的是一个表示一行数据的元组,如果没有数据则返回None。
  • csr.fetchmany(size):获取查询结果集中的指定大小的下一组数据,默认返回一行数据(不同与fetchone,返回的是列表,而列表中只有一个元组),如果没有数据则返回空列表。
  • csr.fetchall():返回查询结果集中的全部数据。

简单示例:

# -*- coding:utf-8 -*-
import sqlite3 # 数据库文件
db = 'sqlite_test.db' # 连接数据库,如果没有则创建数据库
conn = sqlite3.connect(db) # 获取游标
csr = conn.cursor() # 创建表STUDENTS
csr.execute('CREATE TABLE STUDENTS'
'(ID INT PRIMARY KEY NOT NULL,'
'NAME TEXT NOT NULL,'
'AGE INT NOT NULL);') # 插入一条数据
csr.execute('INSERT INTO STUDENTS VALUES(1, "Jason", 18)') # 插入语句sql,并使用占位符
insert_sql = 'INSERT INTO STUDENTS VALUES(?, ?, ?)' # 需要批量插入的数据
students_info = [(2, 'Mickle', 20),
(3, 'Mary', 30),
(4, 'Bob', 40)] # 批量插入数据
csr.executemany(insert_sql, students_info) # 提交事务
conn.commit() # 获取一行数据
# datas = csr.execute('SELECT * FROM STUDENTS;').fetchone() # 获取2行数据
# datas = csr.execute('SELECT * FROM STUDENTS;').fetchmany(2) # 获取全部数据
# datas = csr.execute('SELECT * FROM STUDENTS;').fetchall() # 关闭数据库连接
conn.close()

常用SQL

sqlite的更多知识可以参考笔记开始的sqlite教程。

查询数据库中的表:

SELECT name FROM sqlite_master WHERE type='table';

查询表中的字段信息:

PRAGMA TABLE_INFO([table_name]);

 使用分享:

1、SQL中的表名或者字段名带有特殊符号时应该使用嵌套引号括起来,这些特殊符号可能是语法的一部分,应该使用嵌套引号表名它是一个整体,特别是使用格式化字符串时别忘了使用引号嵌套。如包含点号:'SELECT "aa.bb" FROM xxx;'或者'SELECT xxx FROM "%s";' % 'ccc.ddd.eee'

Python学习笔记:sqlite3(sqlite数据库操作)的更多相关文章

  1. Python学习笔记六:数据库操作

    一:Python操作数据库的流程 二:开发环境准备 1:开发工具PyCharm 2:Python操作mysql的工具:需要安装Python-Mysql Connector,网址:https://sou ...

  2. Python学习笔记21:数据库操作(sqlite3)

    Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言. SQLite作为后端数据库,能够搭配Python建站点,或者制作有数据存储需求的工具. SQLite还在其他领域有广泛 ...

  3. [Python] 学习笔记之MySQL数据库操作

    1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...

  4. python学习笔记(十)完善数据库操作

    1.cur = coon.cursor(cursor=pymysql.cursors.DictCursor)的用法 建立游标,指定cursor类型返回的是字典,如果不指定类型,返回的是元组类型数据 i ...

  5. python学习笔记(二)、字符串操作

    该一系列python学习笔记都是根据<Python基础教程(第3版)>内容所记录整理的 1.字符串基本操作 所有标准序列操作(索引.切片.乘法.成员资格检查.长度.最小值和最大值)都适用于 ...

  6. python学习笔记(十 二)、操作数据库

    每一种语言都少不了多数据库进行各种操作. python支持多种数据库.有关python支持的数据库清单,请参阅:https://wiki.python.org/moin/DatabaseInterfa ...

  7. Java 学习笔记(16)——Java数据库操作

    数据库操作是程序设计中十分重要的一个部分,Java内置JDBC来操作数据库 JDBC使用 JDBC--Java Database connecting Java数据库连接:本质上JDBC定义了操作数据 ...

  8. python 学习笔记6(数据库 sqlite)

    26. SQLite 轻量级的关系型数据库 SQLite是python自带的数据库,可以搭配python存储数据,开发网站等. 标准库中的 sqlite3 提供该数据库的接口. 1. 基本语法如下 c ...

  9. Python学习笔记15—mysql的操作

    安装 Python-MySQLdb pip install mysql-Python Python对mysql的操作 建立一个实验数据库demo mysql> create database d ...

  10. python学习笔记(七)操作mysql

    python操作mysql数据库需要先安装pymysql模块,在之前博客中可翻看如何安装,最简单的就是pip install pymysql 1.导入pymysql模块   import pymysq ...

随机推荐

  1. 定时备份oracle数据库脚本文件

    @echo off REM ########################################################### REM # Windows Server 2003下 ...

  2. Vue.js基础语法(一)

    vue学习的一系列,全部来自于表哥---表严肃,是我遇到过的讲课最通透,英文发音最好听的老师,想一起听课就去这里吧 https://biaoyansu.com/i/hzhj1206 前言: 前端解析数 ...

  3. svg用作背景图

    svg用做背景图的几种方式 1. 直接使用 background: url('data:image/svg+xml;charset=utf-8,<svg width="10" ...

  4. HTML的行内元素与块级元素的区别?

    块级元素:独占一行,其宽度自动填满父元素的宽度,可以容纳行内元素和其他块级元素,可以设置margin和padding值. 行内元素:不会独占一行,与其他行内元素排成一行,直到其父元素拍不下,才会从新一 ...

  5. 【js基础修炼之路】— 深入浅出理解闭包

    之前对于闭包的理解只是很肤浅的,只是浮于表面,这次深究了一下闭包,下面是我对闭包的理解. 什么是闭包? 引用高程里的话 => 闭包就是有权访问另一个作用域中变量的函数,闭包是由函数以及创建该函数 ...

  6. 814. Binary Tree Pruning(leetcode) (tree traverse)

    https://leetcode.com/contest/weekly-contest-79/problems/binary-tree-pruning/ -- 814 from leetcode tr ...

  7. yum 源搭建

    RHEL系统部署网络yum源 配置网络yum源 RHEL系统本身光盘做成的yum源所提供的软件包有限,在实际使用过程中经常会出现缺包的现象,本文中以CentOS源作为替代,CentOS的软件包和RHE ...

  8. bzoj1150 [CTSC2007]数据备份

    Description 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家中 ...

  9. MMU CPU及思想

    要素: 1)CPU访问寻址地址空间: 2)内存不足以容纳所有进程数据: 3)MMU将进程数据分割,保留当前使用数据. http://baike.baidu.com/link?url=KHyp37Ysi ...

  10. HDU(1698),线段树区间更新

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1698 区间更新重点在于懒惰标记. 当你更新的区间就是整个区间的时候,直接sum[rt] = c*(r- ...