Django 外键的使用方法详解

作者:Pengzquan 时间:2022-10-16 14:30:51 

一、描述

在利用django做网络开发的时候我们会遇到一个问题就是,我们建立了多张数据表,但是多张数据表中的内容是不一样的,但是之间有着联系比如:

我有两张表,一张是记录歌曲信息的内容,一张是对歌曲操作的内容(下载次数浏览次数),如果我在views中对下载次数进行一个排序,但是我不能只显示下载次数,我需要歌名的内容,此时我们就需要外键来完成这个工作。

歌曲的操作次数

Django 外键的使用方法详解

歌曲信息

Django 外键的使用方法详解

二、解决

由于在django中都是使用models.py文件来管理数据库,再通过views.py进行连接操作,最后用urls.py来映射到网站

1.models.py:


 dynamic_id = models.AutoField('serial_num', primary_key=True)
  song = models.ForeignKey(Song, on_delete=models.CASCADE, verbose_name='song name')
  dynamic_plays = models.IntegerField('plays_num')
  dynamic_search = models.IntegerField('search_num')
  dynamic_down = models.IntegerField('down_num')

就可以完成外键的设置,第一个参数就是类名,这样就和歌曲信息关联在一起了。

2.views.py


# hot search songs
 search_song = Dynamic.objects.select_related('song').order_by('dynamic_search').all()[:8]
 # sort songs
 label_list = Label.objects.all()
 # hot songs
 play_hot_song = Dynamic.objects.select_related('song').order_by('dynamic_plays').all()[:10]
 # recommend songs
 daily_recommendation = Song.objects.order_by('song_release').all()[:3]
 # hot search and download
 search_ranking = search_song[:6]
 down_ranking = Dynamic.objects.select_related('song').order_by('dynamic_down').all()[:6]
 all_ranking = [search_ranking, down_ranking]
 return render(request, 'index/test.html', locals())

根据上面的信息可以看到在search_song中利用了dynamic_search这个字段来联系我们遇到的信息内容,将dynamic_search和song的信息连在一起外接字段是song,也可以是其他的连接方式。

3.idnex.html:


<img src="{% static 'image/logo.png' %}">
<br/>
{% for play_hot in play_hot_song %}
{{ play_hot.song.song_name }}
<br/>
{% endfor %}

在.html文件中我们使用了在views.py中的对象来引用了song当中的信息,play_hot_song是在views.py中的字段名,进行遍历的是play_hot.song.song_name,play_hot是遍历的参数,song是接口的字段名,song_name是外接对象的内容,这样就可以将信息映射到网站中。

三、结果

Django 外键的使用方法详解

来源:https://www.cnblogs.com/future-dream/p/10484841.html

标签:django,外键,使用,方法
0
投稿

猜你喜欢

  • ajax标签导航实例详解教程

    2008-02-01 10:54:00
  • 详解vue中async-await的使用误区

    2024-05-09 09:21:06
  • JavaScript实现年历效果

    2023-09-10 10:53:26
  • js与jquery获取父元素,删除子元素的两种不同方法

    2023-10-07 04:08:00
  • vue 项目@change多个参数传值多个事件的操作

    2024-06-07 16:01:08
  • MySQL中基本的多表连接查询教程

    2024-01-13 10:44:15
  • Python利用PyAutoGUI轻松搞定图片上传

    2022-11-19 23:15:18
  • Python趣味爬虫之用Python实现智慧校园一键评教

    2022-02-07 17:53:52
  • 详解MySQL数据库优化的八种方式(经典必看)

    2024-01-13 11:32:20
  • 用Frontpage设计网站主页

    2008-10-23 13:44:00
  • C#创建数据库及导入sql脚本的方法

    2024-01-23 04:08:04
  • SQLServer XML查询快速入门(18句话)

    2024-01-26 13:47:07
  • Python利用Turtle绘制Technoblade的示例代码

    2023-08-23 22:43:01
  • Python面向对象之内置函数相关知识总结

    2022-06-05 10:30:24
  • JS实现屏蔽网页右键复制及ctrl+c复制的方法【2种方法】

    2024-04-17 10:07:45
  • Python中常见的异常总结

    2021-11-15 04:21:27
  • Python (Win)readline和tab补全的安装方法

    2021-07-30 16:04:46
  • windows下mysql 5.7版本中修改编码为utf-8的方法步骤

    2024-01-14 14:02:44
  • 浅析Python的命名空间与作用域

    2022-11-27 04:19:04
  • Vue3-KeepAlive,多个页面使用keepalive方式

    2024-05-02 16:33:39
  • asp之家 网络编程 m.aspxhome.com