IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

[Tableaux] iterator et class


Sujet :

Langage PHP

  1. #41
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    1 027
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 1 027
    Points : 1 164
    Points
    1 164
    Par défaut
    C'et ce que j'essaie de faire

    - connection/deconnection
    - select
    - update/delete
    - get et set autocommit
    - begin transaction
    - commit/rollback/savepoint
    - execution de procedure
    - preparation de requete paramétrable
    Sa j'ai envie de dire que c'est que de la ligne à pondre, donc sa me fait pas bien peur (sauf peut être le dernier lol, qu'entends tu par la ?).

    - Des dérivées qui implémente comme il faut.
    - Utilisation des patterns factory et singleton
    C'est surtout ces deux points la que j'ai envie de bien réaliser, car quelque part c'est le plus interessant et le plus important.

    Pour le moment ce que j'ai fait à l'air de rouler, j'en posterais une copie quand j'aurais un peu avancé.


    Meci encore !

    bye

    A la limite, tu te fais un fichier d'init (format que tu veux)
    N'aurais tu pas été un peu marqué par ce thread ?
    http://www.developpez.net/forums/viewtopic.php?t=435752

  2. #42
    Expert confirmé
    Avatar de siddh
    Inscrit en
    Novembre 2005
    Messages
    3 868
    Détails du profil
    Informations personnelles :
    Âge : 48

    Informations forums :
    Inscription : Novembre 2005
    Messages : 3 868
    Points : 5 011
    Points
    5 011
    Par défaut
    pour le "format que tu veux",
    oui, autant utiliser xml et un htaccess a mon avis mais bon ...


    les requetes parametrables, c est une requete que tu ne construit pas dynamiquement mais avec des variables deja définies, c est pratique quand tu doit reutiliser souvent une meme requete avec des arguments différents.

    En gros, tu "prepare" une requete en faisant un truc comme ca :
    SELECT * FROM matable WHERE unchamp=:1 AND unautrechamp=:2
    et quand tu appel l'execution tu lui passe les paramètres qui iront se placer dans l'ordre ou tu les passe.

    Tu peux trouver ça sous l'appellation prepared statement ou prepared query.

  3. #43
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    1 027
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 1 027
    Points : 1 164
    Points
    1 164
    Par défaut
    Tu peux trouver ça sous l'appellation prepared statement ou prepared query.
    Sa n'aurait pas de rapport avec les procédures stockées ?
    Sinon je regarderais cela demain !

    Autrement je te postes, jeff_!, la version de ce que j'ai réalisé pour le moment avec l'idée du resultsets.


    Usage :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
    <?php
    include("include.sql-class.php");
     
    $Connection = new SqlConnection("Mysql");
    $Connection->Host       = "localhost";
    $Connection->User       = "root";
    $Connection->Password   = "";
    $Connection->Open();
    $Connection->SelectDb("test");
     
    $SqlCommand = $Connection->GetNewCommand();
    $Results = $SqlCommand->ExecuteQuery("SELECT * FROM `celko1in10`");
     
    echo $Results->Count();
    echo "<br/>";
    echo "<br/>";
    while( $res = $Results->Next("ASSOC") )
    {
        var_dump($res);
        echo "<br/>";
        echo "<br/>";
    }
     
    $Results = $SqlCommand->ExecuteNonQuery("INSERT INTO `celko1in10` ( `LaClef` ) VALUES ('15');");
     
    echo "<br/>";
    echo "<br/>";
    echo $Results->AffectedRows();
    echo "<br/>";
    echo $Results->InsertedId();
     
    $Connection->Close();
    ?>

    Version Mysql de ISqlCommand
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
     
    <?php
     
    /*
        Implémentation mysql de ISqlCommand
    */
    class MysqlCommand implements ISqlCommand{
     
        private $MysqlLink;
     
        public function __construct( $MysqlLink )
        {
            $this->MysqlLink = NULL;
     
            if(is_resource($MysqlLink))
            {
                $this->MysqlLink = $MysqlLink;
            }
            else
            {
                throw new Exception("L'argument fourni n'est pas une ressource !");
            }
        }
     
        public function ExecuteQuery( $sqlCommand )
        {
            $query = @mysql_query($sqlCommand , $this->MysqlLink);
            if( $query != false )
            {
                return new MysqlQueryResults($query);
            }
            else
            {
                throw new Exception( mysql_errno($this->MysqlLink) . ": " . mysql_error($this->MysqlLink) );
            }
        }
     
        public function ExecuteNonQuery( $sqlCommand )
        {
            $query = @mysql_query($sqlCommand , $this->MysqlLink);
            if( $query != false )
            {
                return new MysqlNonQueryResults($this->MysqlLink);
            }
            else
            {
                throw new Exception( mysql_errno($this->MysqlLink) . ": " . mysql_error($this->MysqlLink) );
            }
        }
     
        public function Protect( $value )
        {
            if( is_array($value) )
            {
                foreach($value as $Key => $val )
                {
                    $value[$Key] = Protect($val);
                }
            }
            elseif(is_object($value))
            {
                foreach($value as $Key => $val )
                {
                    $value->$Key = Protect($val);
                }
            }
            else
            {
               if (get_magic_quotes_gpc())
               {
                 $value = stripslashes($value);
               }
     
               if (!is_numeric($value))
               {
                 $value = mysql_real_escape_string($value);
               }
            }
            return $value;
        }
    }
    ?>
    Et pour faire court, la classe qui equivaut au resultSets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
     
    <?php
     
    class MysqlQueryResults implements ISqlQueryResults
    {
     
        private $Query_;
     
        public function __construct( $query )
        {
            $this->Query = false;
            if( is_resource($query) )
            {
                $this->Query_ = $query;
            }
            else
            {
                throw new Exception("L'argument fourni n'est pas une ressource !");
            }
        }
     
        public function Next($type = "ASSOC")
        {
            switch($type)
            {
                case "ASSOC":
                    $res = mysql_fetch_array($this->Query_ ,MYSQL_ASSOC);
                break;
                case "NUM":
                    $res = mysql_fetch_array($this->Query_ , MYSQL_NUM);
                break;
                case "OBJECT":
                    $res = mysql_fetch_object($this->Query_);
                break;
                default:
                    $res = mysql_fetch_array($this->Query_ , MYSQL_BOTH);
                break;
            }
            if( $res == false )
            {
                @mysql_free_result($this->Query_);
                return false;
            }
     
            return $res;
        }
     
        public function Count()
        {
            if($this->Query_ != false)
            {
                return mysql_num_rows($this->Query_);
            }
            return -1;
        }
     
        public function __destruct()
        {
            @mysql_free_result($this->Query_);
            unset($this->Query_);
        }
    }
    ?>
    voila, j'espère que cela t'inspirera et t'aidera pour ta version !

    bye

  4. #44
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    882
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 882
    Points : 691
    Points
    691
    Par défaut
    pour la colorisation syntaxique il suffit
    de se rendre a l'adresse suivante http://www.decabodi.com/bbcode.php

    c'est quand meme dommage que ce forum n'en possede
    pas

Discussions similaires

  1. rendre iterable une Classe contenant un tableau 2D
    Par Linschn dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 13/05/2009, 22h42
  2. Réponses: 3
    Dernier message: 12/06/2008, 17h05
  3. Tableaux d'une Classe
    Par demcoul dans le forum Langage
    Réponses: 2
    Dernier message: 29/11/2007, 21h01
  4. [Tableaux] problème en classe
    Par jamjam19 dans le forum Langage
    Réponses: 2
    Dernier message: 19/04/2007, 22h20
  5. [Tableaux] Utilisations de classes
    Par hudony dans le forum Langage
    Réponses: 8
    Dernier message: 31/12/2006, 19h12

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo