欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

windows環(huán)境下python連接openGauss數(shù)據(jù)庫的全過程

 更新時間:2023年01月04日 09:09:39   作者:Gauss松鼠會  
openGauss是一款全面友好開放,攜手伙伴共同打造的企業(yè)級開源關(guān)系型數(shù)據(jù)庫,這篇文章主要給大家介紹了關(guān)于windows環(huán)境下python連接openGauss數(shù)據(jù)庫的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下

一、python 介紹

python最新版

windows python是款面向?qū)ο?、直譯式計算機程序設(shè)計語言,同時也是一種功能強大而完善的通用型語言,具有非常簡潔而清晰的語法特點,適合完成各種高層任務(wù),幾乎可以在所有的操作系統(tǒng)中運行。

Python特殊功能

  • 很清楚、明確、易讀的語法
  • 較強的自省能力
  • 直觀的面向?qū)ο?/li>
  • 自然的表達(dá)程序代碼
  • 完整的模塊化設(shè)計,支持分層包
  • 基于異常的錯誤處理
  • 非常高的水平動態(tài)數(shù)據(jù)類型
  • 幾乎每一個任務(wù)的廣泛的標(biāo)準(zhǔn)庫和第三方模塊
  • 擴(kuò)展和模塊很容易寫在C,C + +(或Java的Jython或NET語言IronPython的)
  • 嵌入在應(yīng)用程序中作為腳本接口

Python 軟件亮點

  • 完全模塊化,Python核心編程軟件支持分層包
  • 基于異常的錯誤處理
  • 非常高級別的動態(tài)數(shù)據(jù)類型
  • 廣泛的標(biāo)準(zhǔn)庫和第三方模塊,Python核心編程軟件幾乎被用于每個任務(wù)
  • 擴(kuò)展和模塊易于使用C,C ++(或Jython Java,或IronPython的.NET語言)
  • 可嵌入應(yīng)用程序作為腳本界面

Python說明

Python是一個解釋性語言,因為不需要編譯和連接所以能節(jié)省大量的程序開發(fā)時間。解釋程序可以交互使用,這樣可以可以很容易地試驗語言的各種特色,寫只用一次的程序,或在從底向上程序開發(fā)中測試函數(shù)。它也是一個方便的計算器。

Python是一種面向?qū)ο?、直譯式計算機程序設(shè)計語言,也是一種功能強大而完善的通用型語言,已經(jīng)具有十多年的發(fā)展歷史,成熟且穩(wěn)定。這種語言具有非常簡捷而清晰的語法特點,適合完成各種高層任務(wù),幾乎可以在所有的操作系統(tǒng)中運行。目前,基于這種語言的相關(guān)技術(shù)正在飛速的發(fā)展,用戶數(shù)量急劇擴(kuò)大,相關(guān)的資源非常多。

Python可用于的操作系統(tǒng):Windows和Linux / Unix系統(tǒng),OS / 2,Mac上,Amiga上,其中包括。甚至有NET和Java虛擬機上運行,Python的實現(xiàn)是一個開源許可證,使得它可以自由使用和分派下,甚至用于商業(yè)用途。

二、Python下載及安裝

