<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/book.cubrid.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'zh',
  ),
  'this' => 
  array (
    0 => 'cubrid.examples.php',
    1 => '示例',
    2 => '示例',
  ),
  'up' => 
  array (
    0 => 'book.cubrid.php',
    1 => 'CUBRID',
  ),
  'prev' => 
  array (
    0 => 'cubrid.constants.php',
    1 => '预定义常量',
  ),
  'next' => 
  array (
    0 => 'ref.cubrid.php',
    1 => 'CUBRID 函数',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'zh',
    'path' => 'reference/cubrid/examples.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="cubrid.examples" class="chapter">
 <h1 class="title">示例</h1>

 <p class="simpara">下面是一个在PHP和CUBRID建立连接的简单的例子。本节将覆盖最基本和最显著的特性。下面的代码需要连接CUBRID数据库，这意味着 CUBRID服务和 CUBRID  Broker已经运行。</p>
 <p class="simpara">下面用demodb数据库作为例子举例。默认在安装时就创建了。确认此数据库已经被创建。</p>

 <div class="example" id="example-1">
  <p><strong>示例 #1 数据查询的例子</strong></p>
  <div class="example-contents">
    <div class="phpcode"><code><span style="color: #000000">&lt;html&gt;<br />    &lt;head&gt;<br />    &lt;meta http-equiv="content-type" content="text/html; charset=euc-kr"&gt;<br />    &lt;/head&gt;<br />    &lt;body&gt;<br />    &lt;center&gt;<br />    &lt;table border=2&gt;<br />    <span style="color: #0000BB">&lt;?php<br />        </span><span style="color: #FF8000">/**<br />         * Set server information for CUBRID connection. host_ip is the IP<br />         * address where the CUBRID Broker is installed (localhost in this<br />         * example), and host_port is the port number of the CUBRID Broker.<br />         * The port number is the default given during the installation.<br />         * For details, see "Administrator's Guide."<br />         */<br />        </span><span style="color: #0000BB">$host_ip </span><span style="color: #007700">= </span><span style="color: #DD0000">"localhost"</span><span style="color: #007700">;<br />        </span><span style="color: #0000BB">$host_port </span><span style="color: #007700">= </span><span style="color: #0000BB">33000</span><span style="color: #007700">;<br />        </span><span style="color: #0000BB">$db_name </span><span style="color: #007700">= </span><span style="color: #DD0000">"demodb"</span><span style="color: #007700">;<br />        </span><span style="color: #FF8000">/**<br />         * Connect to CUBRID Server. Do not make the actual connection, but<br />         * only retain the connection information. The reason for not making<br />         * the actual connection is to handle transaction more efficiently<br />         * in the 3-tier architecture.<br />         */<br />        </span><span style="color: #0000BB">$cubrid_con </span><span style="color: #007700">= @</span><span style="color: #0000BB">cubrid_connect</span><span style="color: #007700">(</span><span style="color: #0000BB">$host_ip</span><span style="color: #007700">, </span><span style="color: #0000BB">$host_port</span><span style="color: #007700">, </span><span style="color: #0000BB">$db_name</span><span style="color: #007700">);<br /><br />        if (!</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">) {<br />            echo </span><span style="color: #DD0000">"Database Connection Error"</span><span style="color: #007700">;<br />            exit;<br />        }<br />    </span><span style="color: #0000BB">?&gt;<br /></span>    <span style="color: #0000BB">&lt;?php<br />        $sql </span><span style="color: #007700">= </span><span style="color: #DD0000">"select sports, count(players) as players from event group by sports"</span><span style="color: #007700">;<br />        </span><span style="color: #FF8000">/**<br />         * Request the CUBRID Server for the results of the SQL statement.<br />         * Now make the actual connection to the CUBRID Server.<br />         */<br />        </span><span style="color: #0000BB">$result </span><span style="color: #007700">= </span><span style="color: #0000BB">cubrid_execute</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">, </span><span style="color: #0000BB">$sql</span><span style="color: #007700">);<br /><br />        if (</span><span style="color: #0000BB">$result</span><span style="color: #007700">) {<br />            </span><span style="color: #FF8000">/**<br />             * Get the column names from the result set created by the SQL query.<br />             */<br />            </span><span style="color: #0000BB">$columns </span><span style="color: #007700">= </span><span style="color: #0000BB">cubrid_column_names</span><span style="color: #007700">(</span><span style="color: #0000BB">$result</span><span style="color: #007700">);<br />            </span><span style="color: #FF8000">/**<br />             * Get the number of columns in the result set created by the SQL query.<br />             */<br />            </span><span style="color: #0000BB">$num_fields </span><span style="color: #007700">= </span><span style="color: #0000BB">cubrid_num_cols</span><span style="color: #007700">(</span><span style="color: #0000BB">$result</span><span style="color: #007700">);<br />            </span><span style="color: #FF8000">/**<br />             * List the column names of the result set on the screen.<br />             */<br />            </span><span style="color: #007700">echo </span><span style="color: #DD0000">"&lt;tr&gt;"</span><span style="color: #007700">;<br /><br />            while (list(</span><span style="color: #0000BB">$key</span><span style="color: #007700">, </span><span style="color: #0000BB">$colname</span><span style="color: #007700">) = </span><span style="color: #0000BB">each</span><span style="color: #007700">(</span><span style="color: #0000BB">$columns</span><span style="color: #007700">)) {<br />                echo </span><span style="color: #DD0000">"&lt;td align=center&gt;</span><span style="color: #0000BB">$colname</span><span style="color: #DD0000">&lt;/td&gt;"</span><span style="color: #007700">;<br />            }<br /><br />            echo </span><span style="color: #DD0000">"&lt;/tr&gt;"</span><span style="color: #007700">;<br /><br />            </span><span style="color: #FF8000">/**<br />             * Get the results from the result set.<br />             */<br />            </span><span style="color: #007700">while (</span><span style="color: #0000BB">$row </span><span style="color: #007700">= </span><span style="color: #0000BB">cubrid_fetch</span><span style="color: #007700">(</span><span style="color: #0000BB">$result</span><span style="color: #007700">)) {<br />                echo </span><span style="color: #DD0000">"&lt;tr&gt;"</span><span style="color: #007700">;<br /><br />                for (</span><span style="color: #0000BB">$i </span><span style="color: #007700">= </span><span style="color: #0000BB">0</span><span style="color: #007700">; </span><span style="color: #0000BB">$i </span><span style="color: #007700">&lt; </span><span style="color: #0000BB">$num_fields</span><span style="color: #007700">; </span><span style="color: #0000BB">$i</span><span style="color: #007700">++) {<br />                    echo </span><span style="color: #DD0000">"&lt;td align=center&gt;"</span><span style="color: #007700">;<br />                    echo </span><span style="color: #0000BB">$row</span><span style="color: #007700">[</span><span style="color: #0000BB">$i</span><span style="color: #007700">];<br />                    echo </span><span style="color: #DD0000">"&lt;/td&gt;"</span><span style="color: #007700">;<br />                }<br /><br />                echo </span><span style="color: #DD0000">"&lt;/tr&gt;"</span><span style="color: #007700">;<br />            }<br />        }<br />        </span><span style="color: #FF8000">/**<br />         * The PHP module in the CUBRID runs in a 3-tier architecture. Even when<br />         * calling SELECT for transaction processing, it is processed as a part<br />         * of the transaction. Therefore, the transaction needs to be rolled back<br />         * by calling commit or rollback even though SELECT was called for smooth<br />         * performance.<br />         */<br />        </span><span style="color: #0000BB">cubrid_commit</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);<br />        </span><span style="color: #0000BB">cubrid_disconnect</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);<br />    </span><span style="color: #0000BB">?&gt;<br /></span>    &lt;/body&gt;<br />    &lt;/html&gt;</span></code></div>
  </div>

 </div>
 <div class="example" id="example-2">
 <p><strong>示例 #2 数据插入的例子</strong></p>
   <div class="example-contents">
    <div class="phpcode"><code><span style="color: #000000">&lt;html&gt;<br />    &lt;head&gt;<br />    &lt;meta http-equiv="content-type" content="text/html; charset=euc- kr"&gt;<br />    &lt;/head&gt;<br />    &lt;body&gt;<br />    &lt;center&gt;<br />    &lt;table border=2&gt;<br />    <span style="color: #0000BB">&lt;?php<br />        </span><span style="color: #FF8000">/**<br />         * host_ip is the IP address where the CUBRID Broker is installed<br />         * host_port is the port number of the CUBRID Broker<br />         * db_name is the name of CUBRID Database<br />         */<br />        </span><span style="color: #0000BB">$host_ip </span><span style="color: #007700">= </span><span style="color: #DD0000">"localhost"</span><span style="color: #007700">;<br />        </span><span style="color: #0000BB">$host_port </span><span style="color: #007700">= </span><span style="color: #0000BB">33000</span><span style="color: #007700">;<br />        </span><span style="color: #0000BB">$db_name </span><span style="color: #007700">= </span><span style="color: #DD0000">"demodb"</span><span style="color: #007700">;<br />        </span><span style="color: #0000BB">$cubrid_con </span><span style="color: #007700">= @</span><span style="color: #0000BB">cubrid_connect</span><span style="color: #007700">(</span><span style="color: #0000BB">$host_ip</span><span style="color: #007700">, </span><span style="color: #0000BB">$host_port</span><span style="color: #007700">, </span><span style="color: #0000BB">$db_name</span><span style="color: #007700">);<br /><br />        if (!</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">) {<br />            echo </span><span style="color: #DD0000">"Database Connection Error"</span><span style="color: #007700">;<br />            exit;<br />        }<br />    </span><span style="color: #0000BB">?&gt;<br /></span>    <span style="color: #0000BB">&lt;?php<br />        $sql </span><span style="color: #007700">= </span><span style="color: #DD0000">"insert into olympic (host_year,host_nation,host_city,"<br />            </span><span style="color: #007700">. </span><span style="color: #DD0000">"opening_date,closing_date) values (2008, 'China', 'Beijing',"<br />            </span><span style="color: #007700">. </span><span style="color: #DD0000">"to_date('08-08-2008','mm-dd- yyyy'),to_date('08-24-2008','mm-dd-yyyy')) ;"</span><span style="color: #007700">;<br />        </span><span style="color: #0000BB">$result </span><span style="color: #007700">= </span><span style="color: #0000BB">cubrid_execute</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">, </span><span style="color: #0000BB">$sql</span><span style="color: #007700">);<br />        if (</span><span style="color: #0000BB">$result</span><span style="color: #007700">) {<br />            </span><span style="color: #FF8000">/**<br />             * Handled successfully, so commit.<br />             */<br />            </span><span style="color: #0000BB">cubrid_commit</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);<br />            echo </span><span style="color: #DD0000">"Inserted successfully "</span><span style="color: #007700">;<br />        } else {<br />            </span><span style="color: #FF8000">/**<br />             * Error occurred, so the error message is output and rollback is called.<br />             */<br />            </span><span style="color: #007700">echo </span><span style="color: #0000BB">cubrid_error_msg</span><span style="color: #007700">();<br />            </span><span style="color: #0000BB">cubrid_rollback</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);<br />        }<br />        </span><span style="color: #0000BB">cubrid_disconnect</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);<br />    </span><span style="color: #0000BB">?&gt;<br /></span>    &lt;/body&gt;<br />    &lt;/html&gt;</span></code></div>
  </div>

 </div>


</div>
<?php manual_footer($setup); ?>