利用SQLAlchemy訪問數(shù)據(jù)庫(kù)

SQLAlchemy是Python編程語言下的一款開源軟件,提供了SQL工具包及對(duì)象關(guān)系映射(ORM)工具亏吝。

值得特別注意的是ORM,全稱object-relational mapping,即對(duì)象關(guān)系映射捕儒。再簡(jiǎn)單點(diǎn)來講,ORM就是將python的類映射到數(shù)據(jù)庫(kù)中的表邓夕,一個(gè)類對(duì)應(yīng)一個(gè)表刘莹。

第一步,(如有提示焚刚,需要更新下pip点弯,使用命令行sudo pip install --upgrade pip),安裝SQLAlchemy

sudo pip install sqlalchemy

出現(xiàn)以下信息即表示安裝成功矿咕,最新版本1.2.5抢肛。

Collecting sqlalchemy
Installing collected packages: sqlalchemy
Successfully installed sqlalchemy-1.2.5

接著啟動(dòng)MySQL 服務(wù)狼钮,輸入mysql -u root -p,回車捡絮,再輸入密碼熬芜,回車,以下信息說明MySQL已經(jīng)正常啟動(dòng)了福稳。

mysql

創(chuàng)建一個(gè)數(shù)據(jù)庫(kù):

CREATE DATABASE 數(shù)據(jù)庫(kù)名稱

創(chuàng)建一個(gè)類涎拉,取名叫User吧

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

# 定義User對(duì)象
class User(Base):
    # 表的名字
    __tablename__ = 'school'
    # 表的結(jié)構(gòu)
    id = Column(Integer, primary_key=True)
    school_name = Column(String(20), nullable=False)

往表中添加記錄

def populate(engine):   
    Base.metadata.bind = engine
    
    # 創(chuàng)建DBSession類型,即數(shù)據(jù)庫(kù)會(huì)話類
    DBSession = sessionmaker(bind=engine)
    
    # 創(chuàng)建session對(duì)象的圆,有了session鼓拧,就可以用它去執(zhí)行SQL了
    session = DBSession()
    user_info = User(school_name='清華')

    # 添加到session
    session.add(user_info)
    session.commit()

連接數(shù)據(jù)庫(kù),并開始執(zhí)行

# create_engine()用來初始化數(shù)據(jù)庫(kù)連接越妈。
# SQLAlchemy用一個(gè)字符串表示連接信息:'數(shù)據(jù)庫(kù)類型+數(shù)據(jù)庫(kù)驅(qū)動(dòng)名稱://用戶名:口令@機(jī)器地址:端口號(hào)/數(shù)據(jù)庫(kù)名'

engine =  create_engine('mysql+mysqlconnector://root:password@localhost:3306/dbname')

#找到Base下的所有子類季俩,并在數(shù)據(jù)庫(kù)中建立這些表
Base.metadata.create_all(engine)

populate(engine)
Base.metadata.bind = engine

DBSession = sessionmaker()
DBSession.bind = engine
session = DBSession()

# 獲取User對(duì)象中的第一條數(shù)據(jù)
user = session.query(User).first()

哦,別忘了安裝MySQL驅(qū)動(dòng)梅掠,不然會(huì)報(bào)錯(cuò):ImportError: No module named mysql酌住,在這里用的是mysqlconnector驅(qū)動(dòng),所以:

sudo pip install mysql-connector

目前阎抒,有兩個(gè)MySQL驅(qū)動(dòng):

  • mysql-connector-python:是MySQL官方的純Python驅(qū)動(dòng)赂韵;

  • MySQL-python:是封裝了MySQL C驅(qū)動(dòng)的Python驅(qū)動(dòng)。

