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

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

cdca1bef266a3e91075c9a703f1d0b63.png

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

· 嵌入式设备和物联网

· 数据分析

· 数据传输

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

· 内部或临时数据库

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

· 教育、培训和测试

· 实验性SQL语言扩展

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

a9dca93ca75ea9925196b85882f91be6.png

输入与使用

c2b4113e8bd86383dc4d7ec0397a95b0.png

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

import sqlite3 as sl

创建到数据库的连接

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

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

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

9db7028f3c3ae2c0f3761be6f16b1d73.png

创建表

然后创建一个表:

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)
56fbbf7afd12c372f75febdb6371242c.png

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

a9dca93ca75ea9925196b85882f91be6.png

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

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

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

7fdea6cdd3a3c16a40846c513d837ef1.png

然后,浏览到DB文件。

dfacf5793b2f9f87cf201fbd05304ea5.png

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

444c26d13adf51c74b540bcf00a56ade.png
a9dca93ca75ea9925196b85882f91be6.png

与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']})
58d064c40283b89b3bee63243c98a6f4.png

然后,可以简单地调用数据帧的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)
56a329ab1a4564460385b152ab815c32.png

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

df.to_sql('USER_SKILL', con)

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

fb8b0da4ce2da22320006362c00e865a.png

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

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

5521afcbb35323160bbc1914beb88edb.png

图源:unsplash

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

e05c1beab246ccb940501db6fae53385.png

留言点赞关注

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/558445.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

批量删除HTML链接软件,3种方法教你一次性删除word文档中的所有超链接

您可能感兴趣的话题&#xff1a;Word核心提示&#xff1a;在编辑文档时&#xff0c;可能会在文档以外复制一些内容进来&#xff0c;但是总会有一些烦人的链接很难去掉。或是WORD 从网上下了一些资料,存到 word 里面,里面很多文字和图片都带有超链接。下面小编就为大家介绍3种方…

一文道破Java中的深拷贝,浅拷贝,零拷贝

前言 在Java编写代码中&#xff0c;对象的拷贝是一个常见的操作。根据拷贝的层次和方式不同&#xff0c;可以分为深拷贝、浅拷贝和零拷贝。本篇文章我们将详细介绍这三种拷贝方式的概念、实现方法以及使用场景&#xff0c;方便大佬学习及面试。 深拷贝 深拷贝是一种创建对象副…

关键词热度分析工具_谷歌SEO推广排名的关键要素(一)利用谷歌关键词分析工具分析关键词...

大家好&#xff0c;我是谷歌鸿飞&#xff0c;到今年算起&#xff0c;从业谷歌SEO&#xff0c;已经十一个年头了。服务过的外贸企业也有几百家&#xff0c;接触和操作过外贸产品也有上千种。这么多的企业&#xff0c;这么多的产品&#xff0c;思绪万千&#xff0c;不知如何下笔。…

计算机桌面设置定时,如何设置可以每月自动变化的日历桌面?

设置步骤&#xff1a;1、显示电脑桌面(即把所有窗口都最小化)&#xff1b;2、Windows Xp和Windows 2000设置有些不同&#xff1a;(windows vista好像不能设置活动桌面)Windows xp&#xff1a;在电脑桌面点击鼠标右键&#xff0c;出现菜单&#xff0c;选择“属性”&#xff0c;然…

系统辨识理论及应用_控制理论学习书单推荐(值得一读)

经 System control 授权&#xff0c;基于控制理论学习书单整理改编。提起系统与控制领域的学习&#xff0c;经常被谈论到的就是&#xff0c;对于刚接触这个领域的初学者总会在各种控制理论中迷茫&#xff0c;有的甚至直接劝退。面对众多理论&#xff0c;完全无从下手。下面就简…

正则只能小于0负数_2019–2020学年七年级数学期末考试考点之正数与负数考点详解...

七年级数学期末考试第一讲之正数与负数考点详解嗨&#xff0c;大家好&#xff0c;这里是摆渡学涯。马上我们就要迎来期末考试了&#xff0c;你们有没有开始复习呢&#xff1f;这次课程咱们来为大家讲一下数的考点&#xff0c;教你轻松学数学。数的概念数从是否为正负数的角度来…

controller接收json数据_SpringMVC实现多种数据类型绑定

点击上方“放学等我”&#xff0c;选择“置顶公众号”精品文章&#xff0c;第一时间送达绑定基本数据类型Java基本数据类型int的默认值是0&#xff0c;在使用int进行url传递参数时&#xff0c;参数key是必须写的&#xff0c;其值也只能是int类型的&#xff0c;否则将会报错。 比…

宝塔设置thinkphp的伪静态_宝塔面板与WDCP狭路相逢,谁才是国产之光?

我本来想给大家写一篇工具类的杂谈&#xff0c;思来想去又想到了可视化面板&#xff0c;就目前国产面板而言&#xff0c;WDCP、宝塔面板、AMH等&#xff0c;说是群雄逐鹿一点都不为过&#xff0c;AMH4.2之后&#xff0c;可以说是走了相当一部分人&#xff0c;暗示收费版本&…

