blob: d2a4212085acf930ee2a3ba1496ce1949de05427 [file] [log] [blame]
Andrey Andreev0e8968a2012-01-26 02:04:37 +02001<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
Alex Bilbie84445d02011-03-10 16:43:39 +00002/**
3 * CodeIgniter
4 *
5 * An open source application development framework for PHP 5.1.6 or newer
6 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Andrey Andreev0e8968a2012-01-26 02:04:37 +02008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Andrey Andreev0e8968a2012-01-26 02:04:37 +020010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
Alex Bilbie84445d02011-03-10 16:43:39 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
Greg Aker0defe5d2012-01-01 18:46:41 -060021 * @copyright Copyright (c) 2008 - 2012, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Alex Bilbie84445d02011-03-10 16:43:39 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
27
Alex Bilbie84445d02011-03-10 16:43:39 +000028/**
Alex Bilbie01ab0042011-03-18 19:24:30 +000029 * SQLSRV Utility Class
Alex Bilbie84445d02011-03-10 16:43:39 +000030 *
31 * @category Database
Derek Jonesf4a4bd82011-10-20 12:18:42 -050032 * @author EllisLab Dev Team
Alex Bilbie84445d02011-03-10 16:43:39 +000033 * @link http://codeigniter.com/user_guide/database/
34 */
Alex Bilbie01ab0042011-03-18 19:24:30 +000035class CI_DB_sqlsrv_utility extends CI_DB_utility {
Alex Bilbie84445d02011-03-10 16:43:39 +000036
37 /**
38 * List databases
39 *
Andrey Andreev0e8968a2012-01-26 02:04:37 +020040 * @return string
Alex Bilbie84445d02011-03-10 16:43:39 +000041 */
Andrey Andreev0e8968a2012-01-26 02:04:37 +020042 public function _list_databases()
Alex Bilbie84445d02011-03-10 16:43:39 +000043 {
Andrey Andreev0e8968a2012-01-26 02:04:37 +020044 return 'EXEC sp_helpdb'; // Can also be: EXEC sp_databases
Alex Bilbie84445d02011-03-10 16:43:39 +000045 }
46
47 // --------------------------------------------------------------------
48
49 /**
50 * Optimize table query
51 *
52 * Generates a platform-specific query so that a table can be optimized
53 *
Alex Bilbie84445d02011-03-10 16:43:39 +000054 * @param string the table name
Andrey Andreev0e8968a2012-01-26 02:04:37 +020055 * @return string
Alex Bilbie84445d02011-03-10 16:43:39 +000056 */
Andrey Andreev0e8968a2012-01-26 02:04:37 +020057 public function _optimize_table($table)
Alex Bilbie84445d02011-03-10 16:43:39 +000058 {
Andrey Andreev0e8968a2012-01-26 02:04:37 +020059 return 'ALTER INDEX all ON '.$this->db->protect_identifiers($table).' REORGANIZE';
Alex Bilbie84445d02011-03-10 16:43:39 +000060 }
61
62 // --------------------------------------------------------------------
63
64 /**
65 * Repair table query
66 *
67 * Generates a platform-specific query so that a table can be repaired
68 *
Alex Bilbie84445d02011-03-10 16:43:39 +000069 * @param string the table name
Andrey Andreev0e8968a2012-01-26 02:04:37 +020070 * @return bool
Alex Bilbie84445d02011-03-10 16:43:39 +000071 */
Andrey Andreev0e8968a2012-01-26 02:04:37 +020072 public function _repair_table($table)
Alex Bilbie84445d02011-03-10 16:43:39 +000073 {
Andrey Andreev0e8968a2012-01-26 02:04:37 +020074 // Not supported in MSSQL
75 return FALSE;
Alex Bilbie84445d02011-03-10 16:43:39 +000076 }
77
78 // --------------------------------------------------------------------
79
80 /**
81 * MSSQL Export
82 *
Alex Bilbie84445d02011-03-10 16:43:39 +000083 * @param array Preferences
Andrey Andreev0e8968a2012-01-26 02:04:37 +020084 * @return bool
Alex Bilbie84445d02011-03-10 16:43:39 +000085 */
Andrey Andreev0e8968a2012-01-26 02:04:37 +020086 public function _backup($params = array())
Alex Bilbie84445d02011-03-10 16:43:39 +000087 {
88 // Currently unsupported
89 return $this->db->display_error('db_unsuported_feature');
90 }
91
92}
93
Andrey Andreev0e8968a2012-01-26 02:04:37 +020094/* End of file sqlsrv_utility.php */
95/* Location: ./system/database/drivers/sqlsrv/sqlsrv_utility.php */