Go to file
Salvo 'LtWorf' Tomaselli b538fff8b0 Cleanup generated files
Cleans the generated files in the clean phase, rather than in the
dist one.
2015-09-29 13:55:50 +02:00
debian Updated debian package stuff 2015-09-15 23:38:51 +02:00
feedback-ltworf Prepare for next release 2015-09-15 01:58:17 +02:00
relational Solves mysterious issue 2015-09-14 19:45:09 +02:00
relational_gui Refactored main window creation 2015-09-29 12:47:20 +02:00
relational_readline Removed encoding string 2015-07-14 10:43:13 +02:00
samples - Change from 0.12 to version 1.0 2011-03-04 12:38:00 +00:00
setup Prepare for next release 2015-09-15 01:58:17 +02:00
test Subtle bug that occurred selecting after a join 2015-09-10 12:19:51 +02:00
windows Prepare for next release 2015-09-15 01:58:17 +02:00
.gitignore Use resource file 2015-09-11 13:57:34 +02:00
CHANGELOG Prepare for next release 2015-09-15 01:58:17 +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 Style 2015-07-14 11:01:35 +02:00
Makefile Cleanup generated files 2015-09-29 13:55:50 +02:00
README.md Better readme 2015-09-11 14:20:08 +02:00
relational_gui.py Refactored main window creation 2015-09-29 12:47:20 +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 Installs icon for .desktop file 2015-09-11 14:05:23 +02: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

If it needs some dependencies:

  • Qt5
  • Python 3.4 or greater
  • PyQt5
  • pyuic5 and pyrcc5

You will need to run

make

to generate some .py files.

To launch the application, run

./relational_gui.py

Running on osx

You can probably follow the instructions on running from sources to rut on osx.

If you encounter problems, don't ask me for help.

If you encounter problems and overcome them, please tell me how to update this README.