Go to file
Salvo 'LtWorf' Tomaselli 4dba82aaaa
Localise readline
2020-10-22 08:16:54 +02:00
.github codeql 2020-08-13 14:34:00 +02:00
debian Bump version 2020-09-20 21:50:27 +02:00
feedback-ltworf Return 3.0 from the online thingy 2020-08-12 21:25:55 +02:00
po Some italian strings 2020-10-22 08:16:54 +02:00
relational Localize strings 2020-10-22 08:16:54 +02:00
relational_gui Translate with gettext, not Qt 2020-10-22 08:09:54 +02:00
relational_readline Localise readline 2020-10-22 08:16:54 +02:00
samples - Change from 0.12 to version 1.0 2011-03-04 12:38:00 +00:00
setup Bump version 2020-09-20 21:50:27 +02:00
tests_dir Python test for multiline 2020-08-26 17:15:24 +02:00
windows Bump version 2020-09-20 21:50:27 +02:00
.gitignore .gitignore 2020-08-12 19:36:26 +02:00
.travis.yml Depend on typedload 2020-08-24 18:02:39 +02:00
CHANGELOG CHANGELOG 2020-10-22 08:16:54 +02:00
complexity s/outher join/outer join/ 2016-01-03 09:05:15 +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 Colorize failed test output 2020-08-26 21:17:05 +02:00
Makefile Scan more source files 2020-10-22 08:16:54 +02:00
README.md README.md 2020-08-24 14:38:45 +02:00
relational-cli.1 Refreshed manpages 2015-11-06 16:13:36 +01:00
relational.1 Refreshed manpages 2015-11-06 16:13:36 +01:00
relational.desktop Fixes to the .desktop file 2016-04-27 19:48:00 +02:00
relational.py Add some localization 2020-10-22 08:16:54 +02:00
requirements.txt Add requirements file 2020-09-21 22:39:03 +02:00
SECURITY.md Better specify 2020-08-12 19:36:25 +02:00

Relational

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

screenshot

I test it on GNU/Linux and Windows. It probably works on other systems too.

It provides:

  • A GUI that can be used for executing relational queries
  • A standalone Python module that can be used for executing relational queries, parsing relational expressions and optimizing them
  • A command line interface

Official website

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

Install

Run from sources

For the dependencies, check debian/control for the build dependencies.

You will need to run

make

to generate some .py files.

To launch the application, run

./relational.py

Syntax

These are some valid queries (using the provided example dataset)

# Join people and skills
people ⋈ skills

# Select people within a certain age range
σ age > 25 and age < 50 (people)

# Selection with complicated expression requires an extra set of () around the expression
σ (name.upper().startswith('J') and age > 21) (people)

# Cartesian product of people with itself, including only name and id
ρ id➡i, name➡n (people) * π name, id (people)

For the selection, python expressions are used.

The syntax is explained here: https://ltworf.github.io/relational/allowed_expressions.html