- Documentation
- Reference manual
- Packages
- Constraint Query Language A high level interface to SQL databases
- library(cql/cql): CQL - Constraint Query Language
- Examples
- Simple INSERT
- Simple INSERT with retrieval of identity of the inserted
- Simple DELETE
- Simple SELECT
- Simple UPDATE
- WHERE with arithmetic comparison
- Simple INNER JOIN
- Arithmetic UPDATE with an INNER JOIN and a WHERE restriction
- Confirm row does not exist
- Aggregation - Count
- Aggregation - Sum
- Aggregation - Average
- Maximum Value
- Minimum Value
- Aggregation requiring GROUP BY
- INNER JOIN with an aggregation sub-query where the sub-query is constrained by a shared variable from the main query
- INNER JOIN in an aggregation sub-query
- Negation
- EXISTS
- Left Outer Join
- List-based Restrictions
- Compile time in-list constraint
- Disjunction resulting in OR in WHERE clause
- Disjunction resulting in different joins (implemented as a SQL UNION)
- Disjunction resulting in different SELECT attributes (implemented as separate ODBC queries)
- ORDER BY
- DISTINCT
- SELECT with NOT NULL restriction
- First N
- Self JOIN
- Removing null comparisions
- Three table JOIN
- Three table JOIN with NOLOCK locking hint
- SELECT with LIKE
- Writing exceptions directly to the database
- TOP N is Parametric
- Using compile_time_goal/1
- ON
- Expressions In Where Restrictions
- Explicitly avoid the "No WHERE restriction" message
- HAVING
- INSERT and UPDATE value in-line formatting
- Negations in WHERE Clauses
- Predicate-generated Attribute Values
- INSERT from SELECT
- Examples
- library(cql/cql): CQL - Constraint Query Language
- Constraint Query Language A high level interface to SQL databases
1.7.44 Predicate-generated Attribute Values
It is possible to generate compile time attribute values by specifying a predicate which is executed when the CQL statement is compiled.
The predicate must return the value you want as its last argument. You specify the predicate where you would normally put the attribute value. The predicate is specified with its output argument missing.
Example - Using domain allowed values in a query.
In the following CQL statement the predicate cql_domain_allowed_value/3 is called within findall/3 at compile time to generate a list of domain values that restrict favourite_colour to be 'ORANGE' or 'PINK' or 'BLUE', or 'GREEN'.
colour('ORANGE'). colour('PINK'). colour('BLUE'). colour('GREEN'). {[], se_lt_x :: [d-findall(Value, permissible_colour(Value)), a-UserName]}
Note how findall/3 is actually called by specifying findall/2.
There is not much point using predicate-generated attribute values in compile-at-runtime CQL as you can always call the predicate to generate the required values outside the CQL statement.