1、下載: 進(jìn)入python官網(wǎng)下載(https://www.python.org/)。鼠標(biāo)指向Downloads(不用點擊)會彈出下拉框,直接點擊windows下的Python 3.11.0即可下載。(國外網(wǎng)站下載較慢,建議找個國內(nèi)的資源下載)

2、下載好之后,右鍵以管理員身份運行exe可執(zhí)行文件。

這里勾選Add Python 3.11 to PATH (把Python的安裝路徑添加到系統(tǒng)環(huán)境 變量的Path變量中,如果不選那就需要自己配置環(huán)境變量了,參見FAQ) ,Install Now 默認(rèn)安裝,Customize installation 自定義安裝。

這里選自定義安裝,安裝Python文檔、Python的pip等…默認(rèn)即可,直接next

路徑可以更改一下:

自動安裝中……

最后點這里(紅圈處)。

安裝完成。

打開(cmd)終端窗口,輸入python命令,進(jìn)行驗證,看到相關(guān)版本信息,即表示安裝成功。

打開(cmd)終端窗口,輸入pip 命令,驗證環(huán)境變量是否配置成功。

下載并安裝模塊:打開cmd窗口,鍵入命令 pip install requests 進(jìn)行安裝,使用pip list命令查看是否已經(jīng)安裝模塊。

三、openGauss Connectors (Psycopg2) 介紹

Psycopg是一種用于執(zhí)行SQL語句的PythonAPI,可以為PostgreSQL、openGauss數(shù)據(jù)庫提供統(tǒng)一訪問接口,應(yīng)用程序可基于它進(jìn)行數(shù)據(jù)操作。Psycopg2是對libpq的封裝,主要使用C語言實現(xiàn),既高效又安全。它具有客戶端游標(biāo)和服務(wù)器端游標(biāo)、異步通信和通知、支持“COPY TO/COPY FROM”功能。支持多種類型Python開箱即用,適配PostgreSQL數(shù)據(jù)類型;通過靈活的對象適配系統(tǒng),可以擴(kuò)展和定制適配。Psycopg2兼容Unicode和Python 3。

openGauss數(shù)據(jù)庫提供了對Psycopg2特性的支持,并且支持Psycopg2通過SSL模式鏈接。

四、openGauss Connectors (Psycopg2)下載并初始化

登錄openGauss社區(qū)(https://opengauss.org/zh/download/)下載對應(yīng)的openGauss數(shù)據(jù)庫連接器(本測試環(huán)境下載的是Python-psycopg2_2.1.0,版本與數(shù)據(jù)版本匹配)。

從發(fā)布包中獲取,包名為openGauss-xxxx-操作系統(tǒng)版本號-64bit-Python.tar.gz。解壓后有兩個文件夾:psycopg2庫文件和lib庫文件。

將psycopg2拷貝到python安裝目錄的第三方包文件夾(即site-packages目錄)下。

將lib文件夾中的文件拷貝到安裝目錄Lib目錄下。

對于非數(shù)據(jù)庫用戶,需要將解壓后的lib目錄,配置在LD_LIBRARY_PATH環(huán)境變量中(參考FAQ)。

下載并安裝模塊:打開cmd窗口,鍵入命令pip install psycopg2

五、連接并訪問openGauss數(shù)據(jù)庫

前置條件:openGauss數(shù)據(jù)庫已成功安裝、并成功啟動。

編輯好python文件,并保存。(本測試腳本功能主要實現(xiàn)鏈接openGauss數(shù)據(jù)庫、創(chuàng)建表、插入數(shù)據(jù)、查詢數(shù)據(jù)等)

附原腳本:

#!/usr/bin/python
import psycopg2
conn = psycopg2.connect(database="postgres", user="omm2", password="P@ssw0rd123", host="192.168.52.3", port="26000")

cur = conn.cursor()

#創(chuàng)建表COMPANY1
cur.execute('''CREATE TABLE COMPANY1
       (ID INT PRIMARY KEY     NOT NULL,
       NAME           TEXT    NOT NULL,
       AGE            INT     NOT NULL,
       ADDRESS        CHAR(50),
       SALARY         REAL);''')
       
#插入數(shù)據(jù)       
cur.execute("INSERT INTO COMPANY1 (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (1, 'Paul', 32, 'California', 20000.00 )");

cur.execute("INSERT INTO COMPANY1 (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (2, 'Allen', 25, 'Texas', 15000.00 )");

cur.execute("INSERT INTO COMPANY1 (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )");

cur.execute("INSERT INTO COMPANY1 (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 )");       
      
#查詢結(jié)果
cur.execute("SELECT id, name, address, salary  from COMPANY1")
rows = cur.fetchall()
for row in rows:
   print("ID = ", row[0])
   print("NAME = ", row[1])
   print("ADDRESS = ", row[2])
   print("SALARY = ", row[3])

conn.commit()
conn.close()

執(zhí)行python腳本:打開(cmd)終端窗口, 執(zhí)行命令“python new2.py”,如下截圖。

如上出現(xiàn)以上結(jié)果, 則表示python鏈接openGauss數(shù)據(jù)庫成功,執(zhí)行創(chuàng)建表、插入數(shù)據(jù)、查詢數(shù)據(jù)成功。

六、問題總結(jié)(FAQ)

1、python 環(huán)境變量配置參考:

2、打開(cmd)終端窗口,輸入pip,遇到:‘pip’不是內(nèi)部或外部命令,也不是可運行的程序或批處理文件。即下圖這種情況:

解決辦法:添加環(huán)境變量。復(fù)制python安裝目錄 Scripts的路勁, 調(diào)價到 Path下(參考上文python安裝時配置環(huán)境變量的圖示)。

3、在執(zhí)行python腳本時,如果報錯:ModuleNotFoundError:No module named ‘psycopg2._psycopg’。 則需要執(zhí)行pip install psycopg2 命令, 下載安裝模塊。

4、在鏈接openGauss數(shù)據(jù)庫時,提示:Forbid remote connection with initial user ,意思是禁止用初始用戶進(jìn)行遠(yuǎn)程連接,即不要使用數(shù)據(jù)庫默認(rèn)的omm用戶訪問。

5、Psycopg(接口)參考

Psycopg接口是一套提供給用戶的API方法。

1)psycopg2.connect() :此方法創(chuàng)建新的數(shù)據(jù)庫會話并返回新的connection對象。

原型:

conn=psycopg2.connect(dbname=“test”,user=“postgres”,password=“secret”,host=“127.0.0.1”,port=“5432”)

返回值:connection對象(連接openGauss數(shù)據(jù)庫實例的對象)。

參數(shù) :

關(guān)鍵字 參數(shù)說明
dbname 數(shù)據(jù)庫名稱。
user 用戶名。
password 密碼。
host 數(shù)據(jù)庫IP地址,默認(rèn)為UNIX socket類型。
port 連接端口號,默認(rèn)為5432。
sslmode ssl模式,ssl連接時用。
sslcert 客戶端證書路徑,ssl連接時用。
sslkey 客戶端密鑰路徑,ssl連接時用。
sslrootcert 根證書路徑,ssl連接時用。

2)connection.cursor():此方法用于返回新的cursor對象。