计算机桌面打标签,在电脑桌面上添加便签的方法步骤详解(2)

电脑的桌面便签软件推荐1、CintaNotes电脑的桌面便签软件推荐图1CintaNotes是一款非常轻巧实用的笔记软件,可看作EverNote轻量级替代品。CintaNotes只需1个exe,体积仅1MB,却拥有EverNote易于收集、实时搜索、条状排列、tag分类的优点,更有EverNote 所不具备的中文搜索、纯文本更…

windows。forms.timer设置第一次不等待_适用于初学者的中线交易策略——金叉的三种设置条件...

本文将介绍了使用移动平均线最重要的方法之一——金叉。我们将描述该信号的产生条件&#xff0c;然后深入探讨一下三个交易案例。什么是金叉?当短期移动平均线与长期移动平均线相交时&#xff0c;黄叉就会产生。听起来确实很简单。然而&#xff0c;关键是构成交叉的移动平均线…

python多线程写同一个文件_Python多线程快速写入文件,python,飞速

Python多线程快速写入文件,python,飞速 发表时间&#xff1a;2020-07-10 乱序多线程写入 举个最简单的例子&#xff0c;只要求快速写入即可&#xff0c;对顺序无要求时&#xff1a; import threading def write_string(string, path"test.csv"): with open(path, a) …

2021山东科技大学计算机学院,2021年3月山东科技大学计算机等级考试报名工作通知...

【导语】2021年3月山东科技大学计算机等级考试报名工作通知已公布&#xff0c;为了方便广大考生的查阅&#xff0c;下面无忧考网为您详细介绍一下本次计算机等级考试报名的具体事宜&#xff0c;希望广大考生及时关注&#xff0c;如有相关疑问&#xff0c;敬请关注无忧考网为您实…

html表头的标签,HTML 表头单元格标签

HTML 标签标签定义及使用说明 标签定义 HTML 表格中的表头单元格。HTML 表格有两种单元格类型&#xff1a;表头单元格 - 包含头部信息(由 元素创建)标准单元格 - 包含数据(由 元素创建) 元素中的文本通常呈现为粗体并且居中。 元素中的文本通常是普通的左对齐文本。浏览器支持…

python中计算如何实现_基于python如何实现计算两组数据P值

我们在做A/B试验评估的时候需要借助p_value,这篇文章记录如何利用python计算两组数据的显著性。 一、代码# TTest.py # -*- coding: utf-8 -*-# Created on 2020-05-20 20:36 # TTest.py # author: huiwenhua## Import the packages import numpy as np from scipy import stat…

python自定义函数画图_python matplotlib自定义colorbar颜色条-以及matplotlib中的内置色条...

自定义colorbar&#xff08;draw colorbar without any mapple/plot&#xff09; 参考&#xff1a;Customized Colorbars Tutorial api example code: colorbar_only.py 自定义colorbar可以画出任何自己想要的colorbar&#xff0c;自由自在、不受约束&#xff0c;不依赖于任何已…

python绘制饼图程序_python使用Matplotlib绘制饼图

一、函数原型 plt.pie(x, explodeNone, labelsNone, colorsNone, autopctNone, pctdistance0.6, shadowFalse, labeldistance1.1, startangleNone, radiusNone, counterclockTrue, wedgepropsNone, textpropsNone, center(0, 0), frameFalse) 参数&#xff1a; x&#xff1a;绘…

centos选择什么版本_有几千个 Dubbo 实例的瓜子二手车,为什么要选择2.7.3版本?...

随着瓜子业务的不断发展&#xff0c;系统规模在逐渐扩大&#xff0c;目前在瓜子的私有云上已经运行着数百个 Apache Dubbo ( 下文简称 Dubbo )应用&#xff0c;上千个 Dubbo 实例。瓜子各部门业务迅速发展&#xff0c;版本没有来得及统一&#xff0c;各个部门都有自己的用法。随…

w7系统计算机里没有摄像头,win7系统没有摄像头不能视频的几种原因和解决方法...

电脑升级到win7旗舰版系统后&#xff0c;发现摄像头没有了&#xff0c;之前xp系统在硬盘符中就可以打开摄像头的&#xff0c;可是win7系统没有摄像头怎么办呢&#xff1f;这样就没办法视频了&#xff0c;针对此问题&#xff0c;小编研究出原来要从程序里面调出摄像头功能&#…

新计算机 安装win2000,图文教程!Windows 2000安装过程全接触

13、填写计算机名:安装程序提供了文字输入确定用户的计算机名和其它的设置。   在此&#xff0c;需要声明的是&#xff1a;安装程序会创建一个称为Administrator(系统管理员)的用户帐户,它拥有完全控制计算机的权限。确定这个帐户时&#xff0c;安装程序要求用户输入“系统管…

python创建多线程_初学者看过来:Python中多线程和多处理的指南

使用Python分析数据&#xff0c;如果使用了正确的数据结构和算法&#xff0c;有时可以大量提高程序的速度。实现此目的的一种方法是使用Muiltithreading(多线程)或Multiprocessing(多重处理)。 使用Python分析数据&#xff0c;如果使用了正确的数据结构和算法&#xff0c;有时可…