python可以用哪些数据库


Posted in Python onJune 22, 2020

数据库分类

早期数据库模型有三种,分别为层次式数据库、网络式数据库和关系型数据库。

而在当今的互联网中,通常把数据库分为两类,即关系型数据库和非关系型数据库。

关系型数据库

关系型数据库是指采用了关系模型来组织数据的数据库,而关系模型是由二维表及其联系组成的数据组织。

优点:

1、易于维护:都是使用表结构,格式一致;

2、使用方便:SQL语言通用,可用于复杂查询;

3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。

缺点:

1、读写性能比较差,尤其是海量数据的高效率读写;

2、固定的表结构,灵活度稍欠;

3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。

目前主流的关系型数据库有

MYSQL

目前使用最广泛的开源、多平台的关系型数据库,支持事务、符合ACID、支持多数SQL规范

SQL Server

支持事务、符合ACID、支持多数SQL规范,属于商业软件,需要注意版权和licence授权费用

Oracle

支持事务,符合关系型数据库原理,符合ACID,支持多数SQL规范,功能最强大、最复杂、市场占比最高的商业数据库

Postgresql

开源、多平台、关系型数据库,功能最强大的开源数据库,需要python环境,基于postgresql的TimeScaleDB,是目前比较火的时序数据库之一。(更多学习内容,请点击python学习网)

非关系型数据库

非关系型数据库也称为NOSQL(Not Only SQL),作为关系型数据库的一个补充,能在特定场景和特点问题下发挥高效率和高性能。

常见的非关系型数据库类型有键值(Key-Value)存储数据库和面向文档数据库(Document-oriented)

键值存储数据库类似hash,通过key做添加、删除、查询,性能高,优势在于简单、易部署、高并发,主要产品有

Redis

开源、Linux平台、key-value键值型Nosql数据库,简单稳定,非常主流的、全数据in-momory、定位于“快”的键值型nosql数据库

Memcaced

一个开源的、高性能的、具有分布式内存对象的缓存系统,通过它可以减轻数据库负载,加速动态的web应用

面向文档数据库以文档的形式存储,每个文档是一系列数据项的集合,每个数据项有名称与对应的值,主要产品有

MongoDB

开源、多平台、文档型nosql数据库,“最像关系型数据库”,定位于“灵活”的nosql数据库。适用于网站后台数据库(更新快、实时复制)、小文件系统(json,二进制)、日志分析系统(数据量大的文件)。

知识点扩展:

Python的数据库支持

经过两个多月的学习,我们对Python的基础语法大概都已经学完了,接下来我们要把我们学到的东西逐步用到应用的层面上。今天,我们要学的是,用Python实现数据库的对接。

我们先来讲一下什么是api,在编程语言的学习中,我们经常会接触到api这个词,那么究竟什么是api,简单来说就是一个接口,像java的api,有一个专门的api文档提供查询。Python数据库的api是DB API。我们主要讲的api版本是DB API2.0。

Python DB API有三个模块属性:

1、apilevel:这个属性主要是用来定义使用的Python DB API 的版本,像我们上面说的DB API 2.0;

2、threadsafety:这个是用来定义模块的线程安全度;

该参数是一个0到3的整数,0表示线程不能共享模块,1表示线程可共享模块本身,2表示线程可共享模块和连接, 但不能共享游标,3表示模块是绝对线程安全的。

3、paramstyle:这个属性定义在SQL查询中使用哪种参数风格,这里说明一下,SQL是指数据库的意思。

这个我们就不具体讲了,因为现在刚接触新知识,引入这个知识点,会很容易感到迷茫。

