NAME

DB::Object::Query - Query Object

SYNOPSIS

my $q = DB::Object::Query->new;

VERSION

v0.5.2

DESCRIPTION

This is the base class for this DB::Object query formatter.

METHODS

alias

Sets or gets an hash of column name to alias.

as_string

Returns the formatted query as a string.

avoid

Takes a list or array reference of column to avoid in the next query. This returns a Module::Generic::Array object.

binded

Takes a list or array reference of values to bind in the next query in "execute" in DB::Object::Statement. This returns a Module::Generic::Array object.

binded_group

This returns the values to bind for the group clause of the query. This returns a Module::Generic::Array object.

binded_limit

This returns the values to bind for the limit clause of the query. This returns a Module::Generic::Array object.

binded_order

This returns the values to bind for the order clause of the query. This returns a Module::Generic::Array object.

binded_types

Takes a list or array reference of value types to bind in the next query in "execute" in DB::Object::Statement. This returns a Module::Generic::Array object.

binded_types_as_param

This does nothing and must be implemented by the driver package. So, see "binded_types_as_param" in DB::Object::Mysql::Query, "binded_types_as_param" in DB::Object::Postgres::Query, and "binded_types_as_param" in DB::Object::SQLite::Query

binded_values

Takes a list or array reference of values to bind in the next query in "execute" in DB::Object::Statement. This returns a Module::Generic::Array object.

binded_where

This returns the values to bind for the where clause of the query. This returns a Module::Generic::Array object.

constant

If any argument is provided, this expects an hash reference of constants to value pairs.

It returns the currently set constants as a hash reference.

database_object

Returns the current database object, which should be driver specific like DB::Object::Postgres

delete

Takes some optional arguments used to define the where clause, and this will prepare a DELETE query.

It will refuse to prepare the query if no where clause has been defined, as this would be a very unsafe query. You would need to execute such query yourself using "do" in DB::Object.

If this method is called in void, this will execute the query.

It returns the newly created statement handler as a DB::Object::Statement

enhance

Enable or disable enhancement mode.

final

Enables to know the query reached the end, so that when constant is used, all the processing can be skipped.

from_table

The table used, if any, in a FROM clause.

format_statement

Provided with an hash or hash reference of parameters and this will format the sql statement for queries of types select, delete and insert

In list context, it returns 2 strings: one comma-separated list of fields and one comma-separated list of values. In scalar context, it only returns a comma-separated string of fields.

Accepted parameters are:

data
order

If not provided, this will use the default column order for this table.

table

The table name to use, or, if not specified, this will be set to a value set with "qualified_name" in DB::Object::Tables

If any values were set by "from_unixtime" or "unix_timestamp", the associated columns will be formatted accordingly in the sql statement.

It will go through each of the parameter passed to the original insert, delete, or select query and if a column is one set earlier by "from_unixtime" or "unix_timestamp", it will format it.

If a parameter provided is a DB::Object::Statement it will stringify the query and add it surrounded by parenthesis.

If a parameter is actually a scalar reference, this means to us to use the underlying string as is.

If a parameter is ?, this will be treated as a placeholder.

If a parameter is a blob, it will be transformed into a parameter as a placeholder with its value saved to be bound in "execute" in DB::Object::Statement

If "bind" in DB::Object is not enabled, then the value provided with this parameter will be added after being possibly surrounded by quotes using "quote" in DB::Object::Tables.

If the column type for this parameter is ENUM and the query is of type INSERT or UPDATE, then the parameter value is surrounded with single quote.

If "bind" in DB::Object is enabled, then a placeholder ? will be added and the parameter value will be saed to be passed during "execute" in DB::Object::Statement

If nothing else matches it will add the value, possible quoted, using "quote" in DB::Object::Tables, whose implementation can be driver specific.

If column prefix is required, then the necessary prefix will be prepended to columns.

In list context, this returns the formatted columns and their values, and in scalar context it will returns only the formatted columns.

format_update

Provided with a list of parameters either as a key-value pairs, as an hash reference or even as an array reference and this will format update query based on the following arguments provided:

data

An array of key-value pairs to be used in the update query. This array can be provided as the prime argument as a reference to an array, an array, or as the data element of a hash or a reference to a hash provided.

Why an array if eventually we build a list of key-value pair? Because the order of the fields may be important, and if the key-value pair list is provided, format_update honors the order in which the fields are provided.

If no data is provided, this will return an error.

"format_update" will then iterate through each field-value pair, and perform some work:

If the field being reviewed was provided to "from_unixtime", then "format_update" will enclose it in the function suitable for the driver to convert it into a database datetime. For example, for Mysql, this would be:

  FROM_UNIXTIME(field_name)

