返回顶部
首页 > 资讯 > 数据库 >Python操作MySQL MongoDB Oracle三大数据库深入对比
  • 806
分享到

Python操作MySQL MongoDB Oracle三大数据库深入对比

2024-04-02 19:04:59 806人浏览 独家记忆
摘要

目录1. python操作oracle数据库2. Python操作Mysql数据库3. Python操作mongoDB数据库作为数据分析师,掌握一门数据库语言,是很有必要的。 今天黄

作为数据分析师,掌握一门数据库语言,是很有必要的。

今天黄同学就带着大家学习两个关系型数据库mysql、Oracle,了解一个非关系数据库MonGoDB。

在这里插入图片描述

1. Python操作Oracle数据库

这一部分的难点在于:环境配置有点繁琐。不用担心,我为大家写了一篇关于Oracle环境配置的文章。

Python操作Oracle使用的是cx_Oracle库。需要我们使用如下命令提前安装:


pip insatll cx_Oracle

① Python链接Oracle服务器的3种方式


# ① 用户名、密码和监听写在一起
import cx_Oracle
db = cx_Oracle.connect('scott/a123456@DESKTOP-V4LKB10:1521/orcl')

# ② 用户名、密码和监听分开写
import cx_Oracle
db = cx_Oracle.connect("scott","a123456","192.168.2.1:1521/orcl")

# ③ 配置监听并连接
import cx_Oracle
moniter = cx_Oracle.makedsn('192.168.2.1',1521,'orcl')
db = cx_Oracle.connect('scott','a123456',moniter)

② Python怎么获取Oracle中的数据?

这里有三种常用的方法,分别为大家进行介绍。

Ⅰ fetchone():一次获取一条记录;


import cx_Oracle
# 注意:一定要加下面这两行代码,负责会中文乱码;
import os
os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'

db = cx_Oracle.connect("scott","a123456","192.168.2.1:1521/orcl")
cursor = db.cursor()

cursor.execute('select count(*) from emp1')
aa = cursor.fetchone()
print(aa)
cursor.execute('select ename,deptno,sal from emp1')     
for i in range(aa[0]):
    a,b,c = cursor.fetchone()
    d = "我的名字叫{},所在部门是{},工资是{}美元".fORMat(a,b,c)
    display(d)
db.close()

结果如下:

在这里插入图片描述

Ⅱ fetchall():一次获取所有记录;


import cx_Oracle
# 注意:一定要加下面这两行代码,负责会中文乱码;
import os
os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'

db = cx_Oracle.connect("scott","a123456","192.168.2.1:1521/orcl")
cursor = db.cursor()

cursor.execute('select ename,deptno,sal from emp1')    
aa = cursor.fetchall()
# print(aa)
for a,b,c in aa:
    d = "我的名字叫{},所在部门是{},工资是{}美元".format(a,b,c)
    display(d)
db.close()

结果如下:

在这里插入图片描述

Ⅲ 使用pandas中的read_sql()方法,将提取到的数据直接转化为DataFrame进行操作;


import cx_Oracle
import pandas as pd
import os
os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'

db = cx_Oracle.connect("scott","a123456","192.168.2.1:1521/orcl")
cursor = db.cursor()

df1 = pd.read_sql("select * from emp where deptno=20",db)
display(df1)

df2 = pd.read_sql("select * from emp where deptno=30",db)
display(df2)

结果如下:

在这里插入图片描述

2. Python操作MySQL数据库

MySQL数据库应该是国内应用最多的数据库。大多数公司一般都是使用的该数据库。这也就是很多学生在毕业之前都会选择学习该数据库知识,用于面试

Python操作MySQL使用的是cx_Oracle库。需要我们使用如下命令提前安装:


pip insatll pymysql

更多细节参考:Python操作Oracle详解!

① Python链接MySQL服务器


import pymysql 

db = pymysql.connect(host='localhost',user='root',passWord='123456',port=3306,db='spiders',charset=' utf8')

这里面有六个参数,需要为大家一一介绍一下:

参数host:mysql服务器所在的主机的ip;

参数user:用户名;

参数password:密码;

参数port:连接的mysql主机的端口,默认是3306;

参数db:连接的数据库名;

参数charset:当读取数据出现中文会乱码的时候,需要我们设置一下编码;我们使用python操作数据库的时候,那么python就相当于是client,我们是用这个client来操作mysql的server服务器,python3默认采用的utf8字符集,我的mysql服务器默认采用latin1字符集,因此mysql中创建的每张表,都是建表的时候加了utf8编码的,因此这里设置的应该就是connection连接器的编码;

