全文共2520字,预计学习时长7分钟

如果你是软件开发人员,相信你一定知道甚至曾经使用过一个非常轻量级的数据库——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中更多令人惊讶的特性,享受它们吧!

留言点赞关注

我们一起分享AI学习与发展的干货

如转载,请后台留言,遵守转载规范

dbeaver无法修改表数据_隐藏彩蛋:你知道python有一个内置的数据库吗?相关推荐

  1. python只能使用内置数据库_隐藏彩蛋:你知道python有一个内置的数据库吗?

    本文转载自公众号"读芯术"(ID:AI_Discovery). 如果你是软件开发人员,相信你一定知道甚至曾经使用过一个非常轻量级的数据库--SQLite.它几乎拥有作为一个关系数据 ...

  2. dbeaver无法修改表数据_为什么你用不好数据透视表,看完才知道

    Excel中的数据透视表功能很强大,我们经常用它来分析和统计数据.但在使用数据透视表的过程中,经常会遇到一些棘手的问题.如果不知道如何解决这些问题,那你肯定用不好数据透视表. 1.字段名重复怎么办? ...

  3. 谷歌搜索技巧:搜索语法 隐藏彩蛋 高级设置

    谷歌搜索技巧:搜索语法 隐藏彩蛋 高级设置 Google是一个非常精密成熟的搜索引擎,其搜索结果的丰富性和准确度较其他搜索引擎都要好,但大多数用户都还只是停留在搜索框中输入一两个关键字,然后点击&qu ...

  4. android版本隐藏彩蛋养猫,安卓养猫彩蛋游戏下载-安卓养猫彩蛋 安卓版v0.4.5-PC6手游网...

    安卓养猫彩蛋是一款玩法简单趣味画风治愈解压的猫咪养成手机游戏,在安卓养猫彩蛋游戏中玩家可以自由操作,设置各种玩法模式,可以在商店购买鱼饲料喂养猫咪,提升猫咪等级,获得金币奖励,体验获得养猫彩蛋的快乐. ...

  5. android版本隐藏彩蛋养猫,Android 11 新增养猫彩蛋,正式版即将推送

    近日,谷歌正式推送了 Android 11 Beta3 系统,这是 Android 11 第三次测试版,也是最后一版测试固件,结束测试后 Android 11 将正式推送. 此次推送的 Android ...

  6. 业务如何修改表数据_SAP刘梦_新浪博客

    货铺QQ群号:834508274 微信群不能扫码进了,可以加我微信SAPliumeng拉进群,申请时请提供您哪个模块顾问,否则是一律不通过的. 进群统一修改群名片,例如BJ_ABAP_森林木.群内禁止 ...

  7. 微信翻译生日快乐的代码_微信「隐藏彩蛋」,你发现了没?

    高考加油 愿所有的好运与你相伴,愿在考场的你超常发挥! 这两天就是一年一度的高考的日子,虽特殊,但依旧是一个奋斗的夏季. 相信大家平常使用微信无非就是聊聊天.打打电话什么的,也有部分小小的彩蛋功能被大 ...

  8. PL/SQL Developer如何修改表数据

    找到要修改数据的表,右击该表,选择"编辑数据" 出现下图这样的窗口,注意方框中的信息. 小锁此时打开了,说明可以编辑数据了,后面的加减号表示增加.删除记录. 最后一列的rowid不 ...

  9. MySQL入门之插入、删除、修改表数据

    ---------------------------------------------------------------------------------------------------- ...

最新文章

  1. dev c++ 64位_RHEL7.8添加本地源以及扩展GCC,C++的32位和静态库支持
  2. 2.1.2监测当前打印机状态
  3. boost::leaf::result用法的测试程序
  4. matlab中的uint8函数,未定义与 'uint8' 类型的输入参数相对应的函数 'fitnessty'
  5. C语言 | 内存对齐01 - 什么是内存对齐
  6. 10进制转62进制 java_两种方法实现10进制和62进制互转 | 学步园
  7. python itchat 无法登录_项目分享|5步教你用Python制作朋友圈个性签名
  8. HTML中input是啥意思,HTML中input是什么意思
  9. 解决eclipse配置Tomcat时找不到server选项
  10. Resource is out of sync with the file system
  11. 手机 safari mac 调试
  12. undo歌词中文音译_求sanna Nielsen 唱的undo 中文谐音歌词
  13. oracle 升级到11204,案例客服数据库RAC升级11201升级11204.docx
  14. Linux磁盘阵列(RAID0、RAID1、RADI5、 RAID6、RAID1+0)
  15. jav中什么是组织java程序_Javs ^运算符在Java中做什么?
  16. 孙宏斌:生意总是有赚有赔,认赌服输(含说明会问答全文)
  17. python代码画玫瑰花_python绘制玫瑰
  18. 易中天品汉代风云人物07:韩信功过之谜
  19. zscore标准化步骤_归一化z-score标准化
  20. Windows11清理C盘空间优化

热门文章

  1. php for嵌套循环_PHP中的for循环怎样嵌套
  2. mysql5.5.20安装_mysql5.5.20安装文档
  3. hashset java_Java HashSet clear()方法与示例
  4. c++ array stl_C ++ STL中带有示例的array :: front()函数
  5. 不知道Mysql排序的特性,加班到12点,认了认了!
  6. Redis事务深入解析和使用
  7. python中使用cv2.findContours返回值too many values to unpack (expected 2)错误如何解决
  8. 蓝桥杯vip答案java_Java实现 蓝桥杯VIP 算法训练 麦森数
  9. win10创建新账户_win10系统卸载自带应用软件的操作方法
  10. 计算机桌面上的输入法状态栏,输入法状态栏