Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD > PHP & PostgreSQL
PHP & PostgreSQL Forum d'entraide sur PostgreSQL avec PHP. Avant de poster -> FAQ PostgreSQL, Cours PostgreSQL. Pour les questions concernant le moteur PostgreSQL plutôt que les fonctions PHP, merci d'utiliser le forum PostgreSQL.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 07/10/2011, 08h24   #1
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 124
Détails du profil
Informations personnelles :
Âge : 24
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 124
Points : 71
Points : 71
Par défaut PDO et fonction postgresql avec curseur

Bonjour,

Serait-il possible d'avoir l'équivalent du code suivant
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function test_refcursor()
{
  pg_query("begin");
  $res1 = pg_query("SELECT fcurs()");
  if ($res1!==false) {
    list($cname) = pg_fetch_array($res1);
    $res2 = pg_query("FETCH ALL IN \"" . $cname . "\"");
    if ($res2!==false) {
      $all = pg_fetch_all($res2);
      print_r($all);
    }
  }
  pg_query("commit");
}
avec l'utilisation de PDO à la place des fonctions pg_*() ?

En vous remerciant par avance pour vos idées, vos remarques,

Cordialement,
Thec
thecanea est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 10h26   #2
Modérateur
 
Inscription : septembre 2010
Messages : 7 131
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 131
Points : 8 491
Points : 8 491
oui c'est possible
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 10h47   #3
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 124
Détails du profil
Informations personnelles :
Âge : 24
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 124
Points : 71
Points : 71
Euh... D'accord, serait-il possible d'avoir un exemple fonctionnel ? Ou des pistes plus en détails.

J'ai déjà fait des tests non concluants, notamment en utilisant les fonctionnalités de beginTransaction() et commit() ou rollback() de PDO, sans succès.

Merci par avance pour les idées ou commentaires constructifs.

Cordialement,
Thec
thecanea est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 11h00   #4
Modérateur
 
Inscription : septembre 2010
Messages : 7 131
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 131
Points : 8 491
Points : 8 491
t’embêtes pas avec tout ca, utilise simplement query, fetch et fetchAll, comme dans ton code, après on pourra optimiser le tout, mais commence par le plus basique
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 11h10   #5
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 124
Détails du profil
Informations personnelles :
Âge : 24
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 124
Points : 71
Points : 71
Ok, je vais simplifier, tester et vous tenir informés.

Mais je pensais que pour utiliser les curseurs sous PG, il fallait forcément être dans une transaction, non ?
thecanea est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 11h32   #6
Modérateur
 
Inscription : septembre 2010
Messages : 7 131
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 131
Points : 8 491
Points : 8 491
Citation:
Envoyé par thecanea Voir le message
Ok, je vais simplifier, tester et vous tenir informés.

Mais je pensais que pour utiliser les curseurs sous PG, il fallait forcément être dans une transaction, non ?
pour le moment utilise juste les mêmes fonctions
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 12h31   #7
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 124
Détails du profil
Informations personnelles :
Âge : 24
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 124
Points : 71
Points : 71
Effectivement, en simplifiant (c'est à dire sans les beginTransaction et commit de PDO), ça a marché.

Il m'a suffit de remplacer les pg_query par des $pdo->query() et pg_fetch_array par $stmt->fetch();

Merci pour la piste, c'est résolu pour moi !
thecanea est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 12h35   #8
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 124
Détails du profil
Informations personnelles :
Âge : 24
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 124
Points : 71
Points : 71
Enfin, résolu, sauf s'il y a mieux à faire

Mon code actuel ressemble à ceci :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
function test_refcursor()
{
    // $pdo mon instance PDO
    $pdo->query('BEGIN;');
    $stmt = $pdo->query("SELECT fcurs()");
    if ($stmt->rowCount()) {
        list($cname) = $stmt->fetch();
        $stmt_q = $pdo->query("FETCH ALL IN \"" . $cname . "\"");
        if ($stmt_q->rowCount()) {
            $all = $stmt_q->fetchAll(PDO::FETCH_ASSOC);
            print_r($all);
        }
    }
    $pdo->query('ROLLBACK;');
}
J'ai lu dans de la documentation sur PDO qu'il était possible d'utiliser les curseurs pour faire de la pagination ? Est-ce un moyen toujours adapté ?
thecanea est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 12h58   #9
Modérateur
 
Inscription : septembre 2010
Messages : 7 131
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 131
Points : 8 491
Points : 8 491
oui tu peux choisir dans quel ordre les résultats seront lu
http://www.php.net/manual/fr/pdostatement.fetch.php

mais ça dépend uniquement du pilote, j'ai pas encore tester sous PG si ça marche
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 13h40   #10
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 124
Détails du profil
Informations personnelles :
Âge : 24
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 124
Points : 71
Points : 71
Oui, j'ai vu qu'on pouvait faire des recherches vers l'avant ou en arrière notamment.

Moi ce que je souhaiterai pouvoir faire, c'est afficher les 10 résultats depuis le 50ème.

Comment avec une requête basée sur une fonction postgresql puis-je appliquer un critère LIMIT ? Ou bien comment appliquer un système plus complexe de curseurs ?

En vous remerciant par avance,
thecanea est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/10/2011, 13h48   #11
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 124
Détails du profil
Informations personnelles :
Âge : 24
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 124
Points : 71
Points : 71
J'ai trouvé !

Tout simple, il suffit de suivre la doc postgresql : http://docs.postgresql.fr/8.3/sql-fetch.html

Si je veux afficher les troisième et quatrième lignes, il me suffit d'ajouter la commande suivante :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
function test_refcursor()
{
    // $pdo mon instance PDO
    $pdo->query('BEGIN;');
    $stmt = $pdo->query("SELECT fcurs()");
    if ($stmt->rowCount()) {
        list($cname) = $stmt->fetch();
        $pdo->query("MOVE ABSOLUTE 2 FROM \"" . $cname . "\"");
        $stmt_q = $pdo->query("FETCH 2 IN \"" . $cname . "\"");
        if ($stmt_q->rowCount()) {
            $all = $stmt_q->fetchAll(PDO::FETCH_ASSOC);
            print_r($all);
        }
    }
    $pdo->query('ROLLBACK;');
}
On obtiendra 2 lignes (fetch 2) depuis la position 2 (move absolute 2).

Merci beaucoup pour les pistes et l'aide à la réflexion, c'est résolu pour moi
thecanea est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h11.


 
 
 
 
Partenaires

Hébergement Web