If the the given value is a reference to a scalar, it will be used as-is, ie. it will not be enclosed in quotes or anything. This is useful if you want to control which function to use around that field.

If the value is ? it will be used as a placeholder and the value will be saved to be bound later in "execute" in DB::Object::Statement. Its associated type will be added as blank, so it can be guessed later. However, if the column data type is bytea, the the PostgreSQL data type DBD::Pg::PG_BYTEA will be used when binding the value.

If the column type is jsonb, and the value is an hash reference, it will be json encoded and used instead.

If the given value is another field or looks like a function having parenthesis, or if the value is a question mark, the value will be used as-is.

If "bind" in DB::Object is off, the value will be escaped and the pair field='value' created.

If the field is a SET data type and the value is a number, the value will be used as-is without surrounding single quote.

If "bind" in DB::Object is enabled, a question mark will be used as the value and the original value will be saved as value to bind upon executing the query.

Finally, otherwise the value is escaped and surrounded by single quotes.

"format_update" returns a regular string representing the comma-separated list of columns with their value assigment that will be used.

from_unixtime

Takes a list or array reference of columns that needs to be treated as unix timestamp and will be converted into a database timestamp.

It returns that list as a Module::Generic::Array

format_from_epoch

This is the driver specific implementation to convert unix timestamp to the database timestamp.

This is superseded in driver specific implementation, so see "format_from_epoch" in DB::Object::Mysql::Query, "format_from_epoch" in DB::Object::Postgres::Query and "format_from_epoch" in DB::Object::SQLite:::Query

format_to_epoch

This is the driver specific implementation to convert the database timestamp to unix timestamp.

This is superseded in driver specific implementation, so see "format_from_epoch" in DB::Object::Mysql::Query, "format_from_epoch" in DB::Object::Postgres::Query and "format_from_epoch" in DB::Object::SQLite:::Query

getdefault

Provided with an hash or hash reference of parameters and this will do some preparation work.

Possible parameters are:

arg

An array reference of data which should be a key-value pairs.

as

An hash reference of column to alias pairs. Alternatively, if this is not provided, the value set with "alias" will be used.

avoid

An array reference of column to avoid using. Alternatively, if this is not provided, the value set with "avoid" will be used.

from_unixtime

An array reference of columns to be converted from unix timestamp to the database timestamp.

query_type

The type of query, such as delete, insert, replace, select, update

table

The table name.

time

A unix timestamp. Alternatively, unixtime can be used.

unix_timestamp

An array reference of columns to be converted into unix timestamp.

Does some preparation work such as :

  1. the date/time field to use the FROM_UNIXTIME and UNIX_TIMESTAMP functions

  2. removing from the query the fields to avoid, ie the ones set with the avoid method.

  3. set the fields alias based on the information provided with the alias method.

  4. if a field last_name and first_name exist, it will also create an alias name based on the concatenation of the 2.

  5. it will set the default values provided. This is used for UPDATE queries.

It sets the following properties of the current object:

bind

A boolean value whether the use of placeholder is enabled.

query_type

The type of query, such as select, insert, etc...

_args

The arguments provided as an array reference.

_default

The default value as an hash reference.

_extra

Extra parameters as an array reference.

_fields

The columns as an hash reference.

_from_unix

An hash reference

_structure

The table structure which is an hash reference of column name to definition pairs.

_to_unix

An hash reference

It returns a new DB::Object::Tables object with all the data prepared within.

group

Format the group by portion of the query by calling "_group_order"

It returns a new DB::Object::Query::Clause object.

having

This must be superseded by driver specific implementation of this class. Check out "having" in DB::Object::Mysql::Query, "having" in DB::Object::Postgres::Query, "having" in DB::Object::SQLite::Query

insert

$tbl->insert( col1 => $val1, col2 => $val 2 );
# or
$other_tbl->where( user => 'joe' );
my $sth = $other_tbl->select;
$tbl->insert( $sth );
# will become INSERT INTO some_table SELECT col1, col2 FROM other_table WHERE user = 'joe'

Provided with an array reference or an hash reference or a statement object (DB::Object::Statement) or a list of parameters and this will prepares an insert query using the field-value pairs provided.

If a DB::Object::Statement object is provided as first argument, it will be considered as a SELECT query to be used in the INSERT query, as in: INSERT INTO my table SELECT FROM another_table

Otherwise, "insert" will build the query based on the fields provided.

In void context, it will execute the query by calling of "execute" in DB::Object::Statement.

It returns the statement object.

is_upsert

Sets or gets the boolean value if the query is an upsert, which means a insert or update query that uses an ON CONFLICT clause. See "on_conflict" in DB::Object::Postgres::Query