② Python怎么获取MySQL中的数据?

Ⅰ fetchone():一次获取一条记录;


import  pymysql
 
db = pymysql.connect(host='localhost',user='root',db='huangwei',password='123456',port=3306,charset='utf8')                     
cursor = db.cursor()
cursor.execute('select count(*) from person')
aa = cursor.fetchone()
print(aa)
cursor.execute('select name,age from person')    
for i in range(aa[0]):
    a,b = cursor.fetchone()
    c = "我的名字叫{},今年{}岁".format(a,b)
    display(c)
db.close()

结果如下:

在这里插入图片描述

Ⅱ fetchall():一次获取所有记录;


import  pymysql
 
db = pymysql.connect(host='localhost',user='root',db='huangwei',password='123456',port=3306,charset='utf8')
cursor = db.cursor()
cursor.execute('select name,age from person')
aa = cursor.fetchall()
# print(aa)
for a,b in aa:
    c = "我的名字叫{},今年{}岁".format(a,b)
    display(c)
db.close()

结果如下:

在这里插入图片描述

Ⅲ 使用pandas中的read_sql()方法,将提取到的数据直接转化为DataFrame进行操作;


import pymysql 
import pandas as pd
db = pymysql.connect(host='localhost',user='root',db='huangwei',password='123456',port=3306,charset='utf8')
cursor = db.cursor()
df1 = pd.read_sql("select * from student where ssex='男'",db)
display(df1)
df2 = pd.read_sql("select * from student where ssex='女'",db)
display(df2)

结果如下:

在这里插入图片描述

3. Python操作MongoDB数据库

这一部分主要带大家对比学习:关系型数据和非关系型数据库的不同之处。咱们了解一下即可,不必过深研究,因为数据分析师基本不会使用这种数据库。

Python操作MongoDB使用的是pymongo库。需要我们使用如下命令提前安装:


pip insatll pymongo

更多细节参考:Python操作MongoDB详解!

① Python链接MongoDB服务器


from pymongo import MongoClient

conn = MongoClient("localhost",27017)

② Python怎么获取MongoDB中的数据?

Ⅰ 查询部分文档;


res = collection.find({"age": {"$gte": 19}})
for row in res:
	print(row)

Ⅱ 查询所有文档;


res = collection.find()
for row in res:
	print(row)

Ⅲ 统计查询;


res = collection.find().count()
print(res)

Ⅳ 根据 id 查询;

这里需要引入第三方库。


from bson.objectid import ObjectId
res = collection.find({"_id":ObjectId("5cc506289e1d88c95465488e")})
print(res[0])

Ⅴ 升序排序


res = collection.find().sort("age")
for row in res:
	print(row)

Ⅵ 降序排序;

这里也需要引入第三方库。


import pymongo
res = collection.find().sort("age",pymongo.DESCENDING)
for row in res:
	print(row)

Ⅶ 分页查询


res = collection.find().limit(3).skip(5)
for row in res:
	print(row)

以上就是Python操作MySQL MongoDB Oracle三大数据库深入对比的详细内容,更多关于Python操作MySQL MongoDB Oracle对比的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: Python操作MySQL MongoDB Oracle三大数据库深入对比

