Django基于ORM操作数据库的方法详解


Posted in Python onMarch 27, 2018

本文实例讲述了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)

Django基于ORM操作数据库的方法详解

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为例:

参看网址:http://www.runoob.com/django/django-model.html

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目录下

数据库操作

其它操作:增删改查和排序分组操作自己查询即可,下方图像参考

 Django基于ORM操作数据库的方法详解

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框架的Python程序设计有所帮助。

Python 相关文章推荐
Python中的True,False条件判断实例分析
Jan 12 Python
在Python中使用HTML模版的教程
Apr 29 Python
Python实现TCP/IP协议下的端口转发及重定向示例
Jun 14 Python
python出现"IndentationError: unexpected indent"错误解决办法
Oct 15 Python
python使用xlrd和xlwt读写Excel文件的实例代码
Sep 05 Python
python实现字符串加密成纯数字
Mar 19 Python
windows下python虚拟环境virtualenv安装和使用详解
Jul 16 Python
Python处理mysql特殊字符的问题
Mar 02 Python
Python如何实现邮件功能
May 27 Python
Python基于Socket实现简易多人聊天室的示例代码
Nov 29 Python
Python爬虫+tkinter界面实现历史天气查询的思路详解
Feb 22 Python
python 下载文件的几种方式分享
Apr 07 Python
利用Python批量提取Win10锁屏壁纸实战教程
Mar 27 #Python
Django学习笔记之ORM基础教程
Mar 27 #Python
Python使用xlwt模块操作Excel的方法详解
Mar 27 #Python
Python安装图文教程 Pycharm安装教程
Mar 27 #Python
python 接口返回的json字符串实例
Mar 27 #Python
使用Django和Python创建Json response的方法
Mar 26 #Python
python查询mysql,返回json的实例
Mar 26 #Python
You might like
Thinkphp实现自动验证和自动完成
2015/12/19 PHP
PHP生成腾讯云COS接口需要的请求签名
2018/05/20 PHP
在IE下:float属性会影响offsetTop的取值
2006/12/22 Javascript
JS版网站风格切换实例代码
2008/10/06 Javascript
JQery jstree 大数据量问题解决方法
2010/03/09 Javascript
Jquery对象和Dom对象的区别分析
2014/11/20 Javascript
原生js结合html5制作小飞龙的简易跳球
2015/03/30 Javascript
jquery代码实现多选、不同分享功能
2015/07/31 Javascript
jquery实现图片列表鼠标移入微动
2016/12/01 Javascript
深入解析js轮播插件核心代码的实现过程
2017/04/14 Javascript
vue上传图片组件编写代码
2017/07/26 Javascript
浅谈JS中的常用选择器及属性、方法的调用
2017/07/28 Javascript
vue.js仿hover效果的实现方法示例
2019/01/28 Javascript
深入剖析JavaScript instanceof 运算符
2019/06/14 Javascript
[02:51]2014DOTA2 TI小组赛总结中国军团全部进军钥匙球馆
2014/07/15 DOTA
Python实现抓取网页并且解析的实例
2014/09/20 Python
详解python发送各类邮件的主要方法
2016/12/22 Python
python中实现精确的浮点数运算详解
2017/11/02 Python
python logging重复记录日志问题的解决方法
2018/07/12 Python
详解python使用turtle库来画一朵花
2019/03/21 Python
pytorch 获取层权重,对特定层注入hook, 提取中间层输出的方法
2019/08/17 Python
python实现的爬取电影下载链接功能示例
2019/08/26 Python
python getpass模块用法及实例详解
2019/10/07 Python
Python模块的制作方法实例分析
2019/12/21 Python
记一次django内存异常排查及解决方法
2020/08/07 Python
Wiggle中国:英国骑行、跑步、游泳 & 铁三运动装备专卖网店
2016/08/02 全球购物
HUGO BOSS美国官方网上商店:世界知名奢侈品牌
2017/08/04 全球购物
经济职业学院毕业生自荐书
2014/03/17 职场文书
《忆江南》教学反思
2014/04/07 职场文书
食品工程专业求职信
2014/06/15 职场文书
专业见习报告范文
2014/11/03 职场文书
2015年妇幼保健工作总结
2015/05/19 职场文书
毕业生登记表班级意见
2015/06/05 职场文书
二年级数学教学反思
2016/02/16 职场文书
《我和小伙伴》教学反思
2016/02/20 职场文书
Mysql数据库表中为什么有索引却没有提高查询速度
2022/02/24 MySQL