原型:

cursor(name=None, cursor_factory=None, scrollable=None, withhold=False)

返回值 :cursor對象(用于整個數(shù)據(jù)庫使用Python編程的cursor)。

參數(shù) :
關(guān)鍵字 參數(shù)說明
name cursor名稱,默認(rèn)為None。
cursor_factory 用于創(chuàng)造非標(biāo)準(zhǔn)cursor,默認(rèn)為None。
scrollable 設(shè)置SCROLL選項,默認(rèn)為None。
withhold 設(shè)置HOLD選項,默認(rèn)為False。

3)cursor.execute(query,vars_list) :此方法執(zhí)行被參數(shù)化的SQL語句(即占位符,而不是SQL文字)。psycopg2模塊支持用%s標(biāo)志的占位符。

原型

curosr.execute(query,vars_list)

參數(shù):
關(guān)鍵字 參數(shù)說明
query 待執(zhí)行的sql語句。
vars_list 變量列表,匹配query中%s占位符。

4)cursor.fetchall():此方法獲取查詢結(jié)果的所有(剩余)行,并將它們作為元組列表返回。

原型:

cursor.fetchall()

5)connection.commit():此方法將當(dāng)前掛起的事務(wù)提交到數(shù)據(jù)庫。注意: 默認(rèn)情況下,Psycopg在執(zhí)行第一個命令之前打開一個事務(wù):如果不調(diào)用commit(),任何數(shù)據(jù)操作的效果都將丟失。

原型:

connection.commit()

6)connection.close():此方法關(guān)閉數(shù)據(jù)庫連接。注意: 此方法關(guān)閉數(shù)據(jù)庫連接,并不自動調(diào)用commit()。如果只是關(guān)閉數(shù)據(jù)庫連接而不調(diào)用commit()方法,那么所有更改將會丟失。