這里有兩篇不錯(cuò)的介紹SQLAlchemy的博客
SQLAlchemy 教程 —— 基礎(chǔ)入門篇
SQLAlchemy使用經(jīng)驗(yàn)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末挠蛉,一起剝皮案震驚了整個(gè)濱河市祭示,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌谴古,老刑警劉巖质涛,帶你破解...
    沈念sama閱讀 221,576評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異掰担,居然都是意外死亡汇陆,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門带饱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來毡代,“玉大人,你說我怎么就攤上這事勺疼〗碳牛” “怎么了?”我有些...
    開封第一講書人閱讀 168,017評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵执庐,是天一觀的道長(zhǎng)酪耕。 經(jīng)常有香客問我,道長(zhǎng)轨淌,這世上最難降的妖魔是什么迂烁? 我笑而不...
    開封第一講書人閱讀 59,626評(píng)論 1 296
  • 正文 為了忘掉前任看尼,我火速辦了婚禮,結(jié)果婚禮上盟步,老公的妹妹穿的比我還像新娘藏斩。我一直安慰自己,他們只是感情好却盘,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,625評(píng)論 6 397
  • 文/花漫 我一把揭開白布狰域。 她就那樣靜靜地躺著,像睡著了一般谷炸。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上禀挫,一...
    開封第一講書人閱讀 52,255評(píng)論 1 308
  • 那天旬陡,我揣著相機(jī)與錄音,去河邊找鬼语婴。 笑死描孟,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的砰左。 我是一名探鬼主播匿醒,決...
    沈念sama閱讀 40,825評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼缠导!你這毒婦竟也來了廉羔?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,729評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤僻造,失蹤者是張志新(化名)和其女友劉穎憋他,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體髓削,經(jīng)...
    沈念sama閱讀 46,271評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡竹挡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,363評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了立膛。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片揪罕。...
    茶點(diǎn)故事閱讀 40,498評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖宝泵,靈堂內(nèi)的尸體忽然破棺而出好啰,到底是詐尸還是另有隱情,我是刑警寧澤儿奶,帶...
    沈念sama閱讀 36,183評(píng)論 5 350
  • 正文 年R本政府宣布坎怪,位于F島的核電站,受9級(jí)特大地震影響廓握,放射性物質(zhì)發(fā)生泄漏搅窿。R本人自食惡果不足惜嘁酿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,867評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望男应。 院中可真熱鬧闹司,春花似錦、人聲如沸沐飘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)耐朴。三九已至借卧,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間筛峭,已是汗流浹背铐刘。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留影晓,地道東北人镰吵。 一個(gè)月前我還...
    沈念sama閱讀 48,906評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像挂签,于是被迫代替她去往敵國(guó)和親疤祭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,507評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • 轉(zhuǎn)載饵婆,覺得這篇寫 SQLAlchemy Core勺馆,寫得非常不錯(cuò)。不過后續(xù)他沒寫SQLAlchemy ORM... ...
    非夢(mèng)nj閱讀 5,420評(píng)論 1 14
  • URL與視圖 URL與函數(shù)的映射: 從之前的helloworld.py文件中侨核,我們已經(jīng)看到谓传,一個(gè)URL要與執(zhí)行函數(shù)...
    編程小蟬閱讀 2,777評(píng)論 1 19
  • # Python 資源大全中文版 我想很多程序員應(yīng)該記得 GitHub 上有一個(gè) Awesome - XXX 系列...
    aimaile閱讀 26,502評(píng)論 6 427
  • 《親愛的》 親愛的 你對(duì)我笑 我就會(huì)禿頂或白發(fā) 你對(duì)我哭 我就要成一奔騰白馬 你脫掉外套 我是一人形木炭 你坐在夜...
    楊見閱讀 851評(píng)論 1 3
  • 斷舍離 我是一個(gè)新晉媽媽,看到最多的就是如何帶養(yǎng)孩子的文章芹关。都是教導(dǎo)媽媽們?nèi)绾紊俦Ш⒆有嘁鼓獭⒆约核某摹⒆约和鎯海?..
    妖嬈而生閱讀 321評(píng)論 0 0