MSSQLDatabaseInfo.php

Go to the documentation of this file.
00001 <?php 00002 /* 00003 * $Id: MSSQLDatabaseInfo.php,v 1.9 2004/03/20 04:16:49 hlellelid Exp $ 00004 * 00005 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00006 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00007 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 00008 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 00009 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 00010 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 00011 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 00012 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 00013 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00014 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 00015 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00016 * 00017 * This software consists of voluntary contributions made by many individuals 00018 * and is licensed under the LGPL. For more information please see 00019 * <http://creole.phpdb.org>. 00020 */ 00021 00022 require_once 'creole/metadata/DatabaseInfo.php'; 00023 00031 class MSSQLDatabaseInfo extends DatabaseInfo { 00032 00033 private $dbname; 00034 private $dblink; 00035 00036 public function __construct(Connection $conn) { 00037 parent::__construct($conn); 00038 $dsn = $conn->getDSN(); 00039 $this->dbname = $dsn['database']; 00040 $this->dblink = $conn->getResource(); 00041 } 00042 00047 protected function initTables() 00048 { 00049 include_once 'creole/drivers/mssql/metadata/MSSQLTableInfo.php'; 00050 00051 $dsn = $this->conn->getDSN(); 00052 00053 00054 if (!@mssql_select_db($this->dbname, $this->dblink)) { 00055 throw new SQLException('No database selected'); 00056 } 00057 00058 $result = mssql_query("SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_NAME <> 'dtproperties'", $this->dblink); 00059 00060 if (!$result) { 00061 throw new SQLException("Could not list tables", mssql_get_last_message()); 00062 } 00063 00064 while ($row = mssql_fetch_row($result)) { 00065 $this->tables[strtoupper($row[0])] = new MSSQLTableInfo($this, $row[0]); 00066 } 00067 } 00068 00074 protected function initSequences() 00075 { 00076 // there are no sequences -- afaik -- in MSSQL. 00077 } 00078 00079 }

This file is part of the Creole[php5] library.


Copyright © 2004 Hans Lellelid  
Creole[php5] CVS