PHP
downloads | documentation | faq | getting help | mailing lists | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

dbx_close> <dbmreplace
Last updated: Sun, 25 Nov 2007

view this page in

dbx függvények

Bevezetés

A dbx modul adatbázis-kezelő absztrakciós réteg, ahol az X jelenti a támogatott adatbáziskezelőket. A dbx függvényekkel azonos hívási konvenciót használva lehet elérni a támogatott adatbázisok mindegyikét. A dbx függvények önmagukban nem kommunikálnak az adatbázis-kiszolgálókkal, csak az őket támogató modulokkal/kiterjesztésekkel.

Követelmények

Annak érdekében, hogy ezeket a függvényeket használni lehessen,a be kell tölteni a dbx támogatást vagy hozzá kell linkelni a PHP-t. Jelenleg az alábbi adatbáziskezelőket támogatja a dbx:

Arról, hogyan kell új adatbázis támogatást implementálni a dbx modulba » http://www.guidance.nl/php/dbx/doc/ címen találsz leírást.

Telepítés

Annak érdekében, hogy ezeket a függvényeket használni lehessen,a PHP-t dbx támogatással - az --enable-dbx kapcsoló - és minden használni kívánt adatbázisnak megfelelő kiterjesztéssel kell fordítani, azaz MySQL esetén --with-mysql kapcsolót is meg kell adni.

Futásidejű beállítások

Ez a kiterjesztés semmilyen konfigurációs beállításokat nem definiál a php.ini állományban.

Erőforrás típusok

Két erőforrástípust használ a dbx kiterjesztés (egy - egy object típusút): az egyik az adatbázis-kapcsolat leíró, a másik az eredményhalmaz kezeléséhez szükséges .

Előre definiált állandók

Az itt listázott állandókat ez a kiterjesztés definiálja, és csak akkor elérhetőek, ha az adott kiterjesztés be van fordítva a PHP-be, vagy dinamikusan betöltött.

DBX_MYSQL (integer)
DBX_ODBC (integer)
DBX_PGSQL (integer)
DBX_MSSQL (integer)
DBX_FBSQL (integer)
DBX_OCI8 (integer) (available from PHP 4.3.0)
DBX_SYBASECT (integer)
DBX_SQLITE (integer) (PHP 5)
DBX_PERSISTENT (integer)
DBX_RESULT_INFO (integer)
DBX_RESULT_INDEX (integer)
DBX_RESULT_ASSOC (integer)
DBX_RESULT_UNBUFFERED (integer) (PHP 5)
DBX_COLNAMES_UNCHANGED (integer) (available from PHP 4.3.0)
DBX_COLNAMES_UPPERCASE (integer) (available from PHP 4.3.0)
DBX_COLNAMES_LOWERCASE (integer) (available from PHP 4.3.0)
DBX_CMP_NATIVE (integer)
DBX_CMP_TEXT (integer)
DBX_CMP_NUMBER (integer)
DBX_CMP_ASC (integer)
DBX_CMP_DESC (integer)

Table of Contents

  • dbx_close — lezárja a nyitott adatbázis-kapcsolatot
  • dbx_compare — összehasonlít két sort rendezés céljából
  • dbx_connect — kapcsolódik egy adatbázishoz
  • dbx_error — visszaadja a modulban történt legutolsó hibát (nem feltétlenül a kapcsolathoz kötödő hibát)
  • dbx_escape_string — Escape a string so it can safely be used in an sql-statement
  • dbx_fetch_row — Fetches rows from a query-result that had the DBX_RESULT_UNBUFFERED flag set
  • dbx_query — végrehajt egy lekérdezést és visszaadja a teljes végeredményt (ha van)
  • dbx_sort — dbx_query által visszaadott eredményhalmazt rendezi tetszőleges függvény segítségével


dbx_close> <dbmreplace
Last updated: Sun, 25 Nov 2007
 
add a note add a note User Contributed Notes
dbx
bart at mediawave dot nl
08-Jul-2004 09:45
Simple function for returning paged result sets.

<?php
// use: pagedQuery($link, $sql, $rows_per_page, $current_page)

function pagedQuery($link, $sql, $nrows = 10, $page = 1) {
   
$handle = dbx_query($link, $sql, DBX_RESULT_UNBUFFERED);
   
$result = new stdClass;
   
$result->link = $this->link;
   
$result->page = $page;
   
$result->data = array();
   
$result->info['name'] = array();
   
$start = ($page - 1) * $nrows;
   
$end = $start + $nrows;
   
$result->rows = 0;
    while (
$row = dbx_fetch_row($handle)) {
       
$result->rows++;
        if ((
$result->rows > $start) && ($result->rows <= $end)) {
           
$result->data[] = $row;           
        }
    }
    if (
$result->data[0]) {
       
$result->cols = count($result->data[0]) / 2;
       
$result->info['name'] = array_slice(array_keys($result->data[0]), $result->cols, $result->cols);
       
$result->lastPage = ceil($result->rows / $nrows);
    }
    return
$result;
}
?>
bart at mediawave dot nl
01-Jul-2004 11:12
Would like to confirm that dbx is at least three times faster than adodb with my application. However, once loaded, adodb has much more features and probably performs better in some situations then dbx.

One of the nice features that adodb has, is the way you can quickly make a dropdown menu from a query. Here's a similar function that works with a dbx result object:

<?php

// $result is the dbx_query result (It expects two fields)
// $name is the name of the dropdown field
// $selected is the option that should be selected
// $firstrow takes a string like "myvalue:myname"
// $attr can be used to add some extra attributes

function dropDown($result, $name, $selected, $firstRow, $attr) {
   
$s = '<select name="'.$name.'" '.$attr.'>';
    if (
is_string($firstRow))  {
       
$row = explode(':', $firstRow);
       
$s .= '<option value="'.$row[0].'">'.$row[1].'</option>';
    } else
       
$s .= '<option></option>';
    foreach (
$result->data as $row) {
        if (
$row[0] == $selected)
           
$s .= '<option value="'.$row[0].'" selected="selected">'.htmlspecialchars($row[1]).'</option>';
        else
           
$s .= '<option value="'.$row[0].'">'.htmlspecialchars($row[1]).'</option>';
    }
    return
$s.'</select>';
}

?>
rhcf at linux dot ime dot usp dot br
25-Nov-2003 04:52
BEWARE!!!

dbx_query allocate all retrieved data in an array on memory. If the query result is big (bigger then the memory_limit on php.ini), the result will be empty. So use dbx wih care.
carl [at] carlthompson [dot] net
07-Jun-2003 04:49
The above benchmark is very misleading. Unfortunately, I found out the hard way by porting my app to ADODB. Most PHP apps are going to be very short-lived therefore startup / setup time is a large factor. This benchmark does not measure that. Just include()ing the main ADODB file added 27ms to my app's startup time! Considering my app took only 16ms to run in total using DBX, the idea of switching to ADODB was DOA before running a single query.

In the end, the total time for my app went from 16ms with DBX to 49ms with ADODB. ADODB's powerful features are obviously not worth that kind of overhead.

Carl Thompson
jlim at natsoft dot com dot my
06-Feb-2003 10:35
For some benchmarks of dbx connecting to mysql compared to native mysql api, adodb, and others, see:
http://phplens.com/lens/adodb/
http://php.weblogs.com/2003/02/06#a2336

dbx_close> <dbmreplace
Last updated: Sun, 25 Nov 2007
 
 
show source | credits | sitemap | contact | advertising | mirror sites