4.1 django 操作數(shù)據(jù)庫(原生)

操作數(shù)據(jù)庫

Django配置連接數(shù)據(jù)庫:

在操作數(shù)據(jù)庫之前,首先先要連接數(shù)據(jù)庫宝磨。這里我們以配置MySQL為例來講解。Django連接數(shù)據(jù)庫,不需要單獨(dú)的創(chuàng)建一個(gè)連接對象唤锉。只需要在settings.py文件中做好數(shù)據(jù)庫相關(guān)的配置就可以了世囊。示例代碼如下:

DATABASES = {
    'default': {
        # 數(shù)據(jù)庫引擎(是mysql還是oracle等)
        'ENGINE': 'django.db.backends.mysql',
        # 數(shù)據(jù)庫的名字
        'NAME': 'dfz',
        # 連接mysql數(shù)據(jù)庫的用戶名
        'USER': 'root',
        # 連接mysql數(shù)據(jù)庫的密碼
        'PASSWORD': 'root',
        # mysql數(shù)據(jù)庫的主機(jī)地址
        'HOST': '127.0.0.1',
        # mysql數(shù)據(jù)庫的端口號(hào)
        'PORT': '3306',
    }
}

在Django中操作數(shù)據(jù)庫:

Django中操作數(shù)據(jù)庫有兩種方式。第一種方式就是使用原生sql語句操作窿祥,第二種就是使用ORM模型來操作株憾。這節(jié)課首先來講下第一種。

Django中使用原生sql語句操作其實(shí)就是使用python db api的接口來操作晒衩。如果你的mysql驅(qū)動(dòng)使用的是pymysql嗤瞎,那么你就是使用pymysql來操作的,只不過Django將數(shù)據(jù)庫連接的這一部分封裝好了听系,我們只要在settings.py中配置好了數(shù)據(jù)庫連接信息后直接使用Django封裝好的接口就可以操作了贝奇。示例代碼如下:

# 使用django封裝好的connection對象,會(huì)自動(dòng)讀取settings.py中數(shù)據(jù)庫的配置信息
from django.db import connection

# 獲取游標(biāo)對象
cursor = connection.cursor()
# 拿到游標(biāo)對象后執(zhí)行sql語句
cursor.execute("select * from book")
# 獲取所有的數(shù)據(jù)
rows = cursor.fetchall()
# 遍歷查詢到的數(shù)據(jù)
for row in rows:
    print(row)

以上的execute以及fetchall方法都是Python DB API規(guī)范中定義好的靠胜。任何使用Python來操作MySQL的驅(qū)動(dòng)程序都應(yīng)該遵循這個(gè)規(guī)范掉瞳。所以不管是使用pymysql或者是mysqlclient或者是mysqldb,他們的接口都是一樣的髓帽。更多規(guī)范請參考:https://www.python.org/dev/peps/pep-0249/。

Python DB API下規(guī)范下cursor對象常用接口:

  1. description:如果cursor執(zhí)行了查詢的sql代碼脑豹。那么讀取cursor.description屬性的時(shí)候郑藏,將返回一個(gè)列表,這個(gè)列表中裝的是元組瘩欺,元組中裝的分別是(name,type_code,display_size,internal_size,precision,scale,null_ok)必盖,其中name代表的是查找出來的數(shù)據(jù)的字段名稱,其他參數(shù)暫時(shí)用處不大俱饿。

  2. rowcount:代表的是在執(zhí)行了sql語句后受影響的行數(shù)歌粥。

  3. close:關(guān)閉游標(biāo)。關(guān)閉游標(biāo)以后就再也不能使用了拍埠,否則會(huì)拋出異常失驶。

  4. execute(sql[,parameters]):執(zhí)行某個(gè)sql語句。如果在執(zhí)行sql語句的時(shí)候還需要傳遞參數(shù)枣购,那么可以傳給parameters參數(shù)嬉探。示例代碼如下:

     cursor.execute("select * from article where id=%s",(1,))
    
  5. fetchone:在執(zhí)行了查詢操作以后,獲取第一條數(shù)據(jù)棉圈。

  6. fetchmany(size):在執(zhí)行查詢操作以后涩堤,獲取多條數(shù)據(jù)。具體是多少條要看傳的size參數(shù)分瘾。如果不傳size參數(shù)胎围,那么默認(rèn)是獲取第一條數(shù)據(jù)。

  7. fetchall:獲取所有滿足sql語句的數(shù)據(jù)。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末白魂,一起剝皮案震驚了整個(gè)濱河市汽纤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌碧聪,老刑警劉巖冒版,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異逞姿,居然都是意外死亡辞嗡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門滞造,熙熙樓的掌柜王于貴愁眉苦臉地迎上來续室,“玉大人,你說我怎么就攤上這事谒养⊥φ” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵买窟,是天一觀的道長丰泊。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任颖对,我火速辦了婚禮裹粤,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布盏浇。 她就那樣靜靜地躺著,像睡著了一般芽狗。 火紅的嫁衣襯著肌膚如雪绢掰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天童擎,我揣著相機(jī)與錄音曼月,去河邊找鬼。 笑死柔昼,一個(gè)胖子當(dāng)著我的面吹牛哑芹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播捕透,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼聪姿,長吁一口氣:“原來是場噩夢啊……” “哼碴萧!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起末购,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤破喻,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后盟榴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體曹质,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年擎场,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了羽德。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡迅办,死狀恐怖宅静,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情站欺,我是刑警寧澤姨夹,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站矾策,受9級(jí)特大地震影響磷账,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜贾虽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一逃糟、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧榄鉴,春花似錦履磨、人聲如沸蛉抓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽巷送。三九已至驶忌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間笑跛,已是汗流浹背付魔。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留飞蹂,地道東北人几苍。 一個(gè)月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像陈哑,于是被迫代替她去往敵國和親妻坝。 傳聞我的和親對象是個(gè)殘疾皇子伸眶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344

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

  • Django 準(zhǔn)備 “虛擬環(huán)境為什么需要虛擬環(huán)境:到目前位置,我們所有的第三方包安裝都是直接通過 pip inst...
    33jubi閱讀 1,317評論 0 5
  • 數(shù)據(jù)庫編程概述刽宪、pymysql基本操作方法總結(jié)厘贼、參數(shù)化列表防止SQL注入總結(jié) 2.6 Python數(shù)據(jù)庫編程 學(xué)習(xí)...
    Cestine閱讀 1,497評論 0 2
  • 一、Python簡介和環(huán)境搭建以及pip的安裝 4課時(shí)實(shí)驗(yàn)課主要內(nèi)容 【Python簡介】: Python 是一個(gè)...
    _小老虎_閱讀 5,723評論 0 10
  • Django配置連接數(shù)據(jù)庫: 在操作數(shù)據(jù)庫之前圣拄,首先先要連接數(shù)據(jù)庫嘴秸。這里我們以配置MySQL為例來講解。Djang...
    小短腿電工閱讀 2,440評論 0 2
  • 文/雙 攜一捧金色的陽光于手掌之中 透過指間的細(xì)縫 暉斜地灑向地面 默念一段暖心的文字 嗅著它獨(dú)特的芳香 沉醉其間...
    雙zs閱讀 830評論 13 14