join_fields

Sets or gets the join fields. This is a regular string.

join_tables

Sets or gets the table joined. This returns a Module::Generic::Array

left_join

Sets or gets an hash reference of column joint column pairs

limit

Set or get the limit for the future statement, by calling "_process_limit"

It returns a DB::Object::Query::Clause representing the limit clause.

local

Provided with a variable name and value pairs and this will set them.

It returns the formated declaration as a string.

new_clause

This returns a new DB::Object::Query::Clause object.

order

Provided with a list of parameter and this will format the order clause by calling "_group_order"

It returns a new DB::Object::Query::Clause object.

prepare_options

Sets or gets the options that will be used in "_cache_this" in DB::Object, which is taked with preparing statement when they are not already cached.

This method basically handles an hash reference of properties set by DB::Object::Query and their inheriting packages. Currently only PostgreSQL makes use of this with "dollar_placeholder" in DB::Object::Postgres::Query and "server_prepare" in DB::Object::Postgres::Query

query

Sets or gets the query string. It returns whatever is set as a regular string.

query_reset

Reset the query object to its nominal value so it can be re-used.

query_reset_core_keys

Returns an Module::Generic::Array object of core object properties shared with inheriting package.

Those are used to know what properties to reset.

query_reset_keys

Returns an Module::Generic::Array object of object properties shared with inheriting package.

This contains driver specific properties and together with the ones provided with "query_reset_core_keys", they form a whole.

query_type

Sets or gets the query type, such as delete, insert, select, update, etc.

query_values

Sets or gets the query values.

replace

This is unsupported by default and its implementation is driver specific.

reset

Reset the query object.

What it does is remove the following object properties: alias local binded binded_group binded_limit binded_order binded_types binded_values binded_where where limit group_by order_by reverse from_unixtime unix_timestamp sorted

reset_bind

Reset the bind values by setting the following object property to an empty anonymous array: binded binded_group binded_limit binded_order binded_types binded_where

returning

This is unsupported by default and its implementation is driver specific.

reverse

Mark the query to use reverse order. This is used by "order".

select

Provided with a list or an array reference of columns, and this will format the select statement.

If the parameters provided is actually a scalar reference, it will be used as is.

If the parameters provided is an array or array reference, it will be joined using comma to get the list of columns to get, or, if the array is empty, the special * will be used to get all the columns.

Otherwise, it will use the data parameter provided as is.

If any alias have been set using "alias", they will be added to the list of columns to get.

if a table alias was set using "table_alias" it will be set here.

If the method was called in void context, it will execute immediately the statement object prepared.

It returns the statement object (DB::Object::Statement).

selected_fields

Sets or gets the string representing the list of columns used in previous select statement.

sort

Set the query to use normal sorting order.

sorted

Sets or gets the list of sorted columns used in statements. This returns a Module::Generic::Array object.

table_alias

Sets an optional alias for this table to be used in statement.

table_object

Sets or gets the table object. This will return a DB::Object::Tables object

tie

If provided a hash or a hash ref, it sets the list of fields and their corresponding perl variable to bind their values to.

In list context, it returns the list of those field-variable pair, or a reference to it in scalar context.

unix_timestamp

Provided a list or an array reference of columns, and this sets the columns to be treated for seamless conversion from and to unix time.

It returns a Module::Generic::Array object.

update

Provided with a list, an array reference, or an hash or hash reference of key-value pairs and this will format the update statement.

If no parameter is provided, this will return an error.

This will call "format_update" to format the parameter provided and use the resulting string in the update statement.

If any clauses have been defined such as where, limit, etc, they will be properly formatted and added to the statement.

The resulting formatted query will be saved as the object property "query".

The formatted update columns and values will be saved in the current object property "query_values"

If "update" is called in void context, this will execute the query immediately.

It returns the statement object (DB::Object::Statement).

where

Build the where clause based on the field-value hash provided by calling "_where_having".

It returns a clause object (DB::Object::Query::Clause).

_group_order

This support method is called by "group" and "order" to format those clauses.

Provided with an object, or a list or an array reference of parameters and this will format the relevant clause.

it will go through each parameter and if the parameter provided is an DB::Object::Fields::Field object, it will collect its various attribute.

If the parameter is a scalar reference, it will be used as is.

If the parameter looks like it contains some field, it will be prepended by an appropriate prefix of table and possible database and schema name, if necessary.

Otherwise, it will use whatever value was provided as a column and use it.

It returns a DB::Object::Query::Clause object.

_having

This is called by "where" and "having"

Provided with some data as a list or an array reference and this will format the where or having clause.

Walking through each parameter provided, if a parameter is a scalar reference, it will be used as is.

