Array of stdClasses * UPDATE -> Number of rows affected. * DELETE -> Number of Rows affected. * ELSE -> Boolean true / false depending on success. * * @param string $sql * @param array $bindings * @param string $connection * @return mixed */ public static function query($sql, $bindings = array(), $connection = null) { $query = static::connection($connection)->prepare($sql); $bindings = array_values($bindings); foreach ($bindings as $key => &$binding) { if (is_null($binding)) { $query->bindValue($key + 1, null, \PDO::PARAM_INT); } else { $query->bindParam($key + 1, $binding); } } $result = $query->execute(); if (strpos(strtoupper($sql), 'SELECT') === 0) { return $query->fetchAll(\PDO::FETCH_CLASS, 'stdClass'); } elseif (strpos(strtoupper($sql), 'UPDATE') === 0 or strpos(strtoupper($sql), 'DELETE') === 0) { return $query->rowCount(); } else { return $result; } } /** * Begin a fluent query against a table. * * This method is simply a convenient shortcut into Query::table. * * @param string $table * @param string $connection * @return Query */ public static function table($table, $connection = null) { return new DB\Query($table, $connection); } /** * Get the driver name for a database connection. * * @param string $connection * @return string */ public static function driver($connection = null) { return static::connection($connection)->getAttribute(\PDO::ATTR_DRIVER_NAME); } /** * Get the table prefix for a database connection. * * @param string $connection * @return string */ public static function prefix($connection = null) { $connections = Config::get('db.connections'); if (is_null($connection)) { $connection = Config::get('db.default'); } return (array_key_exists('prefix', $connections[$connection])) ? $connections[$connection]['prefix'] : ''; } }