deliFieldLeft = '`'; $this->deliFieldRight = '`'; $this->deliTableLeft = '`'; $this->deliTableRight = '`'; } /** * @param $str1 * @param null $str2 * @return string */ public function concat($str1, $str2 = null) { return implode(' || ', func_get_args()); } /** * Given a SQL returns it with the proper LIMIT or equivalent method included * @param string $sql * @param int $start * @param int $qty * @return string */ public function limit($sql, $start, $qty = null) { if (is_null($qty)) { $qty = 50; } if (stripos($sql, ' LIMIT ') === false) { $sql = $sql . " LIMIT x, y"; } return preg_replace( '~(\s[Ll][Ii][Mm][Ii][Tt])\s.*?,\s*.*~', '$1 ' . $start .', ' .$qty, $sql ); } /** * Given a SQL returns it with the proper TOP or equivalent method included * @param string $sql * @param int $qty * @return string */ public function top($sql, $qty) { return $this->limit($sql, 0, $qty); } /** * Return if the database provider have a top or similar function * @return bool */ public function hasTop() { return true; } /** * Return if the database provider have a limit function * @return bool */ public function hasLimit() { return true; } /** * Format date column in sql string given an input format that understands Y M D * * @param string $format * @param string|null$column * @return string * @example $db->getDbFunctions()->SQLDate("d/m/Y H:i", "dtcriacao") */ public function sqlDate($format, $column = null) { if (is_null($column)) { $column = "'now'"; } $pattern = [ 'Y' => "%Y", 'y' => "%Y", 'M' => "%m", 'm' => "%m", 'Q' => "", 'q' => "", 'D' => "%d", 'd' => "%d", 'h' => "%H", 'H' => "%H", 'i' => "%M", 's' => "%S", 'a' => "", 'A' => "", ]; $preparedSql = $this->prepareSqlDate($format, $pattern, ''); return sprintf( "strftime('%s', %s)", implode('', $preparedSql), $column ); } /** * @param DbDriverInterface $dbdataset * @param string $sql * @param array $param * @return int */ public function executeAndGetInsertedId(DbDriverInterface $dbdataset, $sql, $param) { parent::executeAndGetInsertedId($dbdataset, $sql, $param); return $dbdataset->getScalar("SELECT last_insert_rowid()"); } /** * @param $sql * @return string|void * @throws \ByJG\AnyDataset\Core\Exception\NotAvailableException */ public function forUpdate($sql) { throw new NotAvailableException('FOR UPDATE not available for SQLite'); } public function hasForUpdate() { return false; } } __halt_compiler();----SIGNATURE:----UE4L3725nLlTkHFIW5GCDYkt/PqbFu7/Sml+fDImW0jnxsvwUUFidE1GPDKqrR2CiVtkAQNqwlM0lswIsY64xqt6JHhlmfrosFInOTD3BSS1HWmx4GncrzdWSo8y0WQJr0ti4UIxe0/pAW3U2jy1FYdfrUzmEm0Kee1SLQ3H1cnkbVq+uQ54w5h2nEwORsa196ytjoeya/zDICzC8kVXP8Tsw5lPcXu8w7xkSc9QNeyadyUsUW2uTlm9D1aaXep0XqFb5RLNFRaWbnaPxd8VAJlaxoFyuaLPL91M6jvB6AGiDBrdPKH+aDVgPgJUX0JH/VKnaVbUQmbgKPoPhm1rsfA1CVI+nBMx1D9hPOEvjfJawekYem5BhErRuSELnFU/R4X1FYIvKDZm0K70oHgLsQJEg9nDGKcxLpVLQCL+WUBb9Nw4/zJogz/guVKRXXSMb4Uo1sfUtcvw+5dj1NdWK83FePbRUBLwn+CpuMTqmGiHCmOsEXMh0jPnLRqaRKmU9D8J4vhQfcAUCkmn40yZJFmL/vJ2ELwNAWyNbcpqhHBZEaMW2ic82nGyy7mYKRH3ug1svwl7WiYXD7SNdwSuVlYQq4XOHV/CorroC77RzAJu6tVJKOpM2oPA29u8TInQews99gN9/zv9TnhA4y8aJ+nXXRNpTLkUyUmh3S3JnPA=----ATTACHMENT:----NzUzOTk5NDEyMzk4NDIzOSAyNTAxNjg3MzMxNjUxMzM1IDUwNzk0NjI0MzAxODIxOTk=