Re: Django model design best practice guidance

2022-12-08 Thread Joshua Corlin

Thanks Mike, i think the lack of understanding of the underlying 
implementation is what was tripping me up.  Data tracked by this "field" 
actually being a different table at the DB level makes complete sense. I 
have added the M2M field to my ticket model and now have this working at 
the DB level.  

For anyone who stumbles on this in the future, lets take my sudo-models 
below, if i add a field subscribers to ticket, as a M2M field to User, I 
can now add 1 or more User objects to said "field" which is actually a 
table, in this example appname_ticket_subscribers which i can add/remove 
users to with ticket.subscribers.[add/remove].(userObject).  

example models
User:
username = charfield
other things

Ticket:
requester = fk to user
owner = fk to user
*subscribers = models.ManyToManyField(User) <-- the new field*
other things

and in the DB 
db=# select * from app_ticket_subscribers;
 id | ticket_id | user_id 
+---+-
  1 | 01  |   1
(1 row)


The relevant KB for anyone trying to implement a similar thing:
https://docs.djangoproject.com/en/4.1/topics/db/examples/many_to_many/
On Thursday, December 8, 2022 at 5:02:05 PM UTC-7 Mike Dewhirst wrote:

> On 9/12/2022 3:04 am, Joshua Corlin wrote:
>
> Ive not used this field before so if it is im having a hard time wrapping 
> my head around how this would work in this use case.  
>
>
> Many-to-many is simple to conceptualise if you realise it is not a field 
> in the table you think it is.
>
> It is actually a separate table containing two foreign key fields. One 
> points to a particular record in your target table and the other points to 
> a particular target record in either the same table or a different table.
>
> Django makes this easy by defining a many-to-many field in the model 
> definition but it actually uses that definition to create the separate 
> relationship table (the "through" table) with two foreign keys.
>
> The nice thing is the "through" model can also be included explicitly 
> among other model definitions. Doing so lets you add other fields to it 
> which can describe the relationship. 
>
> It is definitely worthwhile studying the docs to get this right because it 
> lets you model the real world much more accurately. 
>
> There are migration gotchas when you explicitly define models which have 
> already been created implicitly with Django's many-to-many field but there 
> are documented solutions.
>
> Cheers
>
> Mike
>
> -- 
> Signed email is an absolute defence against phishing. This email has
> been signed with my private key. If you import my public key you can
> automatically decrypt my signature and be sure it came from me. Just
> ask and I'll send it to you. Your email software can handle signing.
>
>

-- 
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to django-users+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/django-users/ca893628-f140-4810-8f08-ce12daaa9a9dn%40googlegroups.com.


Re: Django model design best practice guidance

2022-12-08 Thread Mike Dewhirst

On 9/12/2022 3:04 am, Joshua Corlin wrote:
Ive not used this field before so if it is im having a hard time 
wrapping my head around how this would work in this use case.


Many-to-many is simple to conceptualise if you realise it is not a field 
in the table you think it is.


It is actually a separate table containing two foreign key fields. One 
points to a particular record in your target table and the other points 
to a particular target record in either the same table or a different table.


Django makes this easy by defining a many-to-many field in the model 
definition but it actually uses that definition to create the separate 
relationship table (the "through" table) with two foreign keys.


The nice thing is the "through" model can also be included explicitly 
among other model definitions. Doing so lets you add other fields to it 
which can describe the relationship.


It is definitely worthwhile studying the docs to get this right because 
it lets you model the real world much more accurately.


There are migration gotchas when you explicitly define models which have 
already been created implicitly with Django's many-to-many field but 
there are documented solutions.


Cheers

Mike

--
Signed email is an absolute defence against phishing. This email has
been signed with my private key. If you import my public key you can
automatically decrypt my signature and be sure it came from me. Just
ask and I'll send it to you. Your email software can handle signing.

--
You received this message because you are subscribed to the Google Groups "Django 
users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to django-users+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/django-users/4ea3a261-b8cc-ff61-5e95-1fd31041b4ab%40dewhirst.com.au.


OpenPGP_signature
Description: OpenPGP digital signature


Django model design best practice guidance

2022-12-08 Thread Joshua Corlin
Hello Django Community,  

I am working on implementing a feature in a project that I built and I am 
looking for some guidance on how implement the database side of this 
feature most efficiently.

The models in question: 
The two models in question are the user model and a model that tracks 
tickets raised by users.   A ticket has a requester, self explanatory, and 
an owner, the owner being the person who winds up getting assigned and 
working the ticket to action the underlying request.   Both of these 
columns on tickets are foreign keys to user.  

example models
User:
id = auto pk
username = charfield
other things

Ticket:
id = auto pk
requester = fk to user
owner = fk to user
other things

The problem Im now trying to solve: 
We have a desire to be able to allow other users outside the 
requestor/owner to get notified in the event of a ticket being updated by 
either the owner or the requestor, effectively a list of subscribers.  What 
would be the best practice for implementing a column to track 1 or more 
subscribers from a user model to some other model using a single column in 
a project like this?
  
My initial brainstorming: 
I am sending notifications using logic that just requires username so I 
know I could just store a list of users in a charfield but ive got to 
imagine theres a more elegant way of doing this.  Is this a use case for a 
manytomany field?  Ive not used this field before so if it is im having a 
hard time wrapping my head around how this would work in this use case.  

Any guidance from the community on this would be greatly appreciated!

-- 
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to django-users+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/django-users/b50c92eb-59b7-46fc-a32a-7c5c0f0b2c01n%40googlegroups.com.