Précédent   Forum du club des développeurs et IT Pro > 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
 
Outils de la discussion
Publicité
'
Vieux 07/10/2011, 08h24   #1
thecanea
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 129
Détails du profil
Informations personnelles :
Âge : 25
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 129
Points : 73
Points : 73
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
stealth35
Modérateur
 
Inscription : septembre 2010
Messages : 7 958
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 958
Points : 9 508
Points : 9 508
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
thecanea
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 129
Détails du profil
Informations personnelles :
Âge : 25
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 129
Points : 73
Points : 73
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
stealth35
Modérateur
 
Inscription : septembre 2010
Messages : 7 958
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 958
Points : 9 508
Points : 9 508
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
thecanea
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 129
Détails du profil
Informations personnelles :
Âge : 25
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 129
Points : 73
Points : 73
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
stealth35
Modérateur
 
Inscription : septembre 2010
Messages : 7 958
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 958
Points : 9 508
Points : 9 508
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
thecanea
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 129
Détails du profil
Informations personnelles :
Âge : 25
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 129
Points : 73
Points : 73
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
thecanea
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 129
Détails du profil
Informations personnelles :
Âge : 25
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 129
Points : 73
Points : 73
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
stealth35
Modérateur
 
Inscription : septembre 2010
Messages : 7 958
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 958
Points : 9 508
Points : 9 508
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
thecanea
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 129
Détails du profil
Informations personnelles :
Âge : 25
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 129
Points : 73
Points : 73
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
thecanea
Membre régulier
 
Avatar de thecanea
 
Inscription : octobre 2008
Messages : 129
Détails du profil
Informations personnelles :
Âge : 25
Localisation : France, Côte d'Or (Bourgogne)

Informations forums :
Inscription : octobre 2008
Messages : 129
Points : 73
Points : 73
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 Cette discussion est résolue.
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 12h32.


 
 
 
 
Partenaires

Hébergement Web