原型:

connection.close()

總結(jié)

到此這篇關(guān)于windows環(huán)境下python連接openGauss數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)windows python連接openGauss內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 50條SQL查詢技巧、查詢語句示例

    50條SQL查詢技巧、查詢語句示例

    這篇文章主要介紹了50條SQL查詢技巧、查詢語句示例,本文以學(xué)生表、課程表、成績表、教師表為例,講解不同需求下的SQL語句寫法,需要的朋友可以參考下
    2015-06-06
  • Navicat for SQLite安裝使用教程 附安裝包

    Navicat for SQLite安裝使用教程 附安裝包

    這篇文章主要介紹了Navicat for SQLite安裝教程 附安裝包,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-07-07
  • SQL關(guān)系模型的知識梳理總結(jié)

    SQL關(guān)系模型的知識梳理總結(jié)

    這篇文章主要為大家介紹了SQL關(guān)系模型,文中對SQL關(guān)系模型的知識作了詳細(xì)的梳理總結(jié),有需要的朋友可以借鑒參考下希望能夠有所幫助
    2021-10-10
  • MyBatis獲取數(shù)據(jù)庫自生成的主鍵Id詳解及實例代碼

    MyBatis獲取數(shù)據(jù)庫自生成的主鍵Id詳解及實例代碼

    這篇文章主要介紹了MyBatis獲取數(shù)據(jù)庫自生成的主鍵Id詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 數(shù)據(jù)庫之SQL注入原理以及過程的簡單介紹

    數(shù)據(jù)庫之SQL注入原理以及過程的簡單介紹

    這篇文章主要介紹了數(shù)據(jù)庫之SQL注入原理以及過程的簡單介紹,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 隱式轉(zhuǎn)換引起的sql慢查詢實戰(zhàn)記錄

    隱式轉(zhuǎn)換引起的sql慢查詢實戰(zhàn)記錄

    大家知道數(shù)據(jù)庫為了提高查詢速度,增加索引是必不可少的,但是有些時候即使你加了索引也不定有效果,這篇文章主要給大家介紹了一次因為隱式轉(zhuǎn)換引起的sql慢查詢的相關(guān)資料,需要的朋友可以參考下。
    2018-04-04
  • 在PostgreSQL上安裝并使用擴(kuò)展模塊的教程

    在PostgreSQL上安裝并使用擴(kuò)展模塊的教程

    這篇文章主要介紹了在PostgreSQL上安裝并使用擴(kuò)展模塊的教程,作者在Ubuntu系統(tǒng)上給出演示,需要的朋友可以參考下
    2015-04-04
  • 安裝navicat最新詳細(xì)流程

    安裝navicat最新詳細(xì)流程

    Navicat是一款獨立的數(shù)據(jù)庫管理工具,支持多種數(shù)據(jù)庫管理系統(tǒng),包括MySQL、MariaDB、Oracle、PostgreSQL、SQLite等,下面這篇文章主要給大家介紹了關(guān)于安裝navicat最新詳細(xì)流程,需要的朋友可以參考下
    2023-06-06
  • 簡單聊一聊SQL注入及防止SQL注入

    簡單聊一聊SQL注入及防止SQL注入

    眾所周知SQL注入是比較常見的網(wǎng)絡(luò)攻擊方式之一,它不是利用操作系統(tǒng)的BUG來實現(xiàn)攻擊,而是針對程序員編程時的疏忽,通過SQL語句,實現(xiàn)無帳號登錄,下面這篇文章主要給大家介紹了關(guān)于SQL注入及防止SQL注入的相關(guān)資料,需要的朋友可以參考下
    2022-03-03
  • 介紹PostgreSQL中的jsonb數(shù)據(jù)類型

    介紹PostgreSQL中的jsonb數(shù)據(jù)類型

    這篇文章主要介紹了介紹PostgreSQL中的jsonb數(shù)據(jù)類型,jsonb是PostgreSQL9.4中開始內(nèi)置的類型,能夠支持GIN索引,需要的朋友可以參考下
    2015-04-04

最新評論