configuration.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  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/configuration.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. <p>CodeIgniter 有一个配置文件让你存放数据库连接值(username:用户名,password:密码,database name:数据库名,等等..).
  62. 该配置文件位于 <samp>application/config/database.php</samp>. 你也可以通过放置不同的<strong>database.php</strong>文件到特定的环境配置文件夹里来设置特定<a href="../libraries/config.html">环境</a>的数据库连接值.
  63. <p>配件文件存放在一个如下格式的一个多维数组里:</p>
  64. <code>$db['default']['hostname'] = "localhost";<br />
  65. $db['default']['username'] = "root";<br />
  66. $db['default']['password'] = "";<br />
  67. $db['default']['database'] = "database_name";<br />
  68. $db['default']['dbdriver'] = "mysql";<br />
  69. $db['default']['dbprefix'] = "";<br />
  70. $db['default']['pconnect'] = TRUE;<br />
  71. $db['default']['db_debug'] = FALSE;<br />
  72. $db['default']['cache_on'] = FALSE;<br />
  73. $db['default']['cachedir'] = &quot;&quot;;<br />
  74. $db['default']['char_set'] = "utf8";<br />
  75. $db['default']['dbcollat'] = "utf8_general_ci";<br />
  76. $db['default']['swap_pre'] = "";<br />
  77. $db['default']['autoinit'] = TRUE;<br />
  78. $db['default']['stricton'] = FALSE;</code>
  79. <p>我们使用多维数组的原因是为了让你随意的存储多个连接值的设置。举例:如果你运行多个环境(development:开发、production:生产、test:测试 等等..),你能为每个环境建立独立的连接组,并在组直接进行切换。举例,设置一个"test"环境,你可以这样做:</p>
  80. <code>$db['test']['hostname'] = "localhost";<br />
  81. $db['test']['username'] = "root";<br />
  82. $db['test']['password'] = "";<br />
  83. $db['test']['database'] = "database_name";<br />
  84. $db['test']['dbdriver'] = "mysql";<br />
  85. $db['test']['dbprefix'] = "";<br />
  86. $db['test']['pconnect'] = TRUE;<br />
  87. $db['test']['db_debug'] = FALSE;<br />
  88. $db['test']['cache_on'] = FALSE;<br />
  89. $db['test']['cachedir'] = &quot;&quot;;<br />
  90. $db['test']['char_set'] = "utf8";<br />
  91. $db['test']['dbcollat'] = "utf8_general_ci";<br />
  92. $db['test']['swap_pre'] = "";<br />
  93. $db['test']['autoinit'] = TRUE;<br />
  94. $db['test']['stricton'] = FALSE;</code>
  95. <p>那么,告诉系统使用"test"组,你可以设置位于配置文件中的变量:</p>
  96. <code>$active_group = "test";</code>
  97. <p>注意: "test"的名字是任意的,这可以让你自由设置,我们的主要连接默认使用"default"这个名字,当然,您可以基于您的项目为它起一个更有意义的名字。</p>
  98. <h3>Active Record</h3>
  99. <p> <a href="active_record.html">Active Record 类</a> 可以通过数据库配置文件里的$active_record变量进行全局的设定(允许/禁止 TRUE/FALSE (boolean)). 如果你不用这个类,那么你可以通过将这个变量值设置成FALSE来减少在数据库类初始化时对电脑资源的消耗。</p>
  100. <code>$active_record = TRUE;</code>
  101. <p class="important"><strong>注意:</strong> 一些CodeIgniter的类,例如Sessions,在执行一些函数的时候需要Active Records的支持。</p>
  102. <h3>参数解析:</h3>
  103. <ul>
  104. <li><strong>hostname</strong> - 数据库的主机名,通常位于本机,可以表示为 "localhost".</li>
  105. <li><strong>username</strong> - 需要连接到数据库的用户名.</li>
  106. <li><strong>password</strong> - 登陆数据库的密码.</li>
  107. <li><strong>database</strong> - 你需要连接的数据库名.</li>
  108. <li><strong>dbdriver</strong> - 数据库类型。如:mysql、postgres、odbc 等。必须为小写字母。</li>
  109. <li><strong>dbprefix</strong> - 当运行<a href="active_record.html">Active Record</a>查询时数据表的前缀,它允许在一个数据库上安装多个CodeIgniter程序.</li>
  110. <li><strong>pconnect</strong> - TRUE/FALSE (boolean) - 使用持续连接.</li>
  111. <li><strong>db_debug</strong> - TRUE/FALSE (boolean) - 显示数据库错误信息.</li>
  112. <li><strong>cache_on</strong> - TRUE/FALSE (boolean) - 数据库查询缓存是否开启,详情请见<a href="caching.html">数据库缓存类</a>。</li>
  113. <li><strong>cachedir</strong> - 数据库查询缓存目录所在的服务器绝对路径。</li>
  114. <li><strong>char_set</strong> - 与数据库通信时所使用的字符集。</li>
  115. <li><strong>dbcollat</strong> - 与数据库通信时所使用的字符规则。<p class="important"><strong>提示:</strong> 就MYSQL或MYSQLi数据库而言,如果服务器运行环境PHP版本小于5.2.3、MYSQL版本小于5.0.7,那么该项设置仅被用来备份(由数据库维护类DB Forge所创建查询)。如果使用多字节字符集并且使用低版本PHP环境中不兼容的mysql_real_escape_string()函数,它将使网站更容易受到SQL注入的危险。</p></li>
  116. <li><strong>swap_pre</strong> - 替换默认的dbprefix表前缀,该项设置对于分布式应用是非常有用的,你可以在查询中使用由最终用户定制的表前缀。</li>
  117. <p class="important"><strong>曜日晨阳注: </strong>如果设置了 $db['default']['dbprefix'] 的值
  118. 同时也设置了 $db['default']['swap_pre'] 的值,则会将查询代码中和$db['default']['swap_pre'] 的值一致的字符替换成 $db['default']['dbprefix'] 的值,如果没有设置 $db['default']['swap_pre'] 值,就直接在数据库表名前面加上 $db['default']['dbprefix'] 值。</p>
  119. <li><strong>autoinit</strong> - 当数据库类库(database library)被载入的时候是否需要自动连接数据库,如果设置为FALSE,将在首次查询前进行连接。</li>
  120. <li><strong>stricton</strong> - TRUE/FALSE (boolean) - 是否强制使用 "Strict Mode" 连接, 在开发程序时,使用 strict SQL 是一个好习惯。</li>
  121. <li><strong>port</strong> - 数据库端口号. 要使用这个值,你应该添加一行代码到数据库配置数组。<code>$db['default']['port'] = 5432;</code></li>
  122. </ul>
  123. <p class="important"><strong>提示:</strong> 并不是所有的值都是必须的,这取决与您所使用的数据库平台,如(MySQL, Postgres, 等.)
  124. 例如, 当你使用SQLite时,你不需要提供username 或 password, 数据库名字就是您数据库文件的路径. 以上内容假定您使用的是 MySQL 数据库.</p><p>&nbsp;</p>
  125. <div id="Contributors">
  126. 翻译贡献者:
  127. amos, chenshenghan, Drice, Hex, pipi95, tanqimin, thankwsx, tinsn, yinzhili, zehee, 曜日晨阳</div>
  128. <div id="DocDate">
  129. 最后修改: 2013-03-19 05:07:44</div>
  130. </div>
  131. <!-- END CONTENT -->
  132. <div id="footer">
  133. <p>
  134. 上一个主题:&nbsp;&nbsp;<a href="examples.html">入门: 例子</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  135. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="connecting.html">连接到你的数据库</a> </p>
  136. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  137. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  138. </div>
  139. </body>
  140. </html>