We use a Tree for the navigation bar (not a true DAG, but there are
circular checks):
https://pycon.coderanger.net/browser/django/trunk/pycon/navbar/models.py

There is a validator IsNotCircular, which does the obvious.

There is code to do serialization (currently just a pickle), but there
are plans to add json to communicate to the client.
The (poor) documentation on using the navbar is here:
https://pycon.coderanger.net/wiki/PyCon08/NavBar

I have other examples of true DAG's in DB form, but they are very
domain specific and take advantage of the
limitations in the data. (like the divided room problem where a
conference room might have 3 parts which can
make a total of 6 'rooms', but have special meaning for room
scheduling). But the NavBar is closest to what
you are trying to do.


On Sep 17, 4:08 pm, "paul.dorman" <[EMAIL PROTECTED]> wrote:
> Thanks for your response Julio,
>
> something similar yes. What I'm after is an Django implementation of
> an directed acyclic graph. I understand there's some complexity
> involved to ensure no cycles can be created (which I understand is the
> graph equivalent of an endless loop). There's plenty of good examples
> of DAG out there, but I'm not sure how to implement one that works
> with RDMS (or Django for that matter!)
>
> Paul
>
> On Sep 17, 4:56 pm, Julio César Carrascal Urquijo
>
> <[EMAIL PROTECTED]> wrote:
> > I'm a newbie on Django my self but maybe this is what you are looking
> > for:
>
> > class Category(models.Model):
> >         code = models.CharField(maxlength=200, unique=True)
> >         products = models.ManyToManyField('Product')
>
> > class Product(models.Model):
> >         parent = models.ForeignKey('Post')
> >         code = models.CharField(maxlength=200, unique=True)
>
> > I've also read that you can specify signals for most operations on a
> > model (Like when a model is inserted, updated or deleted from the
> > database) though I can't find the URL right now. There's some mention
> > of it here:
>
> >http://www.djangoproject.com/documentation/db-api/
>
> > On Sep 16, 9:54 pm, "Paul Dorman" <[EMAIL PROTECTED]> wrote:
>
> > > Hi all,
>
> > > definite newbie here. I'd like to implement a category type system in
> > > Django. I've looked in the cookbook and Googled a bit, but to no avail. 
> > > What
> > > I'm after should be pretty simple: a directed graph for categories, where
> > > objects and perhaps categories can be a member of one or more categories.
> > > For example, a 'server' is an 'infrastructure component' (for the 
> > > techies),
> > > as well as an 'asset' (for the financial types). In my grand scheme when 
> > > an
> > > object is associated with one or more categories (one is the minimum), the
> > > application will  execute method calls stored (with optional parameters) 
> > > in
> > > the database (serialized as JSON or XML). With the 'server' example, it
> > > might be that being in the 'infrastructure component' category triggers an
> > > email to be sent to the system administrator, and the existence in the
> > > 'asset' category would trigger an automated update to the asset register.
> > > The methods are stored according to the standard CRUD set of operations, 
> > > so
> > > that a user can create a new category in the view, and then specify 
> > > actions
> > > which occur when an object is created, read, updated, or deleted (provided
> > > by the application itself). Actions are triggered for both objects (the
> > > things that are categorized) and for child categories (so for example it 
> > > may
> > > be that a parent category can be locked in such a way as to prevent any 
> > > more
> > > child categories from being added).
>
> > > Note that categories are purely containers with generic actions (for crud
> > > operations on objects in the category) and distinct from objects, which I
> > > imagine would have a category_id FK. And note also that my objects are all
> > > using the same model, with the bulk of data serialized as XML.
>
> > > Has anyone out there in Djangoland done something like this? The graph's 
> > > the
> > > thing - I'm happy to deal with the CRUD triggers myself. If there's a 
> > > model
> > > out there that would be a good starting point that would be great.
>
> > > One additional thing I'm wondering about is how Django can work with 
> > > stored
> > > procedures. For example, it might be more efficient if the application can
> > > ask the database for the methods to run  when an object is created,  and
> > > have the database return the methods for not only the object's 
> > > bottom-level
> > > category, but for all parent categories as well.
>
> > > P.S.
>
> > > Congratulations on the great sprint!
>
> > > P.P.S. I hope I haven't just embarrassed myself with my naïveté.
>
> > > --
> > > "Science fiction writers are the only ones who care about the future"
> > > --  Kurt Vonnegut


--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to