If the parameter looks like it contains some field, it will be prepended by an appropriate prefix of table and possible database and schema name, if necessary.

If "bind" in DB::Object is enabled, it will save the value used and use a placeholder.

It returns a DB::Object::Query::Clause object.

_initiate_clause_object

This instantiate a new DB::Object::Query::Clause object passing it whatever parameters were provided.

_limit

Sets or gets the limit clause object and returns a DB::Object::Query::Clause object.

_process_limit

Provided with some parameters and this will format the limit clause of the query.

If one parameter was provided, then this will only define the ending limit. The start will be set as "undef" in perlfunc

If two parameters are provided, then this will set the start offset and the limit.

It check each of the start offset and end limit thus set, and if it is a scalar reference, it will be used as is. However, if the parameter is a ? it will be used as a placeholder.

Otherwise, if "bind" in DB::Object is enabled, this will save the parameter value as a binded value to be passed to "execute" in DN::Object::Statement

It returns the limit clause object (DB::Object::Query::Clause)

_query_components

This returns an array reference of formatted clause, in their proper order to be added to query.

This method is called by "delete", "insert", "replace", "select" and "update"

This method is overriden by driver packages, so check "_query_components" in DB::Object::Mysql::Query, "_query_components" in DB::Object::Postgres::Query and "_query_components" in DB::Object::SQLite::Query

_query_type

Based on the latest formatted query and the object property "query", this will return the type of query this is. This can be possibly one of the following: alter, create, drop, grant, listen, notify, insert, update, delete, select, truncate

_save_bind

Provided with a query type and this will collect binded values from various clauses.

It returns the current object.

_value2bind

If "use_bind" in DB::Object is enabled, and this will modify the query passed to replace value with placeholders.

Actually this method is not used anymore and really qui dangerous because parsing sql is quite challenging.

_where_having

This is used to format WHERE and HAVING clause.

Provided with a query type and clause property name such as having or where and other parameters and this will format the where or having clause and return a new DB::Object::Query::Clause object.

It checks each parameter passed.

if the first parameter is a DB::Object::Operator object, it will take it embedded values by calling "value" in DB::Object::Query::Clause. However, if there are any unknown fields, they will be ignored.

If the parameter is a scalar reference, it will use it as is.

If the parameter is a DB::Object::Operator object like DB::Object::AND, DB::Object::OR or DB::Object::NOT, it will recursively process its embedded elements.

If the parameter is a DB::Object::Query::Clause object, it will be added to the stack of elements.

If the parameter is a DB::Object::Expression object, it will be added to the stack of elements.

If the parameter is a DB::Object::Fields::Field::Overloaded object, it will be added as a new DB::Object::Query::Clause to the stack.

If the parameter is a litteral represented as a string or a scalar reference, then it will be added to the list as-is. For example:

$tbl->where(
    $tbl->fo->status eq 'active',
    "LENGTH(?) > 12"
);

or

$tbl->where(
    $tbl->fo->status eq 'active',
    \"LENGTH(?) > 12"
);

However, make sure to put this expression at the end.

It then checks parameters two by two, the first one being the column and the second being its value.

If the value is the operator object DB::Object::NOT, it adds to the stack a new clause object of type column IS NOT something, such as column IS NOT NULL

if the value is undefined or that the value is equal to NULL, then it adds to the stack a new clause object DB::Object::Query::Clause of type column IS NULL

If the value is a scalar reference, it will be added as is in a new clause object that is added to the stack.

If the value is a DB::Object::Statement, "fetchrow" in DB::Object::Statement will be called and the value fetched will be added as a new clause object to the stack.

If the value is a perl Regexp object, then it will be formatted in a way suitable to the driver and added to a new clause object and onto the stack.

If the value looks like some table field embedded inside some SQL function, then it will be added to a new clause object and onto the stack.

See Postgres documentation for more information

See MySQL documentation for more information

See SQLite documentation for more information

If the column is of type bytea, then a new clause object will be added to the stack with the column value being quoted properly using "quote" in DB::Object

All the clause objects in the stack will be merged into one new clause object using "merge" in DB::Object::Query::Clause

The resulting final clause object (DB::Object::Query::Clause) is returned.

AUTOLOAD

When the AUTOLOAD is called, it will check if the value of the method used corresponds to an existing database table, and if it does, it returns the value returned by calling "table" with the table name.

SEE ALSO

DBI

AUTHOR

Jacques Deguest <jack@deguest.jp>

COPYRIGHT & LICENSE

Copyright (c) 2018-2021 DEGUEST Pte. Ltd.

You can use, copy, modify and redistribute this package and associated files under the same terms as Perl itself.