blob: 35f2da7867b0f81e7ee5138de0675ceef5bf0cf6 [file] [log] [blame]
adminfb28bb82006-09-24 17:59:33 +00001<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
Derek Allardafd99ac2008-01-19 19:59:14 +00002<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
adminfb28bb82006-09-24 17:59:33 +00003<head>
4
Derek Allard8039d4c2008-05-31 02:47:56 +00005<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
Derek Jonesfd93d222008-05-06 15:18:50 +00006<title>Queries : CodeIgniter User Guide</title>
adminfb28bb82006-09-24 17:59:33 +00007
8<style type='text/css' media='all'>@import url('../userguide.css');</style>
9<link rel='stylesheet' type='text/css' media='all' href='../userguide.css' />
10
admin17a890d2006-09-27 20:42:42 +000011<script type="text/javascript" src="../nav/nav.js"></script>
admin2296fc32006-09-27 21:07:02 +000012<script type="text/javascript" src="../nav/prototype.lite.js"></script>
admin17a890d2006-09-27 20:42:42 +000013<script type="text/javascript" src="../nav/moo.fx.js"></script>
Derek Allardb3412372007-10-25 12:15:16 +000014<script type="text/javascript" src="../nav/user_guide_menu.js"></script>
adminfb28bb82006-09-24 17:59:33 +000015
adminfb28bb82006-09-24 17:59:33 +000016<meta http-equiv='expires' content='-1' />
17<meta http-equiv= 'pragma' content='no-cache' />
18<meta name='robots' content='all' />
Derek Allard3d879d52008-01-18 19:41:32 +000019<meta name='author' content='ExpressionEngine Dev Team' />
Derek Allardd2df9bc2007-04-15 17:41:17 +000020<meta name='description' content='CodeIgniter User Guide' />
adminfb28bb82006-09-24 17:59:33 +000021
22</head>
23<body>
24
25<!-- START NAVIGATION -->
26<div id="nav"><div id="nav_inner"><script type="text/javascript">create_menu('../');</script></div></div>
Rick Ellis7cdef032008-08-26 18:44:54 +000027<div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="Toggle Table of Contents" alt="Toggle Table of Contents" /></a></div>
adminfb28bb82006-09-24 17:59:33 +000028<div id="masthead">
29<table cellpadding="0" cellspacing="0" border="0" style="width:100%">
30<tr>
Rick Ellis25949532008-08-26 19:48:08 +000031<td><h1>CodeIgniter User Guide Version 1.7</h1></td>
adminc0d5d522006-10-30 19:40:35 +000032<td id="breadcrumb_right"><a href="../toc.html">Table of Contents Page</a></td>
adminfb28bb82006-09-24 17:59:33 +000033</tr>
34</table>
35</div>
36<!-- END NAVIGATION -->
37
38
39<!-- START BREADCRUMB -->
40<table cellpadding="0" cellspacing="0" border="0" style="width:100%">
41<tr>
42<td id="breadcrumb">
Derek Jones7a9193a2008-01-21 18:39:20 +000043<a href="http://codeigniter.com/">CodeIgniter Home</a> &nbsp;&#8250;&nbsp;
adminfb28bb82006-09-24 17:59:33 +000044<a href="../index.html">User Guide Home</a> &nbsp;&#8250;&nbsp;
45<a href="index.html">Database Library</a> &nbsp;&#8250;&nbsp;
46Queries
47</td>
Derek Allardbc030912007-06-24 18:25:29 +000048<td id="searchbox"><form method="get" action="http://www.google.com/search"><input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.com/user_guide/" />Search User Guide&nbsp; <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />&nbsp;<input type="submit" class="submit" name="sa" value="Go" /></form></td>
adminfb28bb82006-09-24 17:59:33 +000049</tr>
50</table>
51<!-- END BREADCRUMB -->
52
53
54
55<br clear="all" />
56
57
58<!-- START CONTENT -->
59<div id="content">
60
61
62<h1>Queries</h1>
63
64<h2>$this->db->query();</h2>
65
66<p>To submit a query, use the following function:</p>
67
68<code>$this->db->query('YOUR QUERY HERE');</code>
69
70<p>The <dfn>query()</dfn> function returns a database result <strong>object</strong> when "read" type queries are run,
71which you can use to <a href="results.html">show your results</a>. When "write" type queries are run it simply returns TRUE or FALSE
72depending on success or failure. When retrieving data you will typically assign the query to your own variable, like this:</p>
73
74<code><var>$query</var> = $this->db->query('YOUR QUERY HERE');</code>
75
76<h2>$this->db->simple_query();</h2>
77
78<p>This is a simplified version of the <dfn>$this->db->query()</dfn> function. It ONLY returns TRUE/FALSE on success or failure.
admine334c472006-10-21 19:44:22 +000079It DOES NOT return a database result set, nor does it set the query timer, or compile bind data, or store your query for debugging.
adminfb28bb82006-09-24 17:59:33 +000080It simply lets you submit a query. Most users will rarely use this function.</p>
81
82
Derek Allard3b118682008-01-22 23:44:32 +000083<h1>Adding Database prefixes manually</h1>
84<p>If you have configured a database prefix and would like to add it in manually for, you can use the following.</p>
85<p><code>$this-&gt;db-&gt;dbprefix('tablename');<br />
86// outputs prefix_tablename</code></p>
Rick Ellis12abaeb2008-10-17 04:08:03 +000087
88
Derek Allard39b622d2008-01-16 21:10:09 +000089<h1>Protecting identifiers</h1>
Rick Ellis12abaeb2008-10-17 04:08:03 +000090<p>In many databases it is advisable to protect table and field names - for example with backticks in MySQL. <strong>Active Record queries are automatically protected</strong>, however if you need to manually protect an identifier you can use:</p>
Derek Jonesaf368e12008-02-25 21:43:26 +000091<p><code>$this-&gt;db-&gt;protect_identifiers('table_name');</code></p>
Rick Ellis12abaeb2008-10-17 04:08:03 +000092
93<p>This function will also add a table prefix to your table, assuming you have a prefix specified in your database config file. To enable the prefixing set <kbd>TRUE</kbd> (boolen) via the second parameter:</p>
94<p><code>$this-&gt;db-&gt;protect_identifiers('table_name', <kbd>TRUE</kbd>);</code></p>
95
96
admin78ce3cc2006-10-02 02:58:03 +000097<h1>Escaping Queries</h1>
admine334c472006-10-21 19:44:22 +000098<p>It's a very good security practice to escape your data before submitting it into your database.
Derek Allardd2df9bc2007-04-15 17:41:17 +000099CodeIgniter has two functions that help you do this:</p>
adminfb28bb82006-09-24 17:59:33 +0000100
101<ol>
admine334c472006-10-21 19:44:22 +0000102<li><strong>$this->db->escape()</strong> This function determines the data type so that it
adminfb28bb82006-09-24 17:59:33 +0000103can escape only string data. It also automatically adds single quotes around the data so you don't have to:
104
Derek Allardc6441282007-07-04 23:54:32 +0000105<code>$sql = "INSERT INTO table (title) VALUES(".$this->db->escape($title).")";</code></li>
adminfb28bb82006-09-24 17:59:33 +0000106
admine334c472006-10-21 19:44:22 +0000107<li><strong>$this->db->escape_str()</strong> This function escapes the data passed to it, regardless of type.
Derek Allardcb36e342008-08-31 14:24:56 +0000108Most of the time you'll use the above function rather than this one. Use the function like this:
adminfb28bb82006-09-24 17:59:33 +0000109
Derek Allardc6441282007-07-04 23:54:32 +0000110<code>$sql = "INSERT INTO table (title) VALUES('".$this->db->escape_str($title)."')";</code></li>
adminfb28bb82006-09-24 17:59:33 +0000111</ol>
112
113
admin78ce3cc2006-10-02 02:58:03 +0000114<h1>Query Bindings</h1>
adminfb28bb82006-09-24 17:59:33 +0000115
116
117<p>Bindings enable you to simplify your query syntax by letting the system put the queries together for you. Consider the following example:</p>
118
119<code>
120$sql = "SELECT * FROM some_table WHERE id = <var>?</var> AND status = <var>?</var> AND author = <var>?</var>";
121<br /><br />
122$this->db->query($sql, array(3, 'live', 'Rick'));
123</code>
124
125<p>The question marks in the query are automatically replaced with the values in the array in the second parameter of the query function.</p>
126<p class="important">The secondary benefit of using binds is that the values are automatically escaped, producing safer queries. You don't have to remember to manually escape data; the engine does it automatically for you.</p>
127
128
129
130</div>
131<!-- END CONTENT -->
132
133
134<div id="footer">
135<p>
136Previous Topic:&nbsp;&nbsp;<a href="connecting.html">Connecting to your Database</a>
137&nbsp;&nbsp;&nbsp;&middot;&nbsp;&nbsp;
138<a href="#top">Top of Page</a>&nbsp;&nbsp;&nbsp;&middot;&nbsp;&nbsp;
139<a href="../index.html">User Guide Home</a>&nbsp;&nbsp;&nbsp;&middot;&nbsp;&nbsp;
140Next Topic:&nbsp;&nbsp;<a href="results.html">Query Results</a>
Derek Allardc6441282007-07-04 23:54:32 +0000141</p>
Derek Jones07870432008-02-13 03:49:26 +0000142<p><a href="http://codeigniter.com">CodeIgniter</a> &nbsp;&middot;&nbsp; Copyright &#169; 2006-2008 &nbsp;&middot;&nbsp; <a href="http://ellislab.com/">Ellislab, Inc.</a></p>
adminfb28bb82006-09-24 17:59:33 +0000143</div>
144
145</body>
146</html>