<?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 => 'fr',
  ),
  'this' => 
  array (
    0 => 'cubrid.examples.php',
    1 => 'Exemples',
    2 => 'Exemples',
  ),
  'up' => 
  array (
    0 => 'book.cubrid.php',
    1 => 'CUBRID',
  ),
  'prev' => 
  array (
    0 => 'cubrid.constants.php',
    1 => 'Constantes pr&eacute;-d&eacute;finies',
  ),
  'next' => 
  array (
    0 => 'ref.cubrid.php',
    1 => 'Fonctions CUBRID',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'fr',
    '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">Exemples</h1>

 <p class="simpara">
  Ce qui suit est un simple exemple qui établit une connexion
  entre PHP et CUBRID. Cette section expose les fonctions les
  plus basiques et utiles. Le code suivant nécessite une
  connexion à la base de données CUBRID, ce qui signifie que le
  serveur CUBRID ainsi que le courtier CUBRID doivent être en
  fonctionnement.
 </p>
 <p class="simpara">
  L&#039;exemple ci-dessous utilise la base de données demodb
  comme exemple. Par défaut, elle est créée durant l&#039;installation.
  Il faut s&#039;assurer que c&#039;est bien le cas.
 </p>
 <div class="example" id="example-1">
  <p><strong>Exemple #1 Exemple de récupération de données</strong></p>
  <div class="example-contents">
<div class="phpcode"><pre><code style="color: #000000">&lt;html&gt;
    &lt;head&gt;
    &lt;meta http-equiv="content-type" content="text/html; charset=euc-kr"&gt;
    &lt;/head&gt;
    &lt;body&gt;
    &lt;center&gt;
    &lt;table border=2&gt;
    <span style="color: #0000BB">&lt;?php
        </span><span style="color: #FF8000">/**
         * Définit les informations du serveur pour une connexion CUBRID.
         * host_ip est l'adresse IP pointant l'installation du courtier CUBRID (localhost
         * dans cet exemple), ainsi que le numéro de port à utiliser pour le courtier CUBRID.
         * Le numéro du port est celui par défaut fourni lors de l'installation.
         * Pour plus de détails, lisez le "Guide d'administration"
         */
        </span><span style="color: #0000BB">$host_ip </span><span style="color: #007700">= </span><span style="color: #DD0000">"localhost"</span><span style="color: #007700">;
        </span><span style="color: #0000BB">$host_port </span><span style="color: #007700">= </span><span style="color: #0000BB">33000</span><span style="color: #007700">;
        </span><span style="color: #0000BB">$db_name </span><span style="color: #007700">= </span><span style="color: #DD0000">"demodb"</span><span style="color: #007700">;
        </span><span style="color: #FF8000">/**
         * Connexion au serveur CUBRID. N'effectue pas la connexion immédiatement,
         * mais ne fait que retenir les informations de connexions. La raison
         * pour laquelle la connexion ne s'effectue pas immédiatement est pour
         * gérer les transactions plus efficacement sur des architectures en 3 parties.
         */
        </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">);

        if (!</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">) {
            echo </span><span style="color: #DD0000">"Erreur de connexion à la base de données"</span><span style="color: #007700">;
            exit;
        }
    </span><span style="color: #0000BB">?&gt;
</span>    <span style="color: #0000BB">&lt;?php
        $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">;
        </span><span style="color: #FF8000">/**
         * Interroge le serveur CUBRID afin de récupérer les résultats de la requête SQL.
         * Maintenant, nous effectuons réellement la connexion au serveur CUBRID.
         */
        </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">);

        if (</span><span style="color: #0000BB">$result</span><span style="color: #007700">) {
            </span><span style="color: #FF8000">/**
             * Récupère les noms des colonnes depuis le jeu de résultats créé par la requête SQL.
             */
            </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">);
            </span><span style="color: #FF8000">/**
             * Récupère le nombre de colonnes depuis le jeu de résultats créé par la requête SQL.
             */
            </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">);
            </span><span style="color: #FF8000">/**
             * Liste les noms des colonnes depuis le jeu de résultats directement sur l'écran.
             */
            </span><span style="color: #007700">echo </span><span style="color: #DD0000">"&lt;tr&gt;"</span><span style="color: #007700">;

            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">)) {
                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">;
            }

            echo </span><span style="color: #DD0000">"&lt;/tr&gt;"</span><span style="color: #007700">;

            </span><span style="color: #FF8000">/**
             * Récupère les résultats depuis le jeu de résultats.
             */
            </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">)) {
                echo </span><span style="color: #DD0000">"&lt;tr&gt;"</span><span style="color: #007700">;

                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">++) {
                    echo </span><span style="color: #DD0000">"&lt;td align=center&gt;"</span><span style="color: #007700">;
                    echo </span><span style="color: #0000BB">$row</span><span style="color: #007700">[</span><span style="color: #0000BB">$i</span><span style="color: #007700">];
                    echo </span><span style="color: #DD0000">"&lt;/td&gt;"</span><span style="color: #007700">;
                }

                echo </span><span style="color: #DD0000">"&lt;/tr&gt;"</span><span style="color: #007700">;
            }
        }
        </span><span style="color: #FF8000">/**
         * Le module PHP dans CUBRID fonctionne en architecture 3 parties.
         * Lors de l'appel à une requête de type SELECT dans une transaction, elle
         * sera exécutée comme faisant partie de la transaction. Aussi, si la
         * transaction est annulée avant l'appel à la requête SELECT, elle sera
         * exécutée avec des performances moindres.
         */
        </span><span style="color: #0000BB">cubrid_commit</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);
        </span><span style="color: #0000BB">cubrid_disconnect</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);
    </span><span style="color: #0000BB">?&gt;
