NAME
DB::Object::Query::Clause - SQL Query Clause Object
SYNOPSIS
my $clause = DB::Object::Query::Clause->new({
value => "$field != '$user'",
generic => "$field != ?",
type => 'where',
# or possibly:
# bind =>
# {
# values => $values_array_ref,
# types => $types_array_ref
# }
})
# A DB::Object::Query object
$clause->query_object( $q );
$clause->bind->values( $res );
$clause->bind->types( '' );
$clause->fields( $field ) if( Scalar::Util::blessed( $field ) && $field->isa( 'DB::Object::Fields::Field' ) );
Merging multiple clauses
$clause = DB::Object::Query::Clause->new->merge( $dbh->AND( @clauses ) );
$clause->bind->values( @values ) if( $bind );
$clause->bind->types( @types ) if( $bind );
Get the clause stringified
my $sql = "SELECT * FROM my_table WHERE $clause";
This could become something like:
SELECT * FROM my_table WHERE username != 'joe' AND username != 'bob'
However if binding values is activated, this would rather become:
SELECT * FROM my_table WHERE username != ? AND username != ?
And the associated values would be automatically bound to the query upon execution
VERSION
v0.1.0
DESCRIPTION
The purpose of this module is to contain various attributes of a SQL clause so that it can be accessed and manipulated flexibly.
It will not create SQL query. This is done by the calling module and the query is stored in the value parameter which is also the "value" method
This is used to contain clauses such as group, having, limit, order, where
METHODS
new
It can take the following properties that can also be accessed as method:
- value
-
The sql query fragment string
- generic
-
The sql fragment with placeholders, for example:
username = ?
- bind
-
Provided a hash with the following properties:
- values
-
The values to bind as an array reference
- types
-
The SQL types of the values to bind as an array reference
as_string
This returns the clause as a string.
This is also called when the object is used as a string
print( "SQL query is: SELECT * FROM my_table WHERE $clause\n")
If field objects were used such as:
$dbh->NOT( $user_tbl->fo->username => 'Bob' );
Then if needed, as_string would prefix the field name with its associated table name
fields
An array reference of field objects (DB::Object::Fields::Field)
The array itself is an object from Module::Generic::Array
generic
Returns a string representing the sql fragment with placeholder.
The string returned is an object of Module::Generic::Scalar
length
Returns the length of the string in "value"
metadata
Set or get an hash reference accessible as a dynamic class object from DB::Object::Query::Clause::Metadata
merge
Given an array of clauses, this will merge them into one new clause object.
If the first value of the array is a DB::Object::Operator such as DB::Object::Operator::AND or DB::Object::Operator::OR, the list will be taken from this object and the resulting sql statement will the operator value, ie AND
or OR
for example
query_object
Set or get the DB::Object::Query object, which normally would have created this clause object.
type
Set or get the type of clause this is, such as group, having, limit, order, where
The return value is a string that can be accessed as an object of Module::Generic::Scalar
value
The SQL fragment as a string. The return value is a string that can be accessed as an object of Module::Generic::Scalar
SEE ALSO
DB::Object::Query, DB::Object::Mysql::Query, DB::Object::Postgres::Query, DB::Object::SQLite::Query
AUTHOR
Jacques Deguest <jack@deguest.jp>
COPYRIGHT & LICENSE
Copyright (c) 2019-2021 DEGUEST Pte. Ltd.
You can use, copy, modify and redistribute this package and associated files under the same terms as Perl itself.