到此这篇关于python可以用哪些数据库的文章就介绍到这了,更多相关python支持哪些数据库内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python聊天程序实例代码分享
Nov 18 Python
使用Python简单的实现树莓派的WEB控制
Feb 18 Python
Python实现更改图片尺寸大小的方法(基于Pillow包)
Sep 19 Python
windows及linux环境下永久修改pip镜像源的方法
Nov 28 Python
Python结巴中文分词工具使用过程中遇到的问题及解决方法
Apr 15 Python
简单了解python的break、continue、pass
Jul 08 Python
Django后端发送小程序微信模板消息示例(服务通知)
Dec 17 Python
Pytorch实现LSTM和GRU示例
Jan 14 Python
使用Python将图片转正方形的两种方法实例代码详解
Apr 29 Python
详解tensorflow2.x版本无法调用gpu的一种解决方法
May 25 Python
Python 通过正则表达式快速获取电影的下载地址
Aug 17 Python
Python GUI编程之tkinter 关于 ttkbootstrap 的使用详解
Mar 03 Python
Python ckeditor富文本编辑器代码实例解析
Jun 22 #Python
keras做CNN的训练误差loss的下降操作
Jun 22 #Python
keras 自定义loss model.add_loss的使用详解
Jun 22 #Python
Python项目跨域问题解决方案
Jun 22 #Python
python os模块在系统管理中的应用
Jun 22 #Python
解决tensorflow读取本地MNITS_data失败的原因
Jun 22 #Python
python实现猜数游戏(保存游戏记录)
Jun 22 #Python
You might like
Ajax PHP简单入门教程代码
2008/04/25 PHP
PHP类与对象中的private访问控制的疑问
2012/11/01 PHP
修改ThinkPHP缓存为Memcache的方法
2014/06/25 PHP
MacOS 安装 PHP的图片裁剪扩展Tclip
2015/03/25 PHP
php打造智能化的柱状图程序,用于报表等
2015/06/19 PHP
php使用高斯算法实现图片的模糊处理功能示例
2016/11/11 PHP
PHP实现生成模糊图片的方法示例
2017/12/21 PHP
PHP长连接实现与使用方法详解
2018/02/11 PHP
PHP实现简单用户登录界面
2019/10/23 PHP
一个刚完成的layout(拖动流畅,不受iframe影响)
2007/08/17 Javascript
DWR Ext 加载数据
2009/03/22 Javascript
JavaScript中的集合及效率
2010/01/08 Javascript
jquery中toggle函数交替使用问题
2015/06/22 Javascript
用js读写cookie的简单方法(推荐)
2016/08/08 Javascript
Vue 中批量下载文件并打包的示例代码
2017/11/20 Javascript
vue-auto-focus: 控制自动聚焦行为的 vue 指令方法
2018/08/25 Javascript
python的urllib模块显示下载进度示例
2014/01/17 Python
在Python中操作列表之list.extend()方法的使用
2015/05/20 Python
OpenCV实现人脸识别
2017/04/07 Python
Python实现的用户登录系统功能示例
2018/02/05 Python
opencv改变imshow窗口大小,窗口位置的方法
2018/04/02 Python
python pandas消除空值和空格以及 Nan数据替换方法
2018/10/30 Python
Python微信操控itchat的方法
2019/05/31 Python
python opencv 简单阈值算法的实现
2019/08/04 Python
Django如何实现上传图片功能
2019/08/16 Python
CentOS7下安装python3.6.8的教程详解
2020/01/03 Python
PyCharm Anaconda配置PyQt5开发环境及创建项目的教程详解
2020/03/24 Python
django 数据库返回queryset实现封装为字典
2020/05/19 Python
python基于openpyxl生成excel文件
2020/12/23 Python
英国二手物品交易网站:Preloved
2017/10/06 全球购物
瑞典最大的儿童用品网上商店:pinkorblue.se
2021/03/09 全球购物
表彰先进集体通报
2014/01/12 职场文书
食品流通安全承诺书
2014/05/22 职场文书
python实现图片九宫格分割的示例
2021/04/25 Python
Python基础数据类型tuple元组的概念与用法
2021/08/02 Python
Python Django模型详解
2021/10/05 Python