blob: e9f4eb64ef22f169dce5f005ed532eb524d24cac [file] [log] [blame]
admin7b613c72006-09-24 18:05:17 +00001<?php if (!defined('BASEPATH')) exit('No direct script access allowed');
2/**
3 * Code Igniter
4 *
5 * An open source application development framework for PHP 4.3.2 or newer
6 *
7 * @package CodeIgniter
8 * @author Rick Ellis
9 * @copyright Copyright (c) 2006, pMachine, Inc.
10 * @license http://www.codeignitor.com/user_guide/license.html
11 * @link http://www.codeigniter.com
12 * @since Version 1.0
13 * @filesource
14 */
15
16// ------------------------------------------------------------------------
17
18/**
19 * SQLite Utility Class
20 *
21 * @category Database
22 * @author Rick Ellis
23 * @link http://www.codeigniter.com/user_guide/database/
24 */
admina5e812c2006-09-25 02:17:30 +000025class CI_DB_sqlite_utility extends CI_DB_utility {
26
admin6ca6f942006-09-25 02:51:08 +000027
28 /**
29 * Create database
30 *
31 * @access public
32 * @param string the database name
33 * @return bool
34 */
admin6cec6a52006-09-25 06:56:49 +000035 function _create_database()
admin6ca6f942006-09-25 02:51:08 +000036 {
37 // In SQLite, a database is created when you connect to the database
38 return TRUE;
39 }
40
41 // --------------------------------------------------------------------
42
43 /**
44 * Drop database
45 *
admin83b05a82006-09-25 21:06:46 +000046 * @access private
admin6ca6f942006-09-25 02:51:08 +000047 * @param string the database name
48 * @return bool
49 */
admin83b05a82006-09-25 21:06:46 +000050 function _drop_database($name)
admin6ca6f942006-09-25 02:51:08 +000051 {
52 if ( ! @file_exists($this->db->database) OR ! @unlink($this->db->database))
53 {
54 if ($this->db_debug)
55 {
56 return $this->display_error('db_unable_to_drop');
57 }
58 return FALSE;
59 }
60 return TRUE;
61 }
62
63 // --------------------------------------------------------------------
64
admin7b613c72006-09-24 18:05:17 +000065 /**
admin72496372006-09-25 03:44:04 +000066 * List databases
67 *
admin83b05a82006-09-25 21:06:46 +000068 * @access private
admin72496372006-09-25 03:44:04 +000069 * @return bool
70 */
admin83b05a82006-09-25 21:06:46 +000071 function _list_databases()
admin72496372006-09-25 03:44:04 +000072 {
73 if ($this->db_debug)
74 {
75 return $this->display_error('db_unsuported_feature');
76 }
77 return array();
78 }
79
80 // --------------------------------------------------------------------
81
82 /**
admin4ceac2d2006-09-25 06:40:16 +000083 * Drop Table
84 *
admin83b05a82006-09-25 21:06:46 +000085 * @access private
admin4ceac2d2006-09-25 06:40:16 +000086 * @return bool
87 */
admin83b05a82006-09-25 21:06:46 +000088 function _drop_table($table)
admin4ceac2d2006-09-25 06:40:16 +000089 {
90 if ($this->db_debug)
91 {
92 return $this->display_error('db_unsuported_feature');
93 }
94 return array();
95 }
96
97 // --------------------------------------------------------------------
98
99 /**
admina5e812c2006-09-25 02:17:30 +0000100 * Version number query string
admin7b613c72006-09-24 18:05:17 +0000101 *
102 * @access public
admina5e812c2006-09-25 02:17:30 +0000103 * @return string
admin7b613c72006-09-24 18:05:17 +0000104 */
admina5e812c2006-09-25 02:17:30 +0000105 function _version()
admin7b613c72006-09-24 18:05:17 +0000106 {
admina5e812c2006-09-25 02:17:30 +0000107 return sqlite_libversion();
108 }
109
110 // --------------------------------------------------------------------
111
112 /**
113 * Show table query
114 *
115 * Generates a platform-specific query string so that the table names can be fetched
116 *
117 * @access public
118 * @return string
119 */
120 function _show_tables()
121 {
122 return "SELECT name from sqlite_master WHERE type='table'";
admin7b613c72006-09-24 18:05:17 +0000123 }
124
125 // --------------------------------------------------------------------
126
admina5e812c2006-09-25 02:17:30 +0000127 /**
128 * Show columnn query
129 *
130 * Generates a platform-specific query string so that the column names can be fetched
131 *
132 * @access public
133 * @param string the table name
134 * @return string
135 */
136 function _show_columns($table = '')
137 {
138 // Not supported
139 return FALSE;
140 }
141
142 // --------------------------------------------------------------------
143
144 /**
145 * Field data query
146 *
147 * Generates a platform-specific query so that the column data can be retrieved
148 *
149 * @access public
150 * @param string the table name
151 * @return object
152 */
153 function _field_data($table)
154 {
admin6cec6a52006-09-25 06:56:49 +0000155 return "SELECT * FROM ".$this->db->_escape_table($table)." LIMIT 1";
admina5e812c2006-09-25 02:17:30 +0000156 }
157
adminab4f61b2006-09-25 22:12:32 +0000158 // --------------------------------------------------------------------
159
160 /**
161 * Optimize table query
162 *
163 * Generates a platform-specific query so that a table can be optimized
164 *
165 * @access private
166 * @param string the table name
167 * @return object
168 */
169 function _optimize_table($table)
170 {
171 return FALSE; // Is this supported SQLite?
172 }
173
174 // --------------------------------------------------------------------
175
176 /**
177 * Repair table query
178 *
179 * Generates a platform-specific query so that a table can be repaired
180 *
181 * @access private
182 * @param string the table name
183 * @return object
184 */
185 function _repair_table($table)
186 {
187 return return FALSE; // Is this supported in SQLite?
188 }
admina5e812c2006-09-25 02:17:30 +0000189
190
admin7b613c72006-09-24 18:05:17 +0000191}
192
193?>