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

PHP & Base de données Discussion :

[SQL] Insertion données dans SQL


Sujet :

PHP & Base de données

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mars 2008
    Messages : 229
    Points : 207
    Points
    207
    Par défaut [SQL] Insertion données dans SQL
    Bonjour,

    Comme vous vous en doutez surement, j'ai un problème. Je suis débutant donc j'attends plus des explications qu'un résultat.

    Après avoir récupéré un fichier, l'avoir parsé, je récupère des données "brutes" ue j'aimerais insérer dans ma base sql.

    Mon code qui récupère et parse le HTML :
    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
     
    	Function recup_code($url_log){
            $file = fopen($url_log,"r");
            if(!$url_log){
    			exit ('marche po');
    		}
     
    		$line ="";
            while(!feof($file)){
    			$line .= fgets($file);
    		}
    		fclose($file);
            return $line;
    	}
            if(isset($_POST['stats'])){
     
    		$url = $_POST['url'];
    		$login = $_POST['nom'];
    		$mdp = $_POST['mdp'];
     
    		$url = str_replace("http://","",$url);
    		$url_log = substr_replace($url,'http://'.$login.':'.$mdp.'@', 0, 0);
     
    		//ajout un / si répertoire à ouvrir
    		//$url_log = $url_log."/";
     
    		$code = recup_code($url_log);
     
    		if(empty($code)){
    			echo "<p>Impossible d'ouvrir le fichier</p>.\n";
    			exit;
    		}
    		else{
    			$code = explode ('<A NAME="TOPREFS"></A>', $code);
    			$code = explode ('<A NAME="TOPSEARCH"></A>', $code[1]);
    			$code = explode ('</TH>',$code[0]);
     
    			//insertion du caractère qui servira de séparateur pour le prochain explode
    			$code2  = str_replace ('<TD','¤<TD',$code[count($code)-2]);
     
    			//Supprime les balises HTML
    			$code2 = strip_tags($code2);
    			$code = explode ('¤',$code2);
     
    			for($i=0;$i<count($code);$i++){
    				if($i%2==0){
    					echo $code[$i]."¤";
    				}
    			}
     
    		}
    Les données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    14534
    http://www.google.fr/search
     
    5024
    http://www.leguide.com/sb/leguide/recherche/str_MotCle/Surjeteuse/org/3/t/1/5050803.htm
    J'aimerai les classer par couple hits:url pour pouvoir les insérer dans ma table.

    Merci d'avance.

    PS : si possible, ne donnez pas de script tout fait, j'ai cherché sans trouver mais je souhaite comprendre. merci

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Citation Envoyé par Enhide Voir le message
    J'aimerai les classer par couple hits:url pour pouvoir les insérer dans ma table.
    Classer des données dans une table n'a pas vraiment de sens.
    En plus, si tu ajoutes des données plus tard, ton classement est fichu donc en gros ça ne sert à rien.

    Ce sont les index sur la table qui te permettront d'extraire des données classées.

    Donc ne t'embête pas à classer avant d'envoyer les données vers la table.
    Envoie-les brut, l'index se fera tout seul.

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mars 2008
    Messages : 229
    Points : 207
    Points
    207
    Par défaut
    Par classer je n'entendais pas classer dans un quelconque ordre.

    J'ai une table avec deux colonne, je veux simplement rentrer mes données dans cette table.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE `stats_ref` (
      `hits` int(11) NOT NULL default '0',
      `url` varchar(255) NOT NULL default '',
      PRIMARY KEY  (`url`)
    Où bien sûr :

    hits =>14534
    url =>http://www.google.fr/search

    Merci pour cette réponse si rapide.

  4. #4
    Membre régulier Avatar de MikeV
    Profil pro
    Webmaster
    Inscrit en
    Mai 2007
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : Canada

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2007
    Messages : 93
    Points : 86
    Points
    86
    Par défaut
    Est-ce que tu as un message d'erreur ?

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mars 2008
    Messages : 229
    Points : 207
    Points
    207
    Par défaut
    Je n'ai pas de message d'erreur puisque je cherche encore comment le faire.

    Tout le code que j'ai fournis fonctionne parfaitement.

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mars 2008
    Messages : 229
    Points : 207
    Points
    207
    Par défaut
    Merci à ceux qui ont répondu mais j'ai fini par trouver : disons que mon colocataire m'énerve un peu, il a le don pour prendre le code que je galère à faire et à me le remplacer par deux lignes qui fonctionnent mieux que toute ma fonction

    Mais ça va, il m'explique en même temps

    Bon, sinon, voilà la solution :

    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
    	if(isset($_POST['stats'])){
     
    		$url = $_POST['url'];
    		$login = $_POST['nom'];
    		$mdp = $_POST['mdp'];
     
    		$url = str_replace("http://","",$url);
    		$url_log = substr_replace($url,'http://'.$login.':'.$mdp.'@', 0, 0);
     
    		//ajout un / si répertoire à ouvrir
    		//$url_log = $url_log."/";
     
    		$code = recup_code($url_log);
     
    		if(empty($code)){
    			echo "<p>Impossible d'ouvrir le fichier</p>.\n";
    			exit;
    		}
    		else{
    			$code = explode ('<A NAME="TOPREFS"></A>', $code);
    			$code = explode ('<A NAME="TOPSEARCH"></A>', $code[1]);
    			$code = explode ('</TH>',$code[0]);
     
    			//insertion du caractère qui servira de séparateur pour le prochaine explode
    			$code2  = str_replace ('<TD','¤<TD',$code[count($code)-2]);
     
    			//Supprime les balises HTML
    			$code2 = strip_tags($code2);
    			$code = explode ('¤',$code2);
    			print_r ($code);
    			for($i=2;$i<count($code);$i=$i+4){
    				mysql_query("INSERT INTO stats_ref VALUES('".$code[$i-1]."','".$code[$i+2]."','".$code[$i]."') ON DUPLICATE KEY UPDATE hits=".$code[$i].",url='".$code[$i+2]."'");
    				echo mysql_error();
    	        }
    		}
     
    	}

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Problème insertion et modification données dans SQL Server CE
    Par Lucas Panny dans le forum Accès aux données
    Réponses: 15
    Dernier message: 09/08/2011, 09h47
  2. Réponses: 1
    Dernier message: 17/09/2008, 13h40
  3. [VS 2005]Insertion données dans SQL Express de Visual Studio
    Par D4rkTiger dans le forum Accès aux données
    Réponses: 1
    Dernier message: 06/09/2007, 09h27
  4. [SQL] Insertion multiple dans base de donnée
    Par leroidje dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 03/08/2007, 13h24
  5. [SQL] Pb d'insertion donnée dans table, pb requête SQL
    Par PuppeT mAsTer dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 03/07/2006, 11h26

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