亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python操作MySQL MongoDB Oracle三大數(shù)據(jù)庫(kù)深入對(duì)比

 更新時(shí)間:2021年10月27日 10:01:06   作者:數(shù)據(jù)分析與統(tǒng)計(jì)學(xué)之美  
對(duì)于數(shù)據(jù)分析師來(lái)說(shuō),學(xué)習(xí)數(shù)據(jù)庫(kù)最重要的就是學(xué)習(xí)它們的查詢功能。這篇文章就以這個(gè)為切入點(diǎn),為大家講述如何用Python操作這3個(gè)數(shù)據(jù)庫(kù)

作為數(shù)據(jù)分析師,掌握一門數(shù)據(jù)庫(kù)語(yǔ)言,是很有必要的。

今天黃同學(xué)就帶著大家學(xué)習(xí)兩個(gè)關(guān)系型數(shù)據(jù)庫(kù)MySQL、Oracle,了解一個(gè)非關(guān)系數(shù)據(jù)庫(kù)MongoDB。

在這里插入圖片描述

1. Python操作Oracle數(shù)據(jù)庫(kù)

這一部分的難點(diǎn)在于:環(huán)境配置有點(diǎn)繁瑣。不用擔(dān)心,我為大家寫了一篇關(guān)于Oracle環(huán)境配置的文章。

Python操作Oracle使用的是cx_Oracle庫(kù)。需要我們使用如下命令提前安裝:

pip insatll cx_Oracle

① Python鏈接Oracle服務(wù)器的3種方式

# ① 用戶名、密碼和監(jiān)聽(tīng)寫在一起
import cx_Oracle
db = cx_Oracle.connect('scott/a123456@DESKTOP-V4LKB10:1521/orcl')

# ② 用戶名、密碼和監(jiān)聽(tīng)分開(kāi)寫
import cx_Oracle
db = cx_Oracle.connect("scott","a123456","192.168.2.1:1521/orcl")

# ③ 配置監(jiān)聽(tīng)并連接
import cx_Oracle
moniter = cx_Oracle.makedsn('192.168.2.1',1521,'orcl')
db = cx_Oracle.connect('scott','a123456',moniter)

② Python怎么獲取Oracle中的數(shù)據(jù)?

這里有三種常用的方法,分別為大家進(jìn)行介紹。

Ⅰ fetchone():一次獲取一條記錄;

import cx_Oracle
# 注意:一定要加下面這兩行代碼,負(fù)責(zé)會(huì)中文亂碼;
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()

結(jié)果如下:

在這里插入圖片描述

Ⅱ fetchall():一次獲取所有記錄;

import cx_Oracle
# 注意:一定要加下面這兩行代碼,負(fù)責(zé)會(huì)中文亂碼;
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()

結(jié)果如下:

在這里插入圖片描述

Ⅲ 使用pandas中的read_sql()方法,將提取到的數(shù)據(jù)直接轉(zhuǎn)化為DataFrame進(jìn)行操作;

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)

結(jié)果如下:

在這里插入圖片描述

2. Python操作MySQL數(shù)據(jù)庫(kù)

MySQL數(shù)據(jù)庫(kù)應(yīng)該是國(guó)內(nèi)應(yīng)用最多的數(shù)據(jù)庫(kù)。大多數(shù)公司一般都是使用的該數(shù)據(jù)庫(kù)。這也就是很多學(xué)生在畢業(yè)之前都會(huì)選擇學(xué)習(xí)該數(shù)據(jù)庫(kù)知識(shí),用于面試。

Python操作MySQL使用的是cx_Oracle庫(kù)。需要我們使用如下命令提前安裝:

pip insatll pymysql

更多細(xì)節(jié)參考:Python操作Oracle詳解!

① Python鏈接MySQL服務(wù)器

import pymysql 

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

這里面有六個(gè)參數(shù),需要為大家一一介紹一下:

參數(shù)host:mysql服務(wù)器所在的主機(jī)的ip;

參數(shù)user:用戶名;

參數(shù)password:密碼;

參數(shù)port:連接的mysql主機(jī)的端口,默認(rèn)是3306;

參數(shù)db:連接的數(shù)據(jù)庫(kù)名;

參數(shù)charset:當(dāng)讀取數(shù)據(jù)出現(xiàn)中文會(huì)亂碼的時(shí)候,需要我們?cè)O(shè)置一下編碼;我們使用python操作數(shù)據(jù)庫(kù)的時(shí)候,那么python就相當(dāng)于是client,我們是用這個(gè)client來(lái)操作mysql的server服務(wù)器,python3默認(rèn)采用的utf8字符集,我的mysql服務(wù)器默認(rèn)采用latin1字符集,因此mysql中創(chuàng)建的每張表,都是建表的時(shí)候加了utf8編碼的,因此這里設(shè)置的應(yīng)該就是connection連接器的編碼;

② Python怎么獲取MySQL中的數(shù)據(jù)?

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

結(jié)果如下:

在這里插入圖片描述

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

結(jié)果如下:

在這里插入圖片描述

Ⅲ 使用pandas中的read_sql()方法,將提取到的數(shù)據(jù)直接轉(zhuǎn)化為DataFrame進(jìn)行操作;

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)

