隐藏彩蛋:你知道python有一个内置的数据库吗?

开发 后端
本文介绍了如何使用Python内置库sqlite3在SQLite数据库中创建和操作表。当然,它也支持更新和删除,你可以自己尝试一下。

本文转载自公众号“读芯术”(ID:AI_Discovery)。

如果你是软件开发人员,相信你一定知道甚至曾经使用过一个非常轻量级的数据库——SQLite。它几乎拥有作为一个关系数据库所需的所有功能,而且这些有功能都保存在一个文件中。下面是一些官方网站显示可以使用SQLite的场景:

[[339832]]

  • 嵌入式设备和物联网
  • 数据分析
  • 数据传输
  • 文件归档和/或数据容器
  • 内部或临时数据库
  • 在演示或测试期间代表企业数据库
  • 教育、培训和测试
  • 实验性SQL语言扩展

最重要的是,SQLite实际上是作为Python的内置库,换言之,你不需要安装任何服务器端/客户端软件,也不需要让某个东西作为服务运行,只要你用Python导入库并开始编码,就会有一个关系数据库管理系统!

输入与使用

[[339833]]

当我们说“内置”时,这意味着你甚至不需要运行pip install来获取库。只需通过以下方式导入:

  1. import sqlite3 as sl 

创建到数据库的连接

不要为驱动程序、连接字符串等烦恼。可以创建一个SQLite数据库,并拥有一个简单的连接对象:

  1. con = sl.connect('my-test.db') 

运行这行代码之后,我们已经创建了数据库并连接到它。我们要求Python自动连接现有的数据库,因此它不是空的。否则,我们可以使用完全相同的代码连接到现有数据库。

创建表

然后创建一个表:

  1. with con: 
  2.     con.execute(""" 
  3.         CREATE TABLE USER ( 
  4.             id INTEGER NOT NULL PRIMARYKEY AUTOINCREMENT, 
  5.             name TEXT, 
  6.             age INTEGER 
  7.         ); 
  8.     """) 

在这个用户表中添加三列。正如你所看到的,SQLite确实是轻量级的,但是它支持常规RDBMS应该具有的所有基本特性,例如数据类型、可为null、主键和自动递增。运行这段代码之后就已经创建了一个表,尽管它什么也不输出。

插入记录

让我们在刚刚创建的USER表中插入一些记录,这也可以证明我们确实创建了它。假设要一次性插入多个条目。Python中的SQLite可以轻松实现这一点。

  1. sql = 'INSERT INTO USER (id, name, age) values(?,?, ?)' 
  2. data = [ 
  3.     (1, 'Alice', 21), 
  4.     (2, 'Bob', 22), 
  5.     (3, 'Chris', 23) 

我们需要用问号作为占位符来定义SQL语句。然后,创建一些要插入的示例数据。通过连接对象,插入这些示例行。

  1. with con: 
  2.     con.executemany(sql, data) 

运行代码之后,没有任何提示,证明我们成功了。

查询表

现在,是时候验证所做的一切了。查询表以获取样本行。

  1. with con: 
  2.     data = con.execute("SELECT *FROM USER WHERE age <= 22") 
  3.     for row in data: 
  4.         print(row) 

另外,尽管SQLite是轻量级的,但是作为一个广泛使用的数据库,大多数SQL客户端软件都支持使用它。我使用最多的是DBeaver。

从SQL客户端(DBeaver)连接到SQLite数据库

因为我用的是googlecolab,所以要下载- my-test.db测试数据库文件到本地计算机。在本例中,如果在本地计算机上运行Python,则可以使用SQL客户机直接连接到数据库文件。

在DBeaver中,创建一个新连接并选择SQLite作为DB type。

然后,浏览到DB文件。

现在,可以在数据库上运行任何SQL查询。它与其他常规关系数据库没有什么不同。

与Pandas无缝融合

事实上,作为Python的一个内置特性,SQLite还可以与Pandas数据帧无缝集成。

定义一个数据帧:

  1. df_skill = pd.DataFrame({ 
  2.     'user_id': [1,1,2,2,3,3,3], 
  3.     'skill': ['Network Security','Algorithm Development', 'Network Security', 'Java', 'Python', 'Data Science','Machine Learning'] 
  4. }) 

然后,可以简单地调用数据帧的to_sql()方法将其保存到数据库中。

  1. df_skill.to_sql('SKILL', con) 

就这样,我们甚至不需要预先创建表,列的数据类型和长度都会被推断出来。当然,如果你想的话,仍然可以事先定义它。

然后,假设我们要连接表USER和SKILL,并将结果读入Pandas数据框。它也是无缝的。

  1. df = pd.read_sql(''' 
  2.     SELECT s.user_id, u.name, u.age,s.skill 
  3.     FROM USER u LEFT JOIN SKILL s ON u.ids.user_id 
  4. ''', con) 

让我们把结果写到一个名为USER_SKILL的新表中:

  1. df.to_sql('USER_SKILL', con) 

然后,还可以使用SQL客户机检索表。

本文介绍了如何使用Python内置库sqlite3在SQLite数据库中创建和操作表。当然,它也支持更新和删除,你可以自己尝试一下。

最重要的是,我们可以轻松地将表从SQLite数据库读入Pandas数据帧,反之亦然。这使我们能够更容易地与轻量级关系数据库进行交互。此外,SQLite没有身份验证,因为一切都需要是轻量级的。

Python中隐藏着许多惊喜。它们并不是故意藏起来,只是因为Python中存在太多现成的特性以至于人们无法发现。去探索Python中更多令人惊讶的特性,享受它们吧!

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2020-07-31 08:07:54

Python开发数据库

2018-04-26 13:33:20

Python语法Bug

2020-04-08 08:35:20

JavaScript模块函数

2023-11-01 15:45:29

DBMPython

2021-11-02 22:50:10

鼠标计算机传感器

2017-01-18 18:28:54

大数据数据库技术

2021-07-29 10:46:56

Python内置库代码

2021-08-27 09:48:18

Pythonitertools代码

2016-11-21 11:43:11

Python

2022-05-09 10:47:08

登录SpringSecurity

2021-09-15 09:20:37

Python函数代码

2020-10-16 15:06:59

开发技术方案

2017-05-18 12:16:03

LinuxPythonNoSql

2021-05-14 10:45:21

PythonNoSQL数据库

2023-11-13 15:36:24

开源数据库

2018-02-28 11:42:59

戴尔

2019-10-29 08:44:47

Java数据库实体

2022-01-08 20:03:20

数据库特点架构

2011-04-01 09:49:54

Python

2018-01-15 15:35:15

数据库性能调优案例
点赞
收藏

51CTO技术栈公众号