使用PythonSQLAlchemy庫的方法-創(chuàng)新互聯(lián)

使用Python SQLAlchemy庫的方法?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

創(chuàng)新互聯(lián)公司專注于中大型企業(yè)的網(wǎng)站設計、成都網(wǎng)站設計和網(wǎng)站改版、網(wǎng)站營銷服務,追求商業(yè)策劃與數(shù)據(jù)分析、創(chuàng)意藝術與技術開發(fā)的融合,累計客戶上千,服務滿意度達97%。幫助廣大客戶順利對接上互聯(lián)網(wǎng)浪潮,準確優(yōu)選出符合自己需要的互聯(lián)網(wǎng)運用,我們將一直專注品牌網(wǎng)站建設和互聯(lián)網(wǎng)程序開發(fā),在前進的路上,與客戶一起成長!

一、SQLAlchemy簡介

1.1、SQLAlchemy是什么?

sqlalchemy是一個python語言實現(xiàn)的的針對關系型數(shù)據(jù)庫的orm庫??捎糜谶B接大多數(shù)常見的數(shù)據(jù)庫,比如Postges、MySQL、SQLite、Oracle等。

1.2、為什么要使用SQLAlchemy?

它將你的代碼從底層數(shù)據(jù)庫及其相關的SQL特性中抽象出來。

1.3、SQLAlchemy提供了兩種主要的使用模式

  • SQL表達式語言(SQLAlchemy Core)
  • ORM
     

1.4、應該選擇哪種模式?

雖然你使用的框架中已經(jīng)內(nèi)置了ORM,但是希望添加更強大的報表功能,請選用Core。
如果你想在一個一模式為中心的視圖中查看數(shù)據(jù)(用戶類似于SQL),請使用Core。
如果你的數(shù)據(jù)不需要業(yè)務對象,請使用Core。
如果你要把數(shù)據(jù)看作業(yè)務對象,請使用ORM。
如果你想快速創(chuàng)建原型,請使用ORM。
如果你需要同事使用業(yè)務對象和其他與問題域無關的數(shù)據(jù),請組合使用Core和ORM。

1.5、連接數(shù)據(jù)庫

要連接到數(shù)據(jù)庫,需要先創(chuàng)建一個SQLAlchemy引擎。SQLAlchemy引擎為數(shù)據(jù)庫創(chuàng)建一個公共接口來執(zhí)行SQL語句。這是通過包裝數(shù)據(jù)庫連接池和方言(不同數(shù)據(jù)庫客戶端)來實現(xiàn)的。

SQLAlchemy提供了一個函數(shù)來創(chuàng)建引擎。在這個函數(shù)中,你可以指定連接字符串,以及其他一些可選的關鍵字參數(shù)。

from sqlalchemy import create_engine
engine = create_engine('sqlite:///cookies.db')
engine1 = create_engine('sqlite:///:memory:')
engine2 = create_engine('sqlite://///home/cookiemonster/cookies.db')
engine3 = create_engine('sqlite:///c:\\Users\\cookiemonster\\cookies.db')

engine_mysql = create_engine('mysql+pymysql://cookiemonster:chocolatechip', '@mysql01.monster.internal/cookies', pool_recycle=3600)

網(wǎng)站標題:使用PythonSQLAlchemy庫的方法-創(chuàng)新互聯(lián)
文章分享:http://www.muchs.cn/article30/djhgpo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名外貿(mào)網(wǎng)站建設、自適應網(wǎng)站、云服務器、品牌網(wǎng)站制作App開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設