当前位置:首页 > 生活百科

python自带数据库好用吗(揭秘SQLite数据库优劣势)

栏目:生活百科日期:2025-05-31浏览:0

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

· 嵌入式设备和物联网

· 数据分析

· 数据传输

· 文件归档和/或数据容器

· 内部或临时数据库

· 在演示或测试期间代表企业数据库

· 教育、培训和测试

· 实验性SQL语言扩展

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

输入与使用

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

import sqlite3 as sl

创建到数据库的连接

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

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

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

创建表

然后创建一个表:

with con:    con.execute("""        CREATE TABLE USER (            id INTEGER NOT NULL PRIMARYKEY AUTOINCREMENT,            name TEXT,            age INTEGER        );    """)

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

插入记录

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

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

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

with con:    con.executemany(sql, data)

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

查询表

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

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

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

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

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

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

然后,浏览到DB文件。

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

与Pandas无缝融合

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

定义一个数据帧:

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

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

df_skill.to_sql('SKILL', con)

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

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

df = pd.read_sql('''    SELECT s.user_id, u.name, u.age,s.skill    FROM USER u LEFT JOIN SKILL s ON u.id= s.user_id''', con)

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

df.to_sql('USER_SKILL', con)

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

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

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

图源:unsplash

Python中隐藏着许多惊喜。它们并不是故意藏起来,只是因为Python中存在太多现成的特性以至于人们无法发现。

“python自带数据库好用吗(揭秘SQLite数据库优劣势)” 的相关文章

华为荣耀20青春版参数配置(手机荣耀20青春版怎么样)

在荣耀众多手机产品线中,&&#8221;青春版&&#8221;系列凭借优秀的机身设计,超高的颜值,一直备受年轻用户的喜爱,拥有大批拥趸,今天,10月22日,荣耀...

harrys剃须刀好不好用(Harry&&#8217;s剃须刀开箱使用测

近5-10年,欧美地区掀起了一股新消费品牌浪潮,比较知名的例如:WarbyParker、Everlane、Harrys、Allbirds等。有人叫他们DTCbr...

中国设计公司排行榜(国内最好的设计公司)

国内做工业设计公司有很多,报价差别也很大,对于初入该行业的小白真的不容易选择。那么,究竟哪些公司更专业靠谱呢?小编根据设计创新能力、公司规模、荣誉奖项、经营年限...

saas系统是什么样的系统,中国saas企业排名

saas是软件即服务的缩写。随着互联网技术的发展和应用软件的成熟,21世纪出现了一种全新的软件应用模式。用户不必购买软件,而是可以将基于web的软件租用提供商的...

eclipse整理代码格式快捷键(eclipse一键整理代码)

设置字体设置编码Eclipse工作空间(workspace)的缺省字符编码是操作系统缺省的编码,简体中文操作系统(WindowsXP、Windows2000简体...

240g固态硬盘多少钱一个(光威240GSSD固态硬盘最新报价)

开头就简单说说情况,免得引起误会,本文的国产含义仅仅就是MADEINCHINA的意思,没有其他意思。至于固态硬盘的闪存颗粒用的是啥,打磨没打磨过,是什么颗粒打磨...

ppt制作工具有哪些(手机做ppt免费模板)

PhotoShowPro最新版是PhotoShow的扩展,具有许多附加功能和照片共享功能;在PC或Macintosh和Google相册以及flickr之间发送和...

主机启动不了灯也不亮怎么回事(电脑不能启动电源风扇解

这个假期还真是短暂啊,一不留神就又到了开工的日子,不过经过了几天假期的休息,你是否会遇到回到工位后发现自己的电脑无法开机的情况呢?接下来给大家介绍几个小技巧,希...

为什么看不到微信好友的朋友圈(无法查看好友动态的4种

别急着拉黑,因为可能另有隐情。看不了他的朋友圈,其实有以下四种情况:1、他关闭了朋友圈功能前些天,小编突然发现发小的朋友圈显示暂未开启朋友圈功能当时一下子懵逼了...

nfs是什么系统(nfs的主要功能)

一、现实问题我有很多的服务器,各自服务器上都有很多文件要进行备份,图片、音频、视频、数据库等等。如果我把这些东西都远程传输到另外一台高存储服务器上效率是很低的,...