您现在的位置是:亿华云 > 系统运维
隐藏彩蛋:你知道python有一个内置的数据库吗?
亿华云2025-10-02 09:01:53【系统运维】1人已围观
简介本文转载自公众号“读芯术”(ID:AI_Discovery)。如果你是软件开发人员,相信你一定知道甚至曾经使用过一个非常轻量级的数据库——SQLite。它几乎拥有作为一个关系数据库所需的所有功能,而且
本文转载自公众号“读芯术”(ID:AI_Discovery)。隐藏
如果你是彩蛋软件开发人员,相信你一定知道甚至曾经使用过一个非常轻量级的知道数据库——SQLite。它几乎拥有作为一个关系数据库所需的内置所有功能,而且这些有功能都保存在一个文件中。据库下面是隐藏一些官方网站显示可以使用SQLite的场景:
最重要的彩蛋是,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没有身份验证,因为一切都需要是轻量级的。
Python中隐藏着许多惊喜。它们并不是故意藏起来,只是因为Python中存在太多现成的特性以至于人们无法发现。去探索Python中更多令人惊讶的特性,享受它们吧!
很赞哦!(35499)
上一篇: BaaS兴起,数据备份正在远离本地存储
相关文章
- 服务器端渲染技术架构:优化Web应用性能
- 这个不用多说,不同平台的注册价格不同,且不同平台对域名释放交易的把控与曝光不同,当然价格相对便宜且平台渠道广操作便利的平台最好。
- 为啥修改dns服务器?dns服务器与域名有何联系?
- 尽量不要在域名中出现特殊字符,这样的域名很容易导致访问者输入错误,同时给人留下不专业的印象,降低网站的可信度,并流失大量潜在客户。
- 新华三李立:攻关算网新技术,推动算力均衡发展
- 这个不用多说,不同平台的注册价格不同,且不同平台对域名释放交易的把控与曝光不同,当然价格相对便宜且平台渠道广操作便利的平台最好。
- 2016年1月1日:注册价格将降至每年7欧元。
- 域名不仅仅是一个简单的网站。对于有长远眼光的公司来说,在运营网站之前确定一个优秀的域名对有长远眼光的公司来说是非常重要的。这对今后的市场营销、产品营销和企业品牌建设都具有十分重要的意义。优秀的域名是企业在市场竞争中获得持久优势的利器。
- 数据中心能源回收创新方法
- 小白注册网站域名该怎么办?有什么步骤?
热门文章
站长推荐
新华三CEO于英涛:助力数字技术深入百行百业,以普惠之心弥合数字鸿沟
第六:这个圈子里的域名确实是赚钱的一些大玩家,至于小米农,有多少赚钱?几乎没有,也就是说,轿子里只有一个人,而且大多数人都抬着轿子。
付款完成后,您只需耐心等待,如果您注册成功,系统会提示您。这里需要注意的是,域名是一个即时产品,只有在最终付款成功时才能预订,注册成功后不能更改。
5、企业注册国内域名需要证件,其它情况一律不需要证件。
迁移到混合数据中心的企业应该具备的三个属性
网站页面结构改版,仅是页面样式发生变化,不会对排名、收录有影响;只有涉及到页面URL改变,才会对网站排名、收录有影响。
4、选择一个安全的域名注册商进行域名注册
小白注册网站域名该怎么办?有什么步骤?