</permacrud>
</class>
- <class id="xfld" controller="open-ils.cstore open-ils.pcrud" oils_obj:fieldmapper="query::expr_xfld" oils_persist:tablename="query.expr_xfld" reporter:label="Field Expression">
- <fields oils_persist:primary="id" oils_persist:sequence="expression_id_seq">
- <field reporter:label="Expression ID" name="id" reporter:datatype="id"/>
- <field reporter:label="Is Parenthesized" name="parenthesize" reporter:datatype="bool"/>
- <field reporter:label="Parent Expression" name="parent_expr" reporter:datatype="link"/>
- <field reporter:label="Sequence Number" name="seq_no" reporter:datatype="int"/>
- <field reporter:label="Column Name" name="column_name" reporter:datatype="text"/>
- <field reporter:label="Left Operand" name="left_operand" reporter:datatype="link"/>
- <field reporter:label="Negate?" name="negate" reporter:datatype="bool"/>
- </fields>
- <links>
- <link field="parent_expr" reltype="has_a" key="id" map="" class="qxp"/>
- <link field="left_operand" reltype="has_a" key="id" map="" class="qxp"/>
- </links>
- <permacrud xmlns="http://open-ils.org/spec/opensrf/IDL/permacrud/v1">
- </permacrud>
- </class>
-
<class id="xfunc" controller="open-ils.cstore open-ils.pcrud" oils_obj:fieldmapper="query::expr_xfunc" oils_persist:tablename="query.expr_xfunc" reporter:label="Function Expression">
<fields oils_persist:primary="id" oils_persist:sequence="expression_id_seq">
<field reporter:label="Expression ID" name="id" reporter:datatype="id"/>
<field reporter:label="Is Parenthesized" name="parenthesize" reporter:datatype="bool"/>
<field reporter:label="Parent Expression" name="parent_expr" reporter:datatype="link"/>
<field reporter:label="Sequence Number" name="seq_no" reporter:datatype="int"/>
+ <field reporter:label="Column Name" name="column_name" reporter:datatype="text"/>
<field reporter:label="Function ID" name="function_id" reporter:datatype="link"/>
<field reporter:label="Negate?" name="negate" reporter:datatype="bool"/>
</fields>
install_date TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW()
);
-INSERT INTO config.upgrade_log (version) VALUES ('0321'); -- miker
+INSERT INTO config.upgrade_log (version) VALUES ('0322'); -- Scott McKellar
CREATE TABLE config.bib_source (
id SERIAL PRIMARY KEY,
'xcast', -- cast
'xcol', -- column
'xex', -- exists
- 'xfld', -- field
'xfunc', -- function
'xin', -- in
'xisnull', -- is null
DO INSTEAD
DELETE FROM query.expression WHERE id = OLD.id;
--- Create updatable view for field expressions
-
-CREATE OR REPLACE VIEW query.expr_xfld AS
- SELECT
- id,
- parenthesize,
- parent_expr,
- seq_no,
- column_name,
- left_operand,
- negate
- FROM
- query.expression
- WHERE
- type = 'xfld';
-
-CREATE OR REPLACE RULE query_expr_xfld_insert_rule AS
- ON INSERT TO query.expr_xfld
- DO INSTEAD
- INSERT INTO query.expression (
- id,
- type,
- parenthesize,
- parent_expr,
- seq_no,
- column_name,
- left_operand,
- negate
- ) VALUES (
- COALESCE(NEW.id, NEXTVAL('query.expression_id_seq'::REGCLASS)),
- 'xfld',
- COALESCE(NEW.parenthesize, FALSE),
- NEW.parent_expr,
- COALESCE(NEW.seq_no, 1),
- NEW.column_name,
- NEW.left_operand,
- COALESCE(NEW.negate, false)
- );
-
-CREATE OR REPLACE RULE query_expr_xfld_update_rule AS
- ON UPDATE TO query.expr_xfld
- DO INSTEAD
- UPDATE query.expression SET
- id = NEW.id,
- parenthesize = NEW.parenthesize,
- parent_expr = NEW.parent_expr,
- seq_no = NEW.seq_no,
- column_name = NEW.column_name,
- left_operand = NEW.left_operand,
- negate = NEW.negate
- WHERE
- id = OLD.id;
-
-CREATE OR REPLACE RULE query_expr_xfld_delete_rule AS
- ON DELETE TO query.expr_xfld
- DO INSTEAD
- DELETE FROM query.expression WHERE id = OLD.id;
-
-- Create updatable view for function call expressions
CREATE OR REPLACE VIEW query.expr_xfunc AS
parenthesize,
parent_expr,
seq_no,
+ column_name,
function_id,
negate
FROM
parenthesize,
parent_expr,
seq_no,
+ column_name,
function_id,
negate
) VALUES (
COALESCE(NEW.parenthesize, FALSE),
NEW.parent_expr,
COALESCE(NEW.seq_no, 1),
+ NEW.column_name,
NEW.function_id,
COALESCE(NEW.negate, false)
);
parenthesize = NEW.parenthesize,
parent_expr = NEW.parent_expr,
seq_no = NEW.seq_no,
+ column_name = NEW.column_name,
function_id = NEW.function_id,
negate = NEW.negate
WHERE
--- /dev/null
+-- Instead of representing a subfield as a distinct expression type in its
+-- own right, express it as a variant of the xfunc type -- i.e. a function
+-- call with a column name. In consequence:
+
+-- 1. Eliminate the query.expr_xfld view;
+
+-- 2. Expand the query.expr_xfunc view to include column_name;
+
+-- 3. Eliminate 'xfld' as a valid value for expression.type.
+
+-- Theoretically, the latter change could create a problem if you already
+-- have xfld rows in your expression table. You would have to delete them,
+-- and represent the corresponding expressions by other means. In practice
+-- this is exceedingly unlikely, since subfields were never even
+-- supported until earlier today.
+
+-- We start by dropping two views; the first for good, and the second so that
+-- we can replace it. We drop them outside the transaction so that the
+-- script won't fail if the views don't exist yet.
+
+DROP VIEW query.expr_xfld;
+
+DROP VIEW query.expr_xfunc;
+
+BEGIN;
+
+INSERT INTO config.upgrade_log (version) VALUES ('0322'); -- Scott McKellar
+
+-- Eliminate 'xfld' as an expression type
+
+ALTER TABLE query.expression
+ DROP CONSTRAINT expression_type;
+
+ALTER TABLE query.expression
+ ADD CONSTRAINT expression_type CHECK ( type in (
+ 'xbet', -- between
+ 'xbind', -- bind variable
+ 'xbool', -- boolean
+ 'xcase', -- case
+ 'xcast', -- cast
+ 'xcol', -- column
+ 'xex', -- exists
+ 'xfunc', -- function
+ 'xin', -- in
+ 'xisnull', -- is null
+ 'xnull', -- null
+ 'xnum', -- number
+ 'xop', -- operator
+ 'xser', -- series
+ 'xstr', -- string
+ 'xsubq' -- subquery
+ ) );
+
+-- Create updatable view for function call expressions
+
+CREATE OR REPLACE VIEW query.expr_xfunc AS
+ SELECT
+ id,
+ parenthesize,
+ parent_expr,
+ seq_no,
+ column_name,
+ function_id,
+ negate
+ FROM
+ query.expression
+ WHERE
+ type = 'xfunc';
+
+CREATE OR REPLACE RULE query_expr_xfunc_insert_rule AS
+ ON INSERT TO query.expr_xfunc
+ DO INSTEAD
+ INSERT INTO query.expression (
+ id,
+ type,
+ parenthesize,
+ parent_expr,
+ seq_no,
+ column_name,
+ function_id,
+ negate
+ ) VALUES (
+ COALESCE(NEW.id, NEXTVAL('query.expression_id_seq'::REGCLASS)),
+ 'xfunc',
+ COALESCE(NEW.parenthesize, FALSE),
+ NEW.parent_expr,
+ COALESCE(NEW.seq_no, 1),
+ NEW.column_name,
+ NEW.function_id,
+ COALESCE(NEW.negate, false)
+ );
+
+CREATE OR REPLACE RULE query_expr_xfunc_update_rule AS
+ ON UPDATE TO query.expr_xfunc
+ DO INSTEAD
+ UPDATE query.expression SET
+ id = NEW.id,
+ parenthesize = NEW.parenthesize,
+ parent_expr = NEW.parent_expr,
+ seq_no = NEW.seq_no,
+ column_name = NEW.column_name,
+ function_id = NEW.function_id,
+ negate = NEW.negate
+ WHERE
+ id = OLD.id;
+
+CREATE OR REPLACE RULE query_expr_xfunc_delete_rule AS
+ ON DELETE TO query.expr_xfunc
+ DO INSTEAD
+ DELETE FROM query.expression WHERE id = OLD.id;
+
+COMMIT;