本文链接: https://lsjlt.com/news/155589.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python操作MySQL MongoDB Oracle三大数据库深入对比
    目录1. Python操作Oracle数据库2. Python操作MySQL数据库3. Python操作MongoDB数据库作为数据分析师,掌握一门数据库语言,是很有必要的。 今天黄...
    99+
    2024-04-02
  • Python操作MySQL MongoDB Oracle三大数据库的区别有哪些
    这篇文章主要讲解了“Python操作MySQL MongoDB Oracle三大数据库的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python操作MySQL MongoDB O...
    99+
    2023-06-25
  • MongoDB(三):数据库操作、集合操作
    1. 数据库操作 看完前面的文章,大家应该把环境搭建好了,下面我们就开始学习MongoDB的一些基本操作了。 首先我们要了解的一些要点: MongoDB将数据存储为一个文档,数据结构由键值对(key=>value)组成 MongoDB文档...
    99+
    2017-03-01
    MongoDB(三):数据库操作 集合操作
  • Python 对mysql数据库的操作
    Python 对mysql数据库的操作 #!/usr/bin/python # -*- coding: utf-8 -*- import MySQLdb class mysql:     def __init__(self, sql, h...
    99+
    2023-01-31
    操作 数据库 Python
  • 部分Mongodb数据如何操作导入mysql数据库
    下文主要给大家带来部分Mongodb数据如何操作导入mysql数据库,希望这些内容能够带给大家实际用处,这也是我编辑部分Mongodb数据如何操作导入mysql数据库这篇文章的主要目的。好了,废话不多说,大...
    99+
    2024-04-02
  • 深入研究:Sybase和Oracle数据库的技术对比
    Sybase和Oracle是两个常见的关系型数据库管理系统,它们在企业领域被广泛应用。本文将深入研究Sybase和Oracle数据库的技术对比,包括各自的优势、劣势和适用场景,并给出具...
    99+
    2024-03-08
    oracle 对比 sybase
  • python-对于mysql数据库的操作
    python操作mysql数据库 问题:DDL,DCL,DML的区别? 语言与框架:jdbc/odbc操作数据库    java(ibatis/hibernate/jpa)操作数据库 客户端工具:navicat for mysql   步...
    99+
    2023-01-30
    操作 数据库 python
  • Oracle学习(三) --- 数据库操作
    Oracle表与用户关联 每一个用户,需要确定表存放位置,这个位置称为表空间 在Oracle中表空间分2中:永久表空间、临时表空间 临时表空间:使用SQL语句操作时,结果先进入临时表空间 永久表空间:当执行commit时,数据将从临时表...
    99+
    2016-01-31
    Oracle学习(三) --- 数据库操作
  • Python对数据库操作
    Windows下安装MySQL-python 下载地址:https://pypi.python.org/pypi/MySQL-python/1.2.5 安装到系统即可。 linux下安装MySQL-py...
    99+
    2022-06-04
    操作 数据库 Python
  • python 操作 mongodb 数据库详情
    目录一、安装二、连接数据库三、创建数据库四、所有数据库五、创建集合六、插入数据七、查询数据八、高级查询九、count统计十、修改数据十一、删除数据十二、数据排序一、安装 pip in...
    99+
    2024-04-02
  • Python怎么操作MongoDB数据库
    这篇文章主要介绍“Python怎么操作MongoDB数据库”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python怎么操作MongoDB数据库”文章能帮助大家解决问题。一、连接器的安装和配置pym...
    99+
    2023-07-05
  • 数据库MySQL简单操作(三)
    1.3 多表查询1.3.1连接查询:#内连接:自连接查询:#外连接左外连接(可以查询出表名1的所有记录,而表名2中只能查出匹配的记录)SELECT 属性名列表 FROM 表名1 LEFT JOIN ...
    99+
    2024-04-02
  • 用python操作mysql数据库(之简单“插入数据”操作)
    #!/usr/bin/env python # -*- coding: utf-8 -*- ''' 1、这里的数据库环境为本地数据库 2、我要通过pytho...
    99+
    2024-04-02
  • 深入学习MySQL表数据操作
    目录前言正式上菜插入数据全部字段插入单条数据指定字段插入多条数据ON DUPLICATE KEY UPDATE修改数据删除数据查询数据简单查询聚合函数条件查询等值查询批量查询...
    99+
    2022-11-13
    MySQL表数据操作 MySQL表操作
  • 如何用python 操作MongoDB数据库
    目录一、前言 二、操作 MongoDB 1、安装 pymongo 2、连接 MongoDB 3、选择数据库 4、选择集合 5、插入数据 6、查询 7、更新数据 8、删除 一...
    99+
    2024-04-02
  • Python中怎么操作MongoDB数据库
    这期内容当中小编将会给大家带来有关Python中怎么操作MongoDB数据库,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、连接服务器连接服务器需要提供一个地址和接口import pymong...
    99+
    2023-06-15
  • Python 操作 MySQL数据库
    开发环境与配置 win_x64 Ubuntu14.04 Python3.x pip安装pymysql模块 直接使用pip安装 pip install pymysql win64上直接在cmd中执...
    99+
    2022-05-30
    Python 操作 MySQL python MySQL
  • python操作mysql数据库
    一、数据库基本操作 1. 想允许在数据库写中文,可在创建数据库时用下面命令 create database zcl charset utf8; 2. 查看students表结构 desc students;...
    99+
    2022-06-04
    操作 数据库 python
  • Python——操作MySQL数据库
    😊Python——操作MySQL数据库 🚀前言🔍数据库编程🍭数据库编程基本介绍🍭数据库编程接口🍭...
    99+
    2023-09-15
    数据库 python mysql
  • Python 操作 MySQL 数据库
    Python 操作 MySQL 数据库 Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口。 Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: ...
    99+
    2023-09-01
    adb
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作