16

Let say i have two models:

level:

id
file_number
status


level_process:

process_ptr_id
level_id

I want to combine both of my table above to display it in one API using django-rest-framework.. I'm looking for the example on the internet and i cannot find it...by the way i'm using python 2.7 , django 1.10.5 and djangorestframework 3.6.2

serializer.py

class LevelSerializer(serializers.HyperlinkedModelSerializer):
    id = serializers.ReadOnlyField()
    class Meta:
        model = Level
        fields = ('__all__')

class LevelProcessSerializer(serializers.ModelSerializer):
    level = LevelSerializer(read_only=True)

    class Meta:
        model = LevelProcess
        fields = ('__all__')

views.py

class ViewLevelProcessViewSet(viewsets.ModelViewSet):
    processes = LevelProcess.objects.all()
    serializer_class = LevelProcessSerializer(processes, many=True)
jsanchezs
  • 1,992
  • 3
  • 25
  • 51
MunirohMansoor
  • 355
  • 1
  • 10
  • 19

3 Answers3

22

Try the following. Create serializer for your Level model:

class LevelSerializer(serializers.ModelSerializer):
    class Meta:
        model = Level

Then, inside LevelProcessSerializer, include LevelSerializer like this:

class LevelProcessSerializer(serializers.ModelSerializer):
    level = LevelSerializer(read_only=True)

    class Meta:
        model = LevelProcess

Usage in your ModelViewset:

class ViewLevelProcessViewSet(viewsets.ModelViewSet):
    queryset = LevelProcess.objects.all() 
    serializer_class = LevelProcessSerializer

This way, your json will look something like this:

{
   "id": 1,
   "level": {
      "id": 3,
      "status": "red"
   }
}

Hope this helps!

Jahongir Rahmonov
  • 13,083
  • 10
  • 47
  • 91
0
class LevelSerializer(serializers.ModelSerializer):
    class Meta:
        model = Level
        fields="__all__"

class LevelProcessSerializer(serializers.ModelSerializer):
    level = LevelSerializer(read_only=True)

class Meta:
    model = LevelProcess
    fields= "__all__"
0sVoid
  • 2,547
  • 1
  • 10
  • 25
-3

Don't try to "join" tables. This isn't SQL.

I am assuming your model look like Following,

class Level(models.Model):
    .......

class LevelProcess(models.Model):
    level = models.ForeignKey(Level)

Now, let's walk for query,

l = Level.objects.filter(id=level_id).first()
lp = l.level_process_set.all()

This is how we do in Django ORM.

  • 16
    Doesn't this result in multiple queries for each related LevelProcess? How is that preferable? It is ultimately SQL, you can't just pretend there's not a database engine behind this thing... – JTW Nov 28 '18 at 19:08