【Python入門】44.數據庫之 使用SQLAlchemy

摘要:教你如何使用SQLAlchemy創(chuàng)建數據庫表


*寫在前面:為了更好的學習python十兢,博主記錄下自己的學習路程。本學習筆記基于廖雪峰的Python教程肺缕,如有侵權狈涮,請告知刪除。歡迎與博主一起學習Pythonヽ( ̄▽ ̄)? *


目錄

數據庫
使用SQLAlchemy

數據庫

使用SQLAlchemy

在Python中涯鲁,我們要表示一個表格內容的話巷查,可以用list表示,像這樣:

[
    ('1', 'Ming'),
    ('2', 'Hong'),
    ('3', 'Leo')
]

這是一個user表抹腿,包含了id和name岛请。

但是這樣用tuple表示一行,很難看出表的結構警绩,我們可以class實例來表示:

class User(object):
    def __init__(self, id, name):
        self.id = id
        self.name = name

[
    User('1', 'Ming'),
    User('2', 'Hong'),
    User('3', 'Leo')
]

這種把關系數據庫的表結構映射到對象上的技術就是ORM(Object-Relational Mapping)技術崇败。

執(zhí)行這種轉換的框架就是ORM框架。

SQLAlchemy就是一種ORM框架肩祥,我們來看一下如何使用SQLAlchemy后室。

首先,在命令提示符中輸入pip安裝SQLAlchemy:

pip install sqlalchemy

然后混狠,我們試一下用SQLAlchemy來創(chuàng)建一個user表咧擂。

第一步,導入SQLAlchemy:

from sqlalchemy import Column, String, create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base

第二步檀蹋,創(chuàng)建User對象:


Base = declarative_base()          # 創(chuàng)建對象的基類

class User(Base):
    __tablename__ ='user'                # 表的名字

    id = Column(String(20), primary_key=True)         # 表的結構
    name = Column(String(20))

這里declarative_base()是用來創(chuàng)建對象的基類松申。

第三步,初始化數據庫連接和DBSession:

engine = create_engine('mysql+pymysql://root:jianhui123@localhost:3306/test')
DBSession = sessionmaker(bind=engine)

create_engine()用來初始化數據庫連接俯逾,緊跟的字符串含義為:

'數據庫類型+數據庫驅動名稱://用戶名:密碼@機器地址:端口號/數據庫名'

這里只需要修改用戶名和密碼即可贸桶。

第四步,添加數據:

session = DBSession()                            # 創(chuàng)建session對象:
new_user = User(id='4', name='Mike')             # 創(chuàng)建User對象:
session.add(new_user)                            # 把User對象添加到session中
session.commit()                                 # 提交session
session.close()

可以看到桌肴,我們想要添加數據的話皇筛,只需要創(chuàng)建對應的對象,然后添加到session中坠七,最后把session提交并關閉即可水醋。

至此旗笔,我們成功使用SQLAlchemy創(chuàng)建了一個user表。

如果想要查詢數據的話拄踪,可以通過query查詢蝇恶,具體如下:

session = DBSession()
user = session.query(User).filter(User.id=='4').one()
print(user.name)
session.close()

這里filter()表示條件,one()表示返回唯一行惶桐。

執(zhí)行結果:

Mike

在關系數據庫中撮弧,會有一對多、多對多的關系姚糊,相應的贿衍,ORM框架也可以提供一對多、多對多等功能救恨。

例如贸辈,在User表中,一個user有一個id肠槽、一個name和多個score擎淤,那么可以這樣定義:

class User(Base):
    __tablename__ = 'user'
    id = Column(String(20), primary_key=True)
    name = Column(String(20))

    score = relationship('Score')                    # 創(chuàng)建一對多關系

class Score(Base):
    __tablename__ = 'score'

    id = Column(String(20), primary_key=True)
    math_score = Column(Integer)                       # 數學成績
    english_score = Column(Integer)                    # 英語成績
    chinese_score = Column(Integer)                    # 語文成績
    
    user_id = Column(String(20), ForeignKey('user.id'))      # 通過外鍵user_id連接到User表

當我們查詢一個User對象時,該對象的score屬性就會返回一個包含多個Score對象的list署浩。

ORM框架的作用就是把數據庫表的每一行數據與每一個對象對應起來,互相轉換扫尺。


以上就是本節(jié)的全部內容筋栋,感謝你的閱讀。

下一節(jié)內容:Web開發(fā)

有任何問題與想法正驻,歡迎評論與吐槽弊攘。

和博主一起學習Python吧( ̄▽ ̄)~*

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市姑曙,隨后出現的幾起案子襟交,更是在濱河造成了極大的恐慌,老刑警劉巖佩研,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件础嫡,死亡現場離奇詭異燥撞,居然都是意外死亡,警方通過查閱死者的電腦和手機焕梅,發(fā)現死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來卦洽,“玉大人贞言,你說我怎么就攤上這事》У伲” “怎么了该窗?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵弟蚀,是天一觀的道長。 經常有香客問我酗失,道長义钉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任级零,我火速辦了婚禮断医,結果婚禮上,老公的妹妹穿的比我還像新娘奏纪。我一直安慰自己鉴嗤,他們只是感情好,可當我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布序调。 她就那樣靜靜地躺著醉锅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪发绢。 梳的紋絲不亂的頭發(fā)上硬耍,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天,我揣著相機與錄音边酒,去河邊找鬼经柴。 笑死,一個胖子當著我的面吹牛墩朦,可吹牛的內容都是我干的坯认。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼氓涣,長吁一口氣:“原來是場噩夢啊……” “哼牛哺!你這毒婦竟也來了?” 一聲冷哼從身側響起劳吠,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤引润,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后痒玩,有當地人在樹林里發(fā)現了一具尸體淳附,經...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年蠢古,在試婚紗的時候發(fā)現自己被綠了燃观。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡便瑟,死狀恐怖缆毁,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情到涂,我是刑警寧澤脊框,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布颁督,位于F島的核電站,受9級特大地震影響浇雹,放射性物質發(fā)生泄漏沉御。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一昭灵、第九天 我趴在偏房一處隱蔽的房頂上張望吠裆。 院中可真熱鬧,春花似錦烂完、人聲如沸试疙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽祝旷。三九已至,卻和暖如春嘶窄,著一層夾襖步出監(jiān)牢的瞬間怀跛,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工柄冲, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留吻谋,地道東北人。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓现横,卻偏偏與公主長得像漓拾,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子长赞,可洞房花燭夜當晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內容