queries.html 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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="utf-8" lang="utf-8">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
  6. <title>查询 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
  7. <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
  8. <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
  9. <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
  10. <link rel="canonical" href="http://codeigniter.org.cn/user_guide/database/queries.html" />
  11. <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
  12. <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
  13. <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
  14. <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
  15. <meta name="robots" content="all" />
  16. <meta name="author" content="ExpressionEngine Dev Team" />
  17. <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
  18. </head>
  19. <body>
  20. <!-- START NAVIGATION -->
  21. <div id="nav">
  22. <div id="nav_inner">
  23. <script type="text/javascript">create_menu('../');</script>
  24. </div>
  25. </div>
  26. <script type="text/javascript">_setNavigation();</script>
  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="切换目录" alt="切换目录" /></a></div>
  28. <div id="masthead" class="clearfix">
  29. <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
  30. <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a>  <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
  31. </div>
  32. <!-- END NAVIGATION -->
  33. <!-- START BREADCRUMB -->
  34. <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
  35. <tr>
  36. <td id="breadcrumb">
  37. <a href="#" target="_blank">CodeIgniter 中国首页</a>&nbsp;&#8250;&nbsp;
  38. <a href="../index.html">用户指南首页</a>&nbsp;&#8250;&nbsp;<a href="index.html">数据库类</a>&nbsp;&#8250;&nbsp;查询 </td>
  39. <td id="searchbox">
  40. <form method="get" action="http://www.google.com.hk/search" target="google_window">
  41. <input type="hidden" name="client" value="pub-0176846097796333"></input>
  42. <input type="hidden" name="forid" value="1"></input>
  43. <input type="hidden" name="ie" value="UTF-8"></input>
  44. <input type="hidden" name="oe" value="UTF-8"></input>
  45. <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
  46. 搜索用户指南&nbsp;
  47. <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
  48. &nbsp;
  49. <input type="submit" class="submit" name="sa" value="Go" />
  50. </form>
  51. </td>
  52. </tr>
  53. </table>
  54. <!-- END BREADCRUMB -->
  55. <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
  56. <a href="#" target="_blank">查看原文</a>
  57. </div>
  58. <!--<br clear="all" />--><!-- START CONTENT -->
  59. <div id="content">
  60. <h1>查询</h1>
  61. <h2>$this-&gt;db-&gt;query();</h2>
  62. <p>要提交一个查询,用以下函数:</p>
  63. <code>$this-&gt;db-&gt;query('YOUR QUERY HERE');</code>
  64. <p><dfn>query()</dfn> 函数以<strong>object(对象)</strong>的形式返回一个数据库结果集. 当使用 "read" 模式来运行查询时, 你可以使用“<a href="results.html">显示你的结果集</a>”来显示查询结果; 当使用 "write" 模式来运行查询时, 将会仅根据执行的成功或失败来返回 TRUE 或 FALSE. 当你需要将返回的结果赋值给一个自定义变量的时候, 你可以这样操作:</p>
  65. <code><var>$query</var> = $this-&gt;db-&gt;query('YOUR QUERY HERE');</code>
  66. <h2>$this-&gt;db-&gt;simple_query();</h2>
  67. <p>这是一个简化版本的 <dfn>$this-&gt;db-&gt;query()</dfn> 函数. 它仅返回 True(bool) 和 False(bool) 以表示查询成功与失败.
  68. 它将不会返回查询数据集,无法设置查询计时器(设置环境变量),无法编译绑定数据,不能够存储查询诊断信息。
  69. 简单地说,他是一个用于提交查询的函数,对于大多数用户而言并不会使用到它。</p>
  70. <h1>Working with Database prefixes manually</h1>
  71. <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>
  72. <p><code>$this-&gt;db-&gt;dbprefix('tablename');<br />
  73. // outputs prefix_tablename</code></p>
  74. <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>
  75. <p><code>$this-&gt;db-&gt;set_dbprefix('newprefix');<br /><br />
  76. $this-&gt;db-&gt;dbprefix('tablename');<br />
  77. // outputs newprefix_tablename</code></p>
  78. <h1>保护标识符</h1>
  79. <p>在许多数据库中,保护表(table)和字段(field)的名称是明智的,例如在MySQL中使用反引号。<strong>Active Record的查询都已被自动保护</strong>,然而,如果您需要手动保护一个标识符,您也可以这样:</p>
  80. <p><code>$this-&gt;db-&gt;protect_identifiers('table_name');</code></p>
  81. <p class="important">Although Active Record will try its best to properly quote any field and table names that you feed it, note that it is NOT designed to work with arbitrary user input. DO NOT feed it with unsanitized user data.</p>
  82. <p>这个函数也会给你的表名添加一个前缀,它假定在你的数据库配置文件中已指定了一个前缀。可通过将第二个参数设置为<kbd>TRUE</kbd> (boolen) 启用前缀:</p>
  83. <p><code>$this-&gt;db-&gt;protect_identifiers('table_name', <kbd>TRUE</kbd>);</code></p>
  84. <h1>转义查询</h1>
  85. <p>将数据转义以后提交到你的数据库是非常好的安全做法,CodeIgniter 提供了 3 个函数帮助你完成这个工作。</p>
  86. <ol>
  87. <li><strong>$this-&gt;db-&gt;escape()</strong> 这个函数将会确定数据类型,以便仅对字符串类型数据进行转义。并且,它也会自动把数据用单引号括起来,所以你不必手动添加单引号,用法如下:
  88. <code>$sql = "INSERT INTO table (title) VALUES(".$this-&gt;db-&gt;escape($title).")";</code></li>
  89. <li><strong>$this-&gt;db-&gt;escape_str()</strong> 此函数将忽略数据类型对传入数据进行转义。更多时候你将使用上面的函数而不是这个。这个函数的使用方法是:
  90. <code>$sql = "INSERT INTO table (title) VALUES('".$this-&gt;db-&gt;escape_str($title)."')";</code></li>
  91. <li><strong>$this-&gt;db-&gt;escape_like_str()</strong> This method should be used when strings are to be used in LIKE conditions so that LIKE wildcards ('%', '_') in the string are also properly escaped.
  92. <code>$search = '20% raise';<br />
  93. $sql = "SELECT id FROM table WHERE column LIKE '%".$this-&gt;db-&gt;escape_like_str($search)."%'";</code></li>
  94. </ol>
  95. <h1>封装查询</h1>
  96. <p>封装,通过让系统为你组装各个查询语句,能够简化你的查询语法。参加下面的范例:</p>
  97. <code>
  98. $sql = "SELECT * FROM some_table WHERE id = <var>?</var> AND status = <var>?</var> AND author = <var>?</var>";
  99. <br /><br />
  100. $this-&gt;db-&gt;query($sql, array(3, 'live', 'Rick'));
  101. </code>
  102. <p>查询语句中的问号会自动被查询函数中位于第二个参数位置的数组中的值所替代。</p>
  103. <p class="important">使用封装查询的第二个好处是所有的值都会被自动转义,形成了较为安全的查询语句。你无需手动地去转义这些数据;控制器将会自动为你进行。</p><p>&nbsp;</p>
  104. <div id="Contributors">
  105. 翻译贡献者:
  106. 498621, Fanbin, Hex, kkorange, szlinz, xjflyttp</div>
  107. <div id="DocDate">
  108. 最后修改: 2014-06-10 13:40:54</div>
  109. </div>
  110. <!-- END CONTENT -->
  111. <div id="footer">
  112. <p>
  113. 上一个主题:&nbsp;&nbsp;<a href="connecting.html">连接到你的数据库</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  114. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="results.html">查询结果</a> </p>
  115. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  116. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  117. </div>
  118. </body>
  119. </html>