亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python ORM編程基礎(chǔ)示例

 更新時(shí)間:2020年02月02日 11:53:45   作者:Dawn__Z  
這篇文章主要介紹了Python ORM編程基礎(chǔ),結(jié)合實(shí)例形式分析了Python ORM編程相關(guān)概念、原理以及緩存、數(shù)據(jù)庫(kù)操作相關(guān)使用技巧,需要的朋友可以參考下

本文實(shí)例講述了Python ORM編程。分享給大家供大家參考,具體如下:

ORM編程

ORM(object-relational mapping)對(duì)象關(guān)系映射 作用:在關(guān)系型數(shù)據(jù)庫(kù)和業(yè)務(wù)實(shí)體對(duì)象之間做一個(gè)映射,方便在開(kāi)發(fā)中,不需要再使用復(fù)雜的sql語(yǔ)句,只需要簡(jiǎn)單操作對(duì)象的屬性與方法。 所有ORM具備3方面基本能力:映射技術(shù)、CRUD操作、緩存優(yōu)化。每種編程語(yǔ)言都具有自己的ORM庫(kù),java 的Hibernate、IBATIS;C#的Grove LINQ; Python 的 SQLAlchemy

1、映射技術(shù)

面向?qū)ο笫菑能浖こ痰幕驹瓌t(如耦合、聚合、封裝)的基礎(chǔ)由來(lái) 關(guān)系型數(shù)據(jù)庫(kù)是從數(shù)學(xué)理論上的基礎(chǔ)發(fā)展而來(lái)。

ORM庫(kù)需解決三個(gè)問(wèn)題:

  • 數(shù)據(jù)類型映射:將數(shù)據(jù)庫(kù)的類型映射為編程語(yǔ)言自身的類型;
  • 類映射:將數(shù)據(jù)表定義映射為編程語(yǔ)言自身的類;
  • 關(guān)系映射:將數(shù)據(jù)庫(kù)中基于外鍵的關(guān)系連接轉(zhuǎn)換為編程語(yǔ)言中基于對(duì)象引用的關(guān)系連接。

2、CRUD操作

  • C–Create(增加)
  • R–Retrieve(讀取,重新得到數(shù)據(jù))
  • U–Update(更新)
  • D–Delete(刪除)

在SQL中:insert,select, update,delete四種語(yǔ)句實(shí)現(xiàn)CRUD

ORM自動(dòng)實(shí)現(xiàn)以下操作:

  1. 將這些調(diào)用轉(zhuǎn)換為SQL語(yǔ)句;
  2. 通過(guò)數(shù)據(jù)庫(kù)引擎發(fā)送個(gè)給數(shù)據(jù)庫(kù)執(zhí)行;
  3. 將數(shù)據(jù)庫(kù)返回的結(jié)果記錄用ORM映射技術(shù)轉(zhuǎn)換為類對(duì)象。

3、緩存優(yōu)化

  • 將從數(shù)據(jù)庫(kù)中查詢到的數(shù)據(jù)以類對(duì)象形式保存在本地內(nèi)存中,以便之后再用時(shí)隨時(shí)抽取。
  • 在真正需要讀取查詢結(jié)果時(shí)才執(zhí)行數(shù)據(jù)庫(kù)的select操作,而不是在ORM查詢命令執(zhí)行時(shí)查詢數(shù)據(jù)庫(kù)。

4、用peewee進(jìn)行ORM數(shù)據(jù)庫(kù)編程

思路:

  • 導(dǎo)入需要的包:peewee,建立一個(gè)數(shù)據(jù)庫(kù)引擎對(duì)象db
  • 定義一個(gè)ORM基類:BaseModel(),建立SQLite連接
  • 類型映射:定義一些數(shù)據(jù)類型
  • 表映射:定義兩個(gè)對(duì)象類:course, teacher
  • 關(guān)系映射:使用ForeignKeyField 設(shè)置與course的連接關(guān)系,其中的參數(shù):to_field用于指定被連接的字段名,related_name參數(shù)對(duì)該關(guān)系賦予了一個(gè)名字
import os
if os.path.exists('sampleDB.db'):
  os.remove('sampleDB.db')
# 引入peewee包的所有內(nèi)容
from peewee import *
# 建立一個(gè)Sqlite數(shù)據(jù)庫(kù)引擎對(duì)象,該引擎打開(kāi)數(shù)據(jù)庫(kù)文件sampleDB.db
db = SqliteDatabase("sampleDB.db")
# 定義一個(gè)ORM的基類,在基類中指定本ORM所使用的數(shù)據(jù)庫(kù),
# 這樣在之后所有的子類中就不用重復(fù)聲明數(shù)據(jù)庫(kù)
class BaseModel(Model):
  class Meta:
    database = db
# 定義course表,繼承自BaseModel
class Course(BaseModel):
  id = PrimaryKeyField() # 定義主鍵
  title = CharField(null=False) # 定義字符串
  period = IntegerField() # 整型
  description = CharField()
  class Meta:
    order_by = ('title',)
    db_table = 'course'  # 定義數(shù)據(jù)庫(kù)中的表名
# 定義 teacher 表,繼承自BaseModel
class Teacher(BaseModel):
  id = PrimaryKeyField()
  name = CharField(null=False)
  gender = BooleanField() # 布爾型
  address = CharField()
  # ForeignKeyField 設(shè)置與course的連接關(guān)系,其中的參數(shù):to_field用于指定被連接的字段名,related_name參數(shù)對(duì)該關(guān)系賦予了一個(gè)名字
  course_id = ForeignKeyField(Course, to_field="id", related_name="course")
  class Meta:
    order_by = ('name',)
    db_table = "teacher"
