您好,登錄后才能下訂單哦!
ORM簡(jiǎn)介
ORM概念
對(duì)象關(guān)系映射(Object Relational Mapping,簡(jiǎn)稱(chēng)ORM)模式是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫(kù)存在的互不匹配的現(xiàn)象的技術(shù)。
簡(jiǎn)單的說(shuō),ORM是通過(guò)使用描述對(duì)象和數(shù)據(jù)庫(kù)之間映射的元數(shù)據(jù),將程序中的對(duì)象自動(dòng)持久化到關(guān)系數(shù)據(jù)庫(kù)中。
ORM在業(yè)務(wù)邏輯層和數(shù)據(jù)庫(kù)層之間充當(dāng)了橋梁的作用。
ORM由來(lái)
讓我們從O/R開(kāi)始。字母O起源于"對(duì)象"(Object),而R則來(lái)自于"關(guān)系"(Relational)。
幾乎所有的軟件開(kāi)發(fā)過(guò)程中都會(huì)涉及到對(duì)象和關(guān)系數(shù)據(jù)庫(kù)。在用戶(hù)層面和業(yè)務(wù)邏輯層面,我們是面向?qū)ο蟮?。?dāng)對(duì)象的信息發(fā)生變化的時(shí)候,我們就需要把對(duì)象的信息保存在關(guān)系數(shù)據(jù)庫(kù)中。
按照之前的方式來(lái)進(jìn)行開(kāi)發(fā)就會(huì)出現(xiàn)程序員會(huì)在自己的業(yè)務(wù)邏輯代碼中夾雜很多SQL語(yǔ)句用來(lái)增加、讀取、修改、刪除相關(guān)數(shù)據(jù),而這些代碼通常都是重復(fù)的。
ORM的優(yōu)勢(shì)
ORM解決的主要問(wèn)題是對(duì)象和關(guān)系的映射。它通常把一個(gè)類(lèi)和一個(gè)表一一對(duì)應(yīng),類(lèi)的每個(gè)實(shí)例對(duì)應(yīng)表中的一條記錄,類(lèi)的每個(gè)屬性對(duì)應(yīng)表中的每個(gè)字段。
ORM提供了對(duì)數(shù)據(jù)庫(kù)的映射,不用直接編寫(xiě)SQL代碼,只需像操作對(duì)象一樣從數(shù)據(jù)庫(kù)操作數(shù)據(jù)。
讓軟件開(kāi)發(fā)人員專(zhuān)注于業(yè)務(wù)邏輯的處理,提高了開(kāi)發(fā)效率。
ORM的劣勢(shì)
ORM的缺點(diǎn)是會(huì)在一定程度上犧牲程序的執(zhí)行效率。
ORM用多了SQL語(yǔ)句就不會(huì)寫(xiě)了,關(guān)系數(shù)據(jù)庫(kù)相關(guān)技能退化...
ORM總結(jié)
ORM只是一種工具,工具確實(shí)能解決一些重復(fù),簡(jiǎn)單的勞動(dòng)。這是不可否認(rèn)的。
但我們不能指望某個(gè)工具能一勞永逸地解決所有問(wèn)題,一些特殊問(wèn)題還是需要特殊處理的。
但是在整個(gè)軟件開(kāi)發(fā)過(guò)程中需要特殊處理的情況應(yīng)該都是很少的,否則所謂的工具也就失去了它存在的意義。
Django連接MySQL數(shù)據(jù)庫(kù)
1. 在Django項(xiàng)目的settings.py文件中,配置數(shù)據(jù)庫(kù)連接信息:
DATABASES = { "default": { "ENGINE": "django.db.backends.mysql", "NAME": "你的數(shù)據(jù)庫(kù)名稱(chēng)", # 需要自己手動(dòng)創(chuàng)建數(shù)據(jù)庫(kù) "USER": "數(shù)據(jù)庫(kù)用戶(hù)名", "PASSWORD": "數(shù)據(jù)庫(kù)密碼", "HOST": "數(shù)據(jù)庫(kù)IP", "POST": 3306 } }
2. 在Django項(xiàng)目(注意,項(xiàng)目里的,不是app)的__init__.py文件中寫(xiě)如下代碼,告訴Django使用pymysql模塊連接MySQL數(shù)據(jù)庫(kù):
import pymysql pymysql.install_as_MySQLdb()
3.如需在pycharm里視圖操作:
Django中ORM的(簡(jiǎn)單)增刪改查
增
增加表
下面這個(gè)例子定義了一個(gè) Person 模型,包含 first_name 和 last_name。
from django.db import models class Person(models.Model): first_name = models.CharField(max_length=30) last_name = models.CharField(max_length=30)
然后執(zhí)行下面命令:
python manage.py makemigrations python manage.py migrate
first_name 和 last_name 是模型的字段。每個(gè)字段被指定為一個(gè)類(lèi)屬性,每個(gè)屬性映射到一個(gè)數(shù)據(jù)庫(kù)列。
上面的 Person 模型將會(huì)像這樣創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)表:
CREATE TABLE myapp_person ( "id" serial NOT NULL PRIMARY KEY, "first_name" varchar(30) NOT NULL, "last_name" varchar(30) NOT NULL );
增加數(shù)據(jù)
models.Person.object.create(first_name='fu',last_name='yong')
刪
models.Person.object.get(id=1).delete()
改
obj = models.Person.object.get(id=1) obj.last_name = 'xiaoyong'<br data-filtered="filtered"><br data-filtered="filtered">obj.save()
查
models.Person.object.all() #查找所有記錄,返回一個(gè)queryset對(duì)象 models.Person.object.get(字段=值) #按照字段查找
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。