大蟒蛇python教程共享Python操作MySQL MongoDB Oracle三大数据库深入对比

目录
  • 1. python操作oracle数据库
  • 2. python操作mysql数据库
  • 3. python操作mongodb数据库

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

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

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

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()  

结果如下:

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

ⅱ 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()  

结果如下:

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

ⅲ 使用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)  

结果如下:

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

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()  

结果如下:

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

ⅱ 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()  

结果如下:

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

ⅲ 使用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)  

结果如下:

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

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对比的资料请关注<计算机技术网(www.ctvol.com)!!>其它相关文章!

需要了解更多python教程分享Python操作MySQL MongoDB Oracle三大数据库深入对比,都可以关注python教程分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/pythontutorial/902100.html

(0)
上一篇 2021年10月27日
下一篇 2021年10月27日

精彩推荐