/lenasys/trunk

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/lenasys/trunk

« back to all changes in this revision

Viewing changes to codeigniter/user_guide/database/queries.html

  • Committer: galaxyAbstractor
  • Date: 2013-04-10 15:49:32 UTC
  • mto: (19.1.5 lenasys)
  • mto: This revision was merged to the branch mainline in revision 23.
  • Revision ID: galaxyabstractor@gmail.com-20130410154932-4vizlzk0ar5gykvi
* Added an simple admin panel to the codeviewer-cmssy stuff
* Redesigned a bit like the mockups - still stuff to come
* Implemented the codeviewer + admin panel again using the Framework CodeIgniter instead 

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
2
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
 
3
<head>
 
4
 
 
5
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 
6
<title>Queries : CodeIgniter User Guide</title>
 
7
 
 
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
 
 
11
<script type="text/javascript" src="../nav/nav.js"></script>
 
12
<script type="text/javascript" src="../nav/prototype.lite.js"></script>
 
13
<script type="text/javascript" src="../nav/moo.fx.js"></script>
 
14
<script type="text/javascript" src="../nav/user_guide_menu.js"></script>
 
15
 
 
16
<meta http-equiv='expires' content='-1' />
 
17
<meta http-equiv= 'pragma' content='no-cache' />
 
18
<meta name='robots' content='all' />
 
19
<meta name='author' content='ExpressionEngine Dev Team' />
 
20
<meta name='description' content='CodeIgniter User Guide' />
 
21
 
 
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>
 
27
<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>
 
28
<div id="masthead">
 
29
<table cellpadding="0" cellspacing="0" border="0" style="width:100%">
 
30
<tr>
 
31
<td><h1>CodeIgniter User Guide Version 2.1.3</h1></td>
 
32
<td id="breadcrumb_right"><a href="../toc.html">Table of Contents Page</a></td>
 
33
</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">
 
43
<a href="http://codeigniter.com/">CodeIgniter Home</a> &nbsp;&#8250;&nbsp;
 
44
<a href="../index.html">User Guide Home</a> &nbsp;&#8250;&nbsp;
 
45
<a href="index.html">Database Library</a> &nbsp;&#8250;&nbsp;
 
46
Queries
 
47
</td>
 
48
<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>
 
49
</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,
 
71
which you can use to <a href="results.html">show your results</a>.  When "write" type queries are run it simply returns TRUE or FALSE
 
72
depending 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.
 
79
It DOES NOT return a database result set, nor does it set the query timer, or compile bind data, or store your query for debugging.
 
80
It simply lets you submit a query. Most users will rarely use this function.</p>
 
81
 
 
82
 
 
83
<h1>Working with Database prefixes manually</h1>
 
84
<p>If you have configured a database prefix and would like to prepend it to a table name for use in a native SQL query for example, then you can use the following:</p>
 
85
<p><code>$this-&gt;db-&gt;dbprefix('tablename');<br />
 
86
// outputs prefix_tablename</code></p>
 
87
 
 
88
<p>If for any reason you would like to change the prefix programatically without needing to create a new connection, you can use this method:</p>
 
89
<p><code>$this-&gt;db-&gt;set_dbprefix('newprefix');<br /><br />
 
90
$this-&gt;db-&gt;dbprefix('tablename');<br />
 
91
// outputs newprefix_tablename</code></p>
 
92
 
 
93
 
 
94
<h1>Protecting identifiers</h1>
 
95
<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>
 
96
<p><code>$this-&gt;db-&gt;protect_identifiers('table_name');</code></p>
 
97
 
 
98
<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>
 
99
<p><code>$this-&gt;db-&gt;protect_identifiers('table_name', <kbd>TRUE</kbd>);</code></p>
 
100
 
 
101
 
 
102
<h1>Escaping Queries</h1>
 
103
<p>It's a very good security practice to escape your data before submitting it into your database.
 
104
CodeIgniter has three methods that help you do this:</p>
 
105
 
 
106
<ol>
 
107
<li><strong>$this->db->escape()</strong> This function determines the data type so that it
 
108
can escape only string data.  It also automatically adds single quotes around the data so you don't have to:
 
109
 
 
110
<code>$sql = "INSERT INTO table (title) VALUES(".$this->db->escape($title).")";</code></li>
 
111
 
 
112
<li><strong>$this->db->escape_str()</strong>  This function escapes the data passed to it, regardless of type.
 
113
Most of the time you'll use the above function rather than this one. Use the function like this:
 
114
 
 
115
<code>$sql = "INSERT INTO table (title) VALUES('".$this->db->escape_str($title)."')";</code></li>
 
116
 
 
117
<li><strong>$this->db->escape_like_str()</strong>  This method should be used when strings are to be used in LIKE
 
118
conditions so that LIKE wildcards ('%', '_') in the string are also properly escaped.
 
119
 
 
120
<code>$search = '20% raise';<br />
 
121
$sql = "SELECT id FROM table WHERE column LIKE '%".$this->db->escape_like_str($search)."%'";</code></li>
 
122
 
 
123
</ol>
 
124
 
 
125
 
 
126
<h1>Query Bindings</h1>
 
127
 
 
128
 
 
129
<p>Bindings enable you to simplify your query syntax by letting the system put the queries together for you. Consider the following example:</p>
 
130
 
 
131
<code>
 
132
$sql = "SELECT * FROM some_table WHERE id = <var>?</var> AND status = <var>?</var> AND author = <var>?</var>";
 
133
<br /><br />
 
134
$this->db->query($sql, array(3, 'live', 'Rick'));
 
135
</code>
 
136
 
 
137
<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>
 
138
<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>
 
139
 
 
140
 
 
141
 
 
142
</div>
 
143
<!-- END CONTENT -->
 
144
 
 
145
 
 
146
<div id="footer">
 
147
<p>
 
148
Previous Topic:&nbsp;&nbsp;<a href="connecting.html">Connecting to your Database</a>
 
149
&nbsp;&nbsp;&nbsp;&middot;&nbsp;&nbsp;
 
150
<a href="#top">Top of Page</a>&nbsp;&nbsp;&nbsp;&middot;&nbsp;&nbsp;
 
151
<a href="../index.html">User Guide Home</a>&nbsp;&nbsp;&nbsp;&middot;&nbsp;&nbsp;
 
152
Next Topic:&nbsp;&nbsp;<a href="results.html">Query Results</a>
 
153
</p>
 
154
<p><a href="http://codeigniter.com">CodeIgniter</a> &nbsp;&middot;&nbsp; Copyright &#169; 2006 - 2012 &nbsp;&middot;&nbsp; <a href="http://ellislab.com/">EllisLab, Inc.</a></p>
 
155
</div>
 
156
 
 
157
</body>
 
158
</html>
 
 
b'\\ No newline at end of file'