</span>    &lt;/body&gt;
    &lt;/html&gt;</code></pre></div>
  </div>

 </div>
 <div class="example" id="example-2">
  <p><strong>Exemple #2 Exemple d&#039;insertion de données</strong></p>
  <div class="example-contents">
<div class="phpcode"><pre><code style="color: #000000">&lt;html&gt;
    &lt;head&gt;
    &lt;meta http-equiv="content-type" content="text/html; charset=euc- kr"&gt;
    &lt;/head&gt;
    &lt;body&gt;
    &lt;center&gt;
    &lt;table border=2&gt;
    <span style="color: #0000BB">&lt;?php
        </span><span style="color: #FF8000">/**
         * host_ip est l'adresse IP pointant l'installation du courtier CUBRID.
         * host_port est le numéro du port du courtier CUBRID.
         * db_name est le nom de la base de données CUBRID.
         */
        </span><span style="color: #0000BB">$host_ip </span><span style="color: #007700">= </span><span style="color: #DD0000">"localhost"</span><span style="color: #007700">;
        </span><span style="color: #0000BB">$host_port </span><span style="color: #007700">= </span><span style="color: #0000BB">33000</span><span style="color: #007700">;
        </span><span style="color: #0000BB">$db_name </span><span style="color: #007700">= </span><span style="color: #DD0000">"demodb"</span><span style="color: #007700">;
        </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">);

        if (!</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">) {
            echo </span><span style="color: #DD0000">"Erreur lors de la connexion à la base de données"</span><span style="color: #007700">;
            exit;
        }
    </span><span style="color: #0000BB">?&gt;
</span>    <span style="color: #0000BB">&lt;?php
        $sql </span><span style="color: #007700">= </span><span style="color: #DD0000">"insert into olympic (host_year,host_nation,host_city,"
            </span><span style="color: #007700">. </span><span style="color: #DD0000">"opening_date,closing_date) values (2008, 'China', 'Beijing',"
            </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">;
        </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">);
        if (</span><span style="color: #0000BB">$result</span><span style="color: #007700">) {
            </span><span style="color: #FF8000">/**
             * Traitement réussi, nous pouvons commiter.
             */
            </span><span style="color: #0000BB">cubrid_commit</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);
            echo </span><span style="color: #DD0000">"Insertion avec succès"</span><span style="color: #007700">;
        } else {
            </span><span style="color: #FF8000">/**
             * Une erreur est survenue, aussi, le message d'erreur est affiché et le rollback est appelé.
             */
            </span><span style="color: #007700">echo </span><span style="color: #0000BB">cubrid_error_msg</span><span style="color: #007700">();
            </span><span style="color: #0000BB">cubrid_rollback</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);
        }
        </span><span style="color: #0000BB">cubrid_disconnect</span><span style="color: #007700">(</span><span style="color: #0000BB">$cubrid_con</span><span style="color: #007700">);
    </span><span style="color: #0000BB">?&gt;
</span>    &lt;/body&gt;
    &lt;/html&gt;</code></pre></div>
  </div>

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