Is it possible to have selective queries in PostgreSQL which select different tables/columns based on values of rows already selected?
Basically, I’ve got a table in which each row contains a sequence of two to five characters (tbl_roots), optionally with a length field which specifies how many characters the sequence is supposed to contain (it’s meant to be made redundant once I figure out a better way, i.e. by counting the length of the sequences).
There are four tables containing patterns (tbl_patterns_biliteral, tbl_patterns_triliteral, …etc), each of which corresponds to a root_length, and a fifth table (tbl_patterns) which is used to synchronise the pattern tables by providing an identifier for each row—so row #2 in tbl_patterns_biliteral corresponds to the same row in tbl_patterns_triliteral. The six pattern tables are restricted such that no row in tbl_patterns_(bi|tri|quadri|quinqui)literal can have a pattern_id that doesn’t exist in tbl_patterns.
Each pattern table has nine other columns which corresponds to an identifier (root_form).
The last table in the database (tbl_words), contains a column for each of the major tables (word_id, root_id, pattern_id, root_form, word). Each word is defined as being a root of a particular length and form, spliced into a particular pattern. The splicing is relatively simple: translate(pattern, '12345', array_to_string(root, '')) as word_combined does the job.
Now, what I want to do is select the appropriate pattern table based on the length of the sequence in tbl_roots, and select the appropriate column in the pattern table based on the value of root_form.
How could this be done? Can it be combined into a simple query, or will I need to make multiple passes? Once I’ve built up this query, I’ll then be able to code it into a PHP script which can search my database.
EDIT
Here’s some sample data (it’s actually the data I’m using at the moment) and some more explanations as to how the system works: https://gist.github.com/823609
It’s conceptually simpler than it appears at first, especially if you think of it as a coordinate system.
I think you’re going to have to change the structure of your tables to have any hope. Here’s a first draft for you to think about. I’m not sure what the significance of the “i”, “ii”, and “iii” are in your column names. In my ignorance, I’m assuming they’re meaningful to you, so I’ve preserved them in the table below. (I preserved their information as integers. Easy to change that to lowercase roman numerals if it matters.)
I’m pretty sure a structure like this will be much easier to query, but you know your field better than I do. (On the other hand, database design is my field . . . )
Expanding on my earlier answer and our comments, take a look at this query. (The test table isn’t even in 3NF, but the table’s not important right now.)
This is the important part.
That query returns, among other things, the translation
soşim.Are we heading in the right direction?