Go to file
Salvo 'LtWorf' Tomaselli 01dc9391d1 Adds len() to relation
Returns the cardinality
2015-06-05 18:28:44 +02:00
debian Debian build updated 2015-06-01 11:50:29 +02:00
feedback-ltworf More changing to 2.0 2015-06-01 09:33:47 +02:00
relational Adds len() to relation 2015-06-05 18:28:44 +02:00
relational_curses Changed about and README to not point to galileo anymore 2013-12-27 00:31:43 +01:00
relational_gui Able to load non .csv files from UI 2015-06-04 22:38:25 +02:00
relational_readline No need to use encode 2015-06-01 13:05:39 +02:00
samples - Change from 0.12 to version 1.0 2011-03-04 12:38:00 +00:00
setup Modified python setup for python3 2015-06-01 10:30:01 +02:00
test Change relational language to use math symbols 2015-05-31 19:01:03 +02:00
windows Don't install Dejavu fonts 2015-06-04 22:35:00 +02:00
.gitignore gitignore 2013-02-10 14:25:30 +01:00
CHANGELOG New changelog entries 2015-06-02 15:40:11 +02:00
complexity Get rid of the last remains of galileo 2013-12-27 00:47:48 +01:00
COPYING renamed equijoin to thetajoin 2008-07-17 22:53:32 +00:00
CREDITS - termcolor modified to use bold by default 2011-04-01 10:28:47 +00:00
driver.py Switch core module to Python3 2015-02-19 12:42:41 +01:00
Makefile Switch GUI generation to Qt5 2015-02-19 13:59:41 +01:00
README.md Updated README's examples 2015-05-31 19:12:10 +02:00
relational_gui.py Set font for windows 2015-06-04 22:30:39 +02:00
relational-cli.1 Updated manpages 2015-06-01 12:54:52 +02:00
relational.1 Updated manpages 2015-06-01 12:54:52 +02:00
relational.desktop Make lintian happy 2013-12-27 01:02:04 +01:00
TODO - Using more the colored class 2011-05-02 10:02:06 +00:00

Relational an educational tool to provide a workspace for experimenting with relational algebra, an offshoot of first-order logic.

It provides GUI that can be used for executing relational queries, and also provides a command line interface.

Provides a standalone Python module that can be used for executing relational queries, parsing relational expressions and optimizing them.

Official website

More documentation can be found here http://ltworf.github.io/relational/

Install

Binary download for Windows can be obtained from the website.

For Linux, check your distribution's packages, relational is available on Debian and Ubuntu.

Syntax

These are some valid queries

σage > 25 and rank == weight(A)
σ (name.upper().startswith('J') and age>21 )(people)
Q ⋈ π a,b(A) ⋈ B
ρid➡i,name➡n(A) - π a,b(π a,b(A)) ∩ σage > 25 or rank = weight(A)
π a,b(π a,b(A))
ρid➡i,name➡n(π a,b(A))
A ⋈ B

Run from sources

To launch the application, run

./relational_gui.py

If it needs some dependencies: Qt5, Python 3.4 or greater, PyQt5

It can run on osx but bugreports about that will be rejected.