Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
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 05/07/2006, 20h28   #1
Membre du Club
 
Avatar de harlock59
 
Inscription : mars 2005
Messages : 249
Détails du profil
Informations personnelles :
Âge : 31

Informations forums :
Inscription : mars 2005
Messages : 249
Points : 58
Points : 58
Envoyer un message via MSN à harlock59 Envoyer un message via Yahoo à harlock59 Envoyer un message via Skype™ à harlock59
Par défaut [envoi mail][enregistr mysql]

bonjour,
je voudrais parcourir une table mysql ne contenant que des champs 'e-mail' (1 seule colonne), et envoyer un mail via la fonction mail de php à tous ces e-mails. si quelqu'un pouvait m'aider ? merci.
__________________
--
Acer Aspire 5315 modifié.
Ubuntu Maverick 10.10 Gnome
harlock59 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/07/2006, 20h50   #2
Membre du Club
 
Avatar de harlock59
 
Inscription : mars 2005
Messages : 249
Détails du profil
Informations personnelles :
Âge : 31

Informations forums :
Inscription : mars 2005
Messages : 249
Points : 58
Points : 58
Envoyer un message via MSN à harlock59 Envoyer un message via Yahoo à harlock59 Envoyer un message via Skype™ à harlock59
je suis allé sur php.net, et ils parlent de al fonction foreach(Array_expresssion as $value)
donc il faudrait que je stocke tous les enregistrements 'e-mail' dans un tableau, mais je ne sais pas trop comment... un mysql fetch array ?
__________________
--
Acer Aspire 5315 modifié.
Ubuntu Maverick 10.10 Gnome
harlock59 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/07/2006, 22h16   #3
Membre du Club
 
Inscription : mai 2003
Messages : 222
Détails du profil
Informations forums :
Inscription : mai 2003
Messages : 222
Points : 67
Points : 67
en gros si j'ai bien compris tu veux faire un newsletter a tous les membres
j'ai fait ca sur mon site
il faut juste extraire les donnees mail dans un tableau puis unfois extraite tu boucle sur mail avec une boucle while et la fonction mail juste en dessus
mail moi si tu n'arrive pas
digger est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/07/2006, 22h34   #4
Membre du Club
 
Avatar de harlock59
 
Inscription : mars 2005
Messages : 249
Détails du profil
Informations personnelles :
Âge : 31

Informations forums :
Inscription : mars 2005
Messages : 249
Points : 58
Points : 58
Envoyer un message via MSN à harlock59 Envoyer un message via Yahoo à harlock59 Envoyer un message via Skype™ à harlock59
j'ai aussi un autre probleme: je veux stocker le texte de la newsletter dans une table ayant comme champs: id, sujet, texte1 à 5
mais lorsque j'insère, il ne prends pas les textes avec des espaces entre les mots... ca m'affiche:
Citation:
Check the manual that corresponds to your MySQL server version for the right syntax to use near 'de diffusion de DB Conseil,un,deux,trois,quatre,cinq' at line 1
voici ma source:
Code :
mysql_query("insert into newsletters (id,sujet,txt1,txt2,txt3,txt4,txt5) values (NULL,".$_POST['sujet'].",".$_POST['texte1'].",".$_POST['texte2'].",".$_POST['texte3'].",".$_POST['texte4'].",".$_POST['texte5']."") OR die (mysql_error());
__________________
--
Acer Aspire 5315 modifié.
Ubuntu Maverick 10.10 Gnome
harlock59 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/07/2006, 23h01   #5
Expert Confirmé Sénior
 
Homme Laurent Willems
Expert Stop/Start
Inscription : septembre 2002
Messages : 2 551
Détails du profil
Informations personnelles :
Nom : Homme Laurent Willems
Âge : 33
Localisation : Belgique

Informations professionnelles :
Activité : Expert Stop/Start

Informations forums :
Inscription : septembre 2002
Messages : 2 551
Points : 4 271
Points : 4 271
Code :
1
2
3
4
5
mysql_query("insert into newsletters (id,sujet,txt1,txt2,txt3,txt4,txt5) values 

(NULL,'".$_POST['sujet']."','".$_POST['texte1']."','".$_POST['texte2']."',

'".$_POST['texte3']."','".$_POST['texte4']."','".$_POST['texte5']."'")) or die (mysql_error());
Il faut également ajouter addslashes() à chaque $_POST

Code :
1
2
 
addslashes($_POST['texte1']) .... etc
Mygale1978 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/07/2006, 09h58   #6
Membre du Club
 
Inscription : mai 2003
Messages : 222
Détails du profil
Informations forums :
Inscription : mai 2003
Messages : 222
Points : 67
Points : 67
Par défaut newsletter

Bon je vais te donner une solution qui marche que j'ai developpe sur mon site perso utilisé chez free pour envoyer en masse la newsletter à les email inscrit dans la table mail

deja en premier tu cree un formulaire HTML avec un champ sujet et un champ message le formulaire pointe sur la page mail.php donc dans ton form action="mail.php"
ensuite
la page mail.php
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
 
<?php
$headers="from:xxxx.xxxx@free.fr"; //ton adresse mail
include("connect.php"); // connexion base de donnée
$req=mysql_query("select email from lettre");// ON liste toute la TABLE lettre
$res=mysql_numrows($req);// ON compte le result
$i=0;
while($i!=$res){
$email=mysql_result($req,$i,"email");
mail($email,$sujet,$message,$headers);//envoi mail
$i++;
}
echo "<h2>Tous les emails ont etes envoyes</h2>";
mysql_close();
?>
digger 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 21h31.


 
 
 
 
Partenaires

Hébergement Web