diff options
Diffstat (limited to 'program/lib/Roundcube/rcube_db_mssql.php')
| -rw-r--r-- | program/lib/Roundcube/rcube_db_mssql.php | 32 | 
1 files changed, 23 insertions, 9 deletions
| diff --git a/program/lib/Roundcube/rcube_db_mssql.php b/program/lib/Roundcube/rcube_db_mssql.php index 37a42678a..3c1b9d71f 100644 --- a/program/lib/Roundcube/rcube_db_mssql.php +++ b/program/lib/Roundcube/rcube_db_mssql.php @@ -29,38 +29,52 @@ class rcube_db_mssql extends rcube_db      public $db_provider = 'mssql';      /** -     * Driver initialization +     * Object constructor +     * +     * @param string $db_dsnw DSN for read/write operations +     * @param string $db_dsnr Optional DSN for read only operations +     * @param bool   $pconn   Enables persistent connections       */ -    protected function init() +    public function __construct($db_dsnw, $db_dsnr = '', $pconn = false)      { +        parent::__construct($db_dsnw, $db_dsnr, $pconn); +          $this->options['identifier_start'] = '[';          $this->options['identifier_end'] = ']';      }      /** -     * Character setting +     * Driver-specific configuration of database connection +     * +     * @param array $dsn DSN for DB connections +     * @param PDO   $dbh Connection handler       */ -    protected function set_charset($charset) +    protected function conn_configure($dsn, $dbh)      { -        // UTF-8 is default +        // Set date format in case of non-default language (#1488918) +        $this->query("SET DATEFORMAT ymd");      }      /**       * Return SQL function for current time and date       * +     * @param int $interval Optional interval (in seconds) to add/subtract +     *       * @return string SQL function to use in query       */ -    public function now() +    public function now($interval = 0)      { +        if ($interval) { +            $interval = intval($interval); +            return "dateadd(second, $interval, getdate())"; +        } +          return "getdate()";      }      /**       * Return SQL statement to convert a field value into a unix timestamp       * -     * This method is deprecated and should not be used anymore due to limitations -     * of timestamp functions in Mysql (year 2038 problem) -     *       * @param string $field Field name       *       * @return string SQL statement to use in query | 
