From: Jean Louis <bugs@gnu.support>
To: Andrew Hyatt <ahyatt@gmail.com>
Cc: emacs-devel@gnu.org
Subject: Re: [ELPA] New package: triples
Date: Thu, 27 Oct 2022 22:15:38 +0300 [thread overview]
Message-ID: <Y1rY2vswFXyfwVzc@protected.localdomain> (raw)
In-Reply-To: <m2a65hsv15.fsf@andrews-mbp.lan>
* Andrew Hyatt <ahyatt@gmail.com> [2022-10-27 08:20]:
> > In this case any table, column, with its primary key may be related to
> > any other table, column with its primary key. That way objects and
> > subjects are constrained and rigid, it is not universal triplets, but
> > database tables dependent one. It relates only what exists in the
> > database. If there is `people' database then such may be related to
> > arbitrary other tables like `statistics'.
>
> Thanks for mentioning this, it's an interesting design I'll read up
> on!
Recently I am thinking of using UUID. Any table, column, by primary
key (by it UUID or just INTEGER or else), may still have UUID. Let us
say transaction entry:
ID 3
Date created "2022-02-27 18:57:23.52117"
Date modified nil
User created "maddox"
User modified "maddox"
Date/Time "2022-02-27 00:00:00"
Name "Mobile money fee"
Description "nil"
Amount 2310.0
Currency "UGX - Ugandan shilling"
From account "Jean Louis"
To account "Mobile money expenses"
UUID "3c171d3d-b2c8-4527-8984-34bbacc82ff2"
Hyperdocument nil
Then by using UUID as subject, predicate, and UUID as object, it
becomes clear what is what. A function must search UUID among those
tables who have it. It is really fast, not noticable. But I can't know
how well it could scale with millions or billions of records. For
presentation purposes it would be fine, but for direct access, I
can't be sure of speed.
> > select * from predicates; predicates_id | predicates_name |
> > predicates_description
> > ---------------+-----------------+-----------------------------------
> > 1 | is | When subject is object. 2 | knows
> > | When subject knows object. 3 | registered | When
> > subject registered an object
> >
> > by adding "has" predicate, one can tell:
> >
> > person has age person has name employee has id id is integer employeee
> > has manager employee is person manager is person
>
> We have "has" but not "is". The schema has types, those types have
> properties. So we can have a subject, "Joe Employee", who has a type
> person, and a type employee, and a type manager, the properties of those
> respective types. But we don't know or enforce that
> every employee is also a person. It's perhaps a feature that can be
> added later if needed; it seems possible in the current
> implementation.
Principle of semantic triplets is just subject, predicate and
object. I guess you allow users to add any kind of predicates, right?
Types are automatically formed by using subject, predicate, object
principle.
Reference: https://en.wikipedia.org/wiki/Semantic_triple
This should be enough by using that principle:
- job is activity
- job has status
- employee is status
- Joe is name
- person has name
- Joe has employee (meaning status)
Also see this:
OneModel — an Alternative to emacs org-mode:
https://soylentnews.org/article.pl?sid=16/04/23/0149257
OneModel - Record, manage and share any knowledge:
http://onemodel.org/1/e-9223372036854618119.html
--
Jean
Take action in Free Software Foundation campaigns:
https://www.fsf.org/campaigns
In support of Richard M. Stallman
https://stallmansupport.org/
next prev parent reply other threads:[~2022-10-27 19:15 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-10-26 0:54 [ELPA] New package: triples Andrew Hyatt
2022-10-26 2:52 ` Stefan Monnier
2022-10-26 5:52 ` Stefan Kangas
2022-10-26 13:23 ` Andrew Hyatt
2022-10-26 13:29 ` Stefan Monnier
2022-10-27 5:15 ` Andrew Hyatt
2022-10-27 15:34 ` Stefan Monnier
2022-11-03 2:32 ` Andrew Hyatt
2022-10-27 3:36 ` Jean Louis
2022-10-27 5:19 ` Andrew Hyatt
2022-10-27 19:15 ` Jean Louis [this message]
2022-10-27 23:33 ` Jean Louis
2022-11-03 2:37 ` Andrew Hyatt
2022-11-03 16:57 ` Jean Louis
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Y1rY2vswFXyfwVzc@protected.localdomain \
--to=bugs@gnu.support \
--cc=ahyatt@gmail.com \
--cc=emacs-devel@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.