Django基于ORM操作数据库的方法详解
本文主要和大家介绍了Django基于ORM操作数据库的方法,结合实例形式总结分析了Django使用ORM操作数据库的相关配置、增删改查等相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。
1、配置数据库
vim settings #HelloWorld/HelloWorld目录下
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', #mysql数据库中第一个库test 'NAME': 'test', 'USER': 'root', 'PASSWORD': '123456', 'HOST':'127.0.0.1', 'PORT':'3306', }, 'article': { 'ENGINE': 'django.db.backends.mysql', # mysql数据库中第二个库test2 'NAME': 'test2', 'USER': 'root', 'PASSWORD': '123456', 'HOST':'127.0.0.1', 'PORT':'3306', } }
2、在项目目录中建立“web站点”(app)
django-admin.py startapp blog ##HelloWorld/目录下建立网站app,我建了两个app(blog和article)
3、配置新建的app(blog和article)
vim settings ##/HelloWorld/HelloWorld目录下
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'blog', 'article', ]
4、以blog为例,创建模型
vim models.py ##blog目录下
from django.db import models # Create your models here. class Teacher(models.Model): id = models.IntegerField(primary_key=True) name = models.CharField(max_length=50) class Meta: db_table = 'teacher'#默认库test中建立名为teacher的表。字段就是id和name
5、同步模型到数据库中
python manage.py migrate ##建立Django系统表,首次运行即可
python manage.py makemigrations ##生成迁移计划,每次加表或字段时都运行生成计划
python manage.py migrate ##同步用户定义的表
vim models.py #blog目录下,新建个表测试下,可以在添加或修改删除几个字段试试
class Student(models.Model): id = models.IntegerField(primary_key=True) name = models.CharField(max_length=50) student_number = models.CharField(default="",max_length=50) class Meta: db_table = 'student'
6、多个数据库的使用,上边的blog应用对应数据库中的test库,再搭建个应用article用test2这个库。这样一个项目中的两个应用分别用不同的库。
我上边已经创建好了article应用,并且配置好了settings.py中的DATABASES项中对应数据库为test2。注意article这个名字要一致。
cd article #进入article目录
vim models.py #article目录下
from django.db import models class Author(models.Model): id = models.IntegerField(primary_key=True) name = models.CharField(max_length=50) author_ids = models.CharField(max_length=50) class Meta: db_table = 'author' app_label = 'article' ##对应的article这个应用,名字要一致
python manage.py makemigrations article ##生成同步计划
##对article应用执行同步,同步到 article(settings中的配置,对应test2)对应的数据库中.
python migrate article --database article ##执行计划,必须加--database 指定要同步的库
7、第6步多个应用使用各自的数据库已经配置好了,但是存在一个应用使用多个数据库的情况,此步进行配置。
cd blog #进入blog目录下 vim models.py ##blog目录下,在文件中增加一个表,注意后边app_label
class Group(models.Model): id = models.IntegerField(primary_key=True) group_name = models.CharField(max_length=50) class Meta: db_table = 'group' app_label = 'article' ##必须指定这个库
python manage.py makemigrations article ##生成同步计划,虽说改的是blog python migrate article --database article ##执行计划,虽说改的是blog
8、开始操作数据库测试,以blog为例:
vim view.py ##blog目录下,添加下列代码
from blog.models import Teacher def orm_handle_db(request): test1 = Teacher(id=1,name='runoob',teacher_number='10') ##定义数据 test1.save() ##保存 return render_to_response('orm_handle_db.html')
vim urls.py ##blog目录下
from django.conf.urls import url from blog import views urlpatterns = [ url(r'^hello/$', views.hello), url(r'^search/$', views.search), url(r'^post_search/$', views.post_search), url(r'^search_submit$', views.search_submit), url(r'^post_search_submit$', views.post_search_submit), url(r'^db_handle/$', views.db_handle), url(r'^orm_handle_db/$', views.orm_handle_db), ##这里配置好 ]
vim orm_handle_db.html ##blog/templates目录下
数据库操作
其它操作:增删改查和排序分组操作自己查询即可,下方图像参考
9、操作另一个数据库test2怎么弄呢
vim settings.py ##HelloWorld/HelloWorld目录下,添加下面两项
DATABASES_APPS_MAPPING = { 'blog': 'default', 'article': 'article', } DATABASE_ROUTERS = ['HelloWorld.database_app_router.DatabaseAppsRouter']
vim database_app_router.py ##配置路由 ,HelloWorld/HelloWorld/目录下。直接粘贴
from django.conf import settings class DatabaseAppsRouter(object): def db_for_read(self, model, **hints): app_label = model._meta.app_label if app_label in settings.DATABASES_APPS_MAPPING: res = settings.DATABASES_APPS_MAPPING[app_label] print(res) return res return None def db_for_write(self, model, **hints): app_label = model._meta.app_label if app_label in settings.DATABASES_APPS_MAPPING: return settings.DATABASES_APPS_MAPPING[app_label] return None def allow_relation(self, obj1, obj2, **hints): db_obj1 = settings.DATABASES_APPS_MAPPING.get(obj1._mata.app_label) db_obj2 = settings.DATABASES_APPS_MAPPING.get(obj2._mata.app_label) if db_obj1 and db_obj2: if db_obj1 == db_obj2: return True else: return False return None def db_for_migrate(self, db, app_label, model_name=None, **hints): if db in settings.DATABASES_APPS_MAPPING.values(): return settings.DATABASES_APPS_MAPPING.get(app_label) == db elif app_label in settings.DATABASES_APPS_MAPPING: return False return None
之后再像第8步那样操作数据库即可,会自动路由找到相应的数据库
vim views.py #blog目录下,添加下方代码
from blog.models import Teacher,Group##这是第8步没有的 def orm_handle_db(request): test1 = Teacher(id=1,name='runoob',teacher_number='10') test2 = Group(id=1,group_name='runoob') ##这是第8步没有的 test1.save() test2.save()##这是第8步没有的 return render_to_response('orm_handle_db.html')
10、对于单个库中的表链接操作(1对1、多对1、多对多)。如有需要参看视频。实在是不想用外键的方式
11、夸库的表链接操作django不支持,需要使用绕过orm的方式进行操作。见总结文档
总结:简单操作用ORM,复杂操作用绕过ORM方式。
以上是Django基于ORM操作数据库的方法详解的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

而后悔莫及、人们常常会因为一些原因不小心将某些联系人删除、微信作为一款广泛使用的社交软件。帮助用户解决这一问题,本文将介绍如何通过简单的方法找回被删除的联系人。1.了解微信联系人删除机制这为我们找回被删除的联系人提供了可能性、微信中的联系人删除机制是将其从通讯录中移除,但并未完全删除。2.使用微信内置“通讯录恢复”功能微信提供了“通讯录恢复”节省时间和精力,用户可以通过该功能快速找回之前被删除的联系人,功能。3.进入微信设置页面点击右下角,打开微信应用“我”再点击右上角设置图标、进入设置页面,,

字体大小的设置成为了一项重要的个性化需求,随着手机成为人们日常生活的重要工具。以满足不同用户的需求、本文将介绍如何通过简单的操作,提升手机使用体验,调整手机字体大小。为什么需要调整手机字体大小-调整字体大小可以使文字更清晰易读-适合不同年龄段用户的阅读需求-方便视力不佳的用户使用手机系统自带字体大小设置功能-如何进入系统设置界面-在设置界面中找到并进入"显示"选项-找到"字体大小"选项并进行调整第三方应用调整字体大小-下载并安装支持字体大小调整的应用程序-打开应用程序并进入相关设置界面-根据个人

手机游戏成为了人们生活中不可或缺的一部分,随着科技的发展。它以其可爱的龙蛋形象和有趣的孵化过程吸引了众多玩家的关注,而其中一款备受瞩目的游戏就是手机版龙蛋。帮助玩家们在游戏中更好地培养和成长自己的小龙,本文将向大家介绍手机版龙蛋的孵化方法。1.选择合适的龙蛋种类玩家需要仔细选择自己喜欢并且适合自己的龙蛋种类,根据游戏中提供的不同种类的龙蛋属性和能力。2.提升孵化机的等级玩家需要通过完成任务和收集道具来提升孵化机的等级,孵化机的等级决定了孵化速度和孵化成功率。3.收集孵化所需的资源玩家需要在游戏中

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

手机膜成为了必不可少的配件之一,随着智能手机的普及。延长其使用寿命,选择一款合适的手机膜可以保护手机屏幕。帮助读者选出最适合自己的手机膜、本文将介绍选购手机膜的几大要点与技巧。了解手机膜的材质及类型PET膜,TPU等、手机膜有多种材质,包括钢化玻璃。PET膜较为柔软、钢化玻璃膜具有较好的耐刮花性能,TPU则具有较好的防震性能。可以根据个人偏好及需求来决定,在选择时。考虑屏幕的保护程度不同类型的手机膜对屏幕的保护程度不同。PET膜则主要起到防刮花作用,钢化玻璃膜具有较好的耐摔性能。可以选择具有较好

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

颈部和手背等暴露部位,老年斑是一种常见的皮肤问题,往往出现在年长者的面部。也会让人看起来显老、它不仅给人们的外貌带来困扰。随着科技的进步和美容技术的发展,现在有了许多简单而快速的方法来祛除老年斑,然而。恢复年轻而健康的肌肤、帮助您快速消除老年斑、本文将分享一些有效的养肤秘诀。1.积极保护皮肤免受紫外线伤害的重要性所以避免长时间暴露在阳光下是非常重要的、紫外线是导致老年斑形成的主要原因之一。2.合理选择护肤产品,使用含有抗氧化剂和美白成分的产品护肤产品中含有抗氧化剂和美白成分可以帮助减少老年斑的形
