admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
Derek Allard | afd99ac | 2008-01-19 19:59:14 +0000 | [diff] [blame] | 2 | <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 3 | <head>
|
| 4 |
|
Derek Allard | 8039d4c | 2008-05-31 02:47:56 +0000 | [diff] [blame] | 5 | <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
Derek Jones | fd93d22 | 2008-05-06 15:18:50 +0000 | [diff] [blame] | 6 | <title>Query Helper Functions : CodeIgniter User Guide</title>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 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 |
|
admin | 17a890d | 2006-09-27 20:42:42 +0000 | [diff] [blame] | 11 | <script type="text/javascript" src="../nav/nav.js"></script>
|
admin | 2296fc3 | 2006-09-27 21:07:02 +0000 | [diff] [blame] | 12 | <script type="text/javascript" src="../nav/prototype.lite.js"></script>
|
admin | 17a890d | 2006-09-27 20:42:42 +0000 | [diff] [blame] | 13 | <script type="text/javascript" src="../nav/moo.fx.js"></script>
|
Derek Allard | b341237 | 2007-10-25 12:15:16 +0000 | [diff] [blame] | 14 | <script type="text/javascript" src="../nav/user_guide_menu.js"></script>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 15 |
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 16 | <meta http-equiv='expires' content='-1' />
|
| 17 | <meta http-equiv= 'pragma' content='no-cache' />
|
| 18 | <meta name='robots' content='all' />
|
Derek Allard | 3d879d5 | 2008-01-18 19:41:32 +0000 | [diff] [blame] | 19 | <meta name='author' content='ExpressionEngine Dev Team' />
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 20 | <meta name='description' content='CodeIgniter User Guide' />
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 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.jpg" width="153" height="44" 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>
|
Derek Jones | 6b7b11f | 2008-05-06 16:07:27 +0000 | [diff] [blame] | 31 | <td><h1>CodeIgniter User Guide Version 1.6.2</h1></td>
|
admin | c0d5d52 | 2006-10-30 19:40:35 +0000 | [diff] [blame] | 32 | <td id="breadcrumb_right"><a href="../toc.html">Table of Contents Page</a></td>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 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">
|
Derek Jones | 7a9193a | 2008-01-21 18:39:20 +0000 | [diff] [blame] | 43 | <a href="http://codeigniter.com/">CodeIgniter Home</a> ›
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 44 | <a href="../index.html">User Guide Home</a> ›
|
| 45 | <a href="index.html">Database Library</a> ›
|
| 46 | Query Helpers
|
| 47 | </td>
|
Derek Allard | bc03091 | 2007-06-24 18:25:29 +0000 | [diff] [blame] | 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 <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" /> <input type="submit" class="submit" name="sa" value="Go" /></form></td>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 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>Query Helper Functions</h1>
|
| 63 |
|
| 64 |
|
| 65 | <h2>$this->db->insert_id()</h2>
|
| 66 | <p>The insert ID number when performing database inserts.</p>
|
| 67 |
|
| 68 | <h2>$this->db->affected_rows()</h2>
|
| 69 | <p>Displays the number of affected rows, when doing "write" type queries (insert, update, etc.).</p>
|
Derek Allard | 0ce2755 | 2008-03-18 17:48:06 +0000 | [diff] [blame] | 70 | <p>Note: In MySQL "DELETE FROM TABLE" returns 0 affected rows. The database class has a small hack that allows it to return the
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 71 | correct number of affected rows. By default this hack is enabled but it can be turned off in the database driver file.</p>
|
| 72 |
|
| 73 |
|
admin | 910d862 | 2006-09-26 02:09:05 +0000 | [diff] [blame] | 74 | <h2>$this->db->count_all();</h2>
|
| 75 | <p>Permits you to determine the number of rows in a particular table. Submit the table name in the first parameter. Example:</p>
|
| 76 | <code>echo $this->db->count_all('<var>my_table</var>');<br />
|
| 77 | <br />
|
| 78 | // Produces an integer, like 25
|
| 79 | </code>
|
| 80 |
|
| 81 |
|
admin | d125c5c | 2006-09-25 23:26:12 +0000 | [diff] [blame] | 82 | <h2>$this->db->platform()</h2>
|
| 83 | <p>Outputs the database platform you are running (MySQL, MS SQL, Postgre, etc...):</p>
|
| 84 | <code>echo $this->db->platform();</code>
|
| 85 |
|
| 86 |
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 87 | <h2>$this->db->version()</h2>
|
| 88 | <p>Outputs the database version you are running:</p>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 89 | <code>echo $this->db->version();</code>
|
| 90 |
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 91 |
|
admin | d125c5c | 2006-09-25 23:26:12 +0000 | [diff] [blame] | 92 | <h2>$this->db->last_query();</h2>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 93 | <p>Returns the last query that was run (the query string, not the result). Example:</p>
|
| 94 |
|
| 95 | <code>$str = $this->db->last_query();<br />
|
| 96 | <br />
|
| 97 | // Produces: SELECT * FROM sometable....
|
| 98 | </code>
|
| 99 |
|
| 100 |
|
| 101 | <p>The following two functions help simplify the process of writing database INSERTs and UPDATEs.</p>
|
| 102 |
|
| 103 |
|
| 104 | <h2>$this->db->insert_string(); </h2>
|
| 105 | <p>This function simplifies the process of writing database inserts. It returns a correctly formatted SQL insert string. Example:</p>
|
| 106 |
|
| 107 | <code>$data = array('name' => $name, 'email' => $email, 'url' => $url);<br />
|
| 108 | <br />
|
| 109 | $str = $this->db->insert_string('table_name', $data);
|
| 110 | </code>
|
| 111 |
|
| 112 | <p>The first parameter is the table name, the second is an associative array with the data to be inserted. The above example produces:</p>
|
Derek Jones | ff845f9 | 2008-06-26 17:05:55 +0000 | [diff] [blame^] | 113 | <code>INSERT INTO table_name (name, email, url) VALUES ('Rick', 'rick@example.com', 'example.com')</code>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 114 |
|
Rick Ellis | 325197e | 2006-11-20 17:29:05 +0000 | [diff] [blame] | 115 | <p class="important">Note: Values are automatically escaped, producing safer queries.</p>
|
| 116 |
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 117 |
|
| 118 |
|
| 119 | <h2>$this->db->update_string(); </h2>
|
| 120 | <p>This function simplifies the process of writing database updates. It returns a correctly formatted SQL update string. Example:</p>
|
| 121 |
|
| 122 | <code>$data = array('name' => $name, 'email' => $email, 'url' => $url);<br />
|
| 123 | <br />
|
| 124 | $where = "author_id = 1 AND status = 'active'";
|
| 125 | <br /><br />
|
| 126 | $str = $this->db->update_string('table_name', $data, $where);
|
| 127 | </code>
|
| 128 |
|
Derek Allard | 44bd10f | 2008-03-25 22:27:37 +0000 | [diff] [blame] | 129 | <p>The first parameter is the table name, the second is an associative array with the data to be updated, and the third parameter is the "where" clause. The above example produces:</p>
|
Derek Jones | ff845f9 | 2008-06-26 17:05:55 +0000 | [diff] [blame^] | 130 | <code> UPDATE table_name SET name = 'Rick', email = 'rick@example.com', url = 'example.com' WHERE author_id = 1 AND status = 'active'</code>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 131 |
|
Rick Ellis | 325197e | 2006-11-20 17:29:05 +0000 | [diff] [blame] | 132 | <p class="important">Note: Values are automatically escaped, producing safer queries.</p>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 133 |
|
| 134 |
|
| 135 | </div>
|
| 136 | <!-- END CONTENT -->
|
| 137 |
|
| 138 |
|
| 139 | <div id="footer">
|
| 140 | <p>
|
| 141 | Previous Topic: <a href="results.html">Query Results</a>
|
| 142 | ·
|
| 143 | <a href="#top">Top of Page</a> ·
|
| 144 | <a href="../index.html">User Guide Home</a> ·
|
| 145 | Next Topic: <a href="active_record.html">Active Record Pattern</a>
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 146 | </p>
|
Derek Jones | 0787043 | 2008-02-13 03:49:26 +0000 | [diff] [blame] | 147 | <p><a href="http://codeigniter.com">CodeIgniter</a> · Copyright © 2006-2008 · <a href="http://ellislab.com/">Ellislab, Inc.</a></p>
|
admin | fb28bb8 | 2006-09-24 17:59:33 +0000 | [diff] [blame] | 148 | </div>
|
| 149 |
|
| 150 | </body>
|
| 151 | </html> |