# 建表,僅需創(chuàng)建一次
Course.create_table()
Teacher.create_table()
# 新增行
Course.create(id=1, title='經(jīng)濟(jì)學(xué)', period=320, description='文理科學(xué)生均可選修')
Course.create(id=2, title='大學(xué)英語(yǔ)', period=300, description='大一學(xué)生必修課')
Course.create(id=3, title='哲學(xué)', period=100, description='必修課')
Course.create(id=134, title='編譯原理', period=100, description='計(jì)算機(jī)系選修')
Teacher.create(name='白陣君', gender=True, address='..', course_id=1)
Teacher.create(name='李森', gender=True, address='..', course_id=3)
Teacher.create(name='張?chǎng)?, gender=False, address='..', course_id=2)
# 查詢一行
record = Course.get(Course.title == '大學(xué)英語(yǔ)')
print("課程:%s, 學(xué)時(shí):%d, 課程類型: %s" % (record.title, record.period, record.description))
# 更新
record.period = 200
record.save()
# 刪除
record.delete_instance()
# 查詢所有記錄
courses = Course.select()
for i in courses:
  print(i.id, i.title, i.period, i.description)
# 帶條件查詢,并將結(jié)果按period字段倒序排序
courses = Course.select().where(Course.id< 10).order_by(Course.period.desc())
for i in courses:
  print(i.id, i.title, i.period, i.description)
# 統(tǒng)計(jì)所有課程的平均學(xué)時(shí)
total = Course.select(fn.Avg (Course.period).alias('avg_period'))
for i in total:
  print(u"平均學(xué)時(shí):", i.avg_period)
# 更新多個(gè)記錄
Course.update(period=300).where(Course.id > 100).execute()
# 多表連接操作,Peewee會(huì)自動(dòng)根據(jù)ForeignKeyField的外鍵定義進(jìn)行連接:
Record = Course.select().join(Teacher).where(Teacher.gender == True)
for i in Record:
  print(i.id, i.title, i.period, i.description)

參考來(lái)源:書(shū)籍《python 高效開(kāi)發(fā)實(shí)戰(zhàn)

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》、《Python數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門(mén)與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Python?json模塊常用方法小結(jié)

    Python?json模塊常用方法小結(jié)

    本文主要介紹了Python?json模塊常用方法小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Tensorflow實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)擬合線性回歸

    Tensorflow實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)擬合線性回歸

    這篇文章主要為大家詳細(xì)介紹了Tensorflow實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)擬合線性回歸,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • python創(chuàng)建學(xué)生成績(jī)管理系統(tǒng)

    python創(chuàng)建學(xué)生成績(jī)管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了python創(chuàng)建學(xué)生成績(jī)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • pytorch 如何查看數(shù)據(jù)類型和大小

    pytorch 如何查看數(shù)據(jù)類型和大小

    這篇文章主要介紹了pytorch 實(shí)現(xiàn)查看數(shù)據(jù)類型和大小的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python爬蟲(chóng)代理池搭建的方法步驟

    Python爬蟲(chóng)代理池搭建的方法步驟

    這篇文章主要介紹了Python爬蟲(chóng)代理池搭建的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • opencv讀取視頻并保存圖像的方法

    opencv讀取視頻并保存圖像的方法

    實(shí)習(xí)項(xiàng)目要做安全帽目標(biāo)檢測(cè),拿到了公司給的一些視頻數(shù)據(jù),使用Opencv讀取視頻并每隔1s存儲(chǔ)一副圖像,本文就詳細(xì)的介紹一下使用,感興趣的可以了解一下
    2021-06-06
  • Python selenium模擬網(wǎng)頁(yè)點(diǎn)擊爬蟲(chóng)交管12123違章數(shù)據(jù)

    Python selenium模擬網(wǎng)頁(yè)點(diǎn)擊爬蟲(chóng)交管12123違章數(shù)據(jù)

    本次介紹怎么以模擬點(diǎn)擊方式進(jìn)入交管12123爬取車輛違章數(shù)據(jù),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • python正則表達(dá)式實(shí)現(xiàn)自動(dòng)化編程

    python正則表達(dá)式實(shí)現(xiàn)自動(dòng)化編程

    這篇文章主要介紹了python正則表達(dá)式實(shí)現(xiàn)自動(dòng)化編程,re模塊的compile()方法是構(gòu)成正則表達(dá)式的方法,向compile()傳入一個(gè)字符串表示正則表達(dá)式,該方法返回一個(gè)Regex模式的對(duì)象,需要的朋友可以參考下
    2023-01-01
  • spyder常用快捷鍵(分享)

    spyder常用快捷鍵(分享)

    下面小編就為大家?guī)?lái)一篇spyder常用快捷鍵(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • Python實(shí)現(xiàn)獲取某天是某個(gè)月中的第幾周

    Python實(shí)現(xiàn)獲取某天是某個(gè)月中的第幾周

    這篇文章主要介紹了Python實(shí)現(xiàn)獲取某天是某個(gè)月中的第幾周,本文代碼實(shí)現(xiàn)獲取指定的某天是某個(gè)月中的第幾周、周一作為一周的開(kāi)始,需要的朋友可以參考下
    2015-02-02

最新評(píng)論