結(jié)果如下:

在這里插入圖片描述

3. Python操作MongoDB數(shù)據(jù)庫(kù)

這一部分主要帶大家對(duì)比學(xué)習(xí):關(guān)系型數(shù)據(jù)和非關(guān)系型數(shù)據(jù)庫(kù)的不同之處。咱們了解一下即可,不必過(guò)深研究,因?yàn)閿?shù)據(jù)分析師基本不會(huì)使用這種數(shù)據(jù)庫(kù)。

Python操作MongoDB使用的是pymongo庫(kù)。需要我們使用如下命令提前安裝:

pip insatll pymongo

更多細(xì)節(jié)參考:Python操作MongoDB詳解!

① Python鏈接MongoDB服務(wù)器

from pymongo import MongoClient

conn = MongoClient("localhost",27017)

② Python怎么獲取MongoDB中的數(shù)據(jù)?

Ⅰ 查詢部分文檔;

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

Ⅱ 查詢所有文檔;

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

Ⅲ 統(tǒng)計(jì)查詢;

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

Ⅳ 根據(jù) id 查詢;

這里需要引入第三方庫(kù)。

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)

Ⅵ 降序排序;

這里也需要引入第三方庫(kù)。

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

Ⅶ 分頁(yè)查詢

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

以上就是Python操作MySQL MongoDB Oracle三大數(shù)據(jù)庫(kù)深入對(duì)比的詳細(xì)內(nèi)容,更多關(guān)于Python操作MySQL MongoDB Oracle對(duì)比的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python編程使用selenium編寫測(cè)試用例

    python編程使用selenium編寫測(cè)試用例

    這篇文章主要為大家介紹了在python編程學(xué)習(xí)中如何使用selenium來(lái)編寫測(cè)試用例,文中給出了詳細(xì)的測(cè)試用例代碼,有需要的朋友可以借鑒參考下
    2021-10-10
  • Python利用PIL實(shí)現(xiàn)多張圖片合成gif動(dòng)畫的案例詳解

    Python利用PIL實(shí)現(xiàn)多張圖片合成gif動(dòng)畫的案例詳解

    這篇文章主要介紹了Python利用PIL實(shí)現(xiàn)多張圖片合成gif動(dòng)畫的案例,文章通過(guò)代碼示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,感興趣的小伙伴可以自己動(dòng)手試一下
    2023-11-11
  • Python條件分支?if?語(yǔ)句全講解(一文掌握)

    Python條件分支?if?語(yǔ)句全講解(一文掌握)

    在Python編程中,布爾運(yùn)算符有明確的優(yōu)先級(jí)順序,影響代碼邏輯判斷,從高到低依次是:括號(hào)()、not、and、or,括號(hào)用于明確運(yùn)算順序,not具有次高優(yōu)先級(jí),影響單個(gè)布爾值,and和or則根據(jù)優(yōu)先級(jí)順序結(jié)合布爾值,正確理解和應(yīng)用這些優(yōu)先級(jí)對(duì)于編寫有效和準(zhǔn)確的條件語(yǔ)句至關(guān)重要
    2024-10-10
  • python中關(guān)于CIFAR10數(shù)據(jù)集的使用

    python中關(guān)于CIFAR10數(shù)據(jù)集的使用

    這篇文章主要介紹了python中關(guān)于CIFAR10數(shù)據(jù)集的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Django模板Templates使用方法詳解

    Django模板Templates使用方法詳解

    這篇文章主要介紹了Django模板Templates使用方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • python pyinstaller打包exe報(bào)錯(cuò)的解決方法

    python pyinstaller打包exe報(bào)錯(cuò)的解決方法

    這篇文章主要給大家介紹了關(guān)于python pyinstaller打包exe報(bào)錯(cuò)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 在Windows中設(shè)置Python環(huán)境變量的實(shí)例講解

    在Windows中設(shè)置Python環(huán)境變量的實(shí)例講解

    下面小編就為大家分享一篇在Windows中設(shè)置Python環(huán)境變量的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • 淺談Python]程序的分支結(jié)構(gòu)

    淺談Python]程序的分支結(jié)構(gòu)

    這篇文章主要介紹了淺談Python]程序的分支結(jié)構(gòu),語(yǔ)句塊是 if 條件滿足后執(zhí)行的一個(gè)或多個(gè)語(yǔ)句序列,語(yǔ)句塊中語(yǔ)句通過(guò)與 if 所在行形成縮進(jìn)表達(dá)包含關(guān)系,需要的朋友可以參考下
    2023-04-04
  • 實(shí)現(xiàn)用python算法計(jì)算圓周率的小訣竅

    實(shí)現(xiàn)用python算法計(jì)算圓周率的小訣竅

    什么!你不會(huì)背圓周率(鄙夷的眼神) 3.1415926535 8979323846 26433... 但是,我會(huì)算啊,本文用一個(gè)簡(jiǎn)單的python代碼,教你計(jì)算圓周率
    2021-08-08
  • Python格式化輸出%s和%d

    Python格式化輸出%s和%d

    本篇文章主要介紹了Python格式化輸出%s和%d的實(shí)例案例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05

最新評(píng)論