Php create table avec boucle

Fermé
ca_mouss_un_mouss - 19 juil. 2005 à 11:56
grofwa Messages postés 440 Date d'inscription jeudi 24 juillet 2003 Statut Membre Dernière intervention 21 juillet 2006 - 19 juil. 2005 à 14:47
salut les jsunes,

j'ai crée un formulaire permettant de concevoir une table en recupérant le nombre de champ et le nom de la table par la methode POST. j'arrive sur une seconde page qui permet de concevoir un tableau avec des champs text(un pour le nom(champ), le type, la taille) :

for ($i=1;$i<$nb_champs+1;$i++)
{
echo '<tr><td>Champ';
echo "$i";
echo ' : <input type="text" name="champ'.$i.'"><p></td>';
echo '<td>
<select size="1" name="type'.$i.'">
<option>VARCHAR</option>
<option>TEXT</option>
<option>DATE</option>
<option>INT</option>
<option>FLOAT</option>
</select><p></td>';
echo '<td><input type="text" name="taille'.$i.'"><p></td></tr>';
}
?>

je souhaite ensuite créer la requete permettant de créer la table. Problème!!! une partie est fixe le "CREATE TABLE...." et une partie est dans une boucle le NOMCHAMP TYPE TAILLE car je repete ces trois champs autant de fois que j'ai de champs!! COMMENT GERER LA BOUCLE FOR DANS LA REQUETE ??

est ce possible :

$requete="CREATE TABLE '".$_POST["ma_table"]."'
for ($j=0;$j<$nombre_champ;$j++)
{

suis pas clair dsl:s c dur a expliquer :'(
A voir également:

10 réponses

grofwa Messages postés 440 Date d'inscription jeudi 24 juillet 2003 Statut Membre Dernière intervention 21 juillet 2006 479
19 juil. 2005 à 12:09
Ben oui, c'est l'idée.

Dans ta boucle, tu récupères un à un les champs, concatène avec le type et éventuellement la longueur du champ.

Ca coince où ?

Michael.

0
c'est dans la requete que ca coince dans les boucles
0
grofwa Messages postés 440 Date d'inscription jeudi 24 juillet 2003 Statut Membre Dernière intervention 21 juillet 2006 479
19 juil. 2005 à 13:11
Comprends pas trop où est ton problème...

$requete="CREATE TABLE '".$_POST["ma_table"]." ('
for ($j=0;$j<$nombre_champ;$j++)
{ 
  $requete .= 'champ' . $j . ' ' . $_POST['type' . $j] . ' ' . $_POST['taille' . $j]
}
$requete .= ')'


du moins dans les grandes lignes :-)
0
la partie create table n'est pas dans la boucle mais comment insérer une boucle au milieu d'une requete !!
g create table TABLE1
(champ1, type1, taille1
champ2, type2, taile2..... onc il faut intégrer la boucle for dans la requete pour affichier les champs champ$i, taille $i, type$i!!!

et ca plante :

Parse error: parse error, expecting `T_STRING' or `T_VARIABLE' or `T_NUM_STRING' in f:\projet_admin_prenium\administration_medium\concevoir_table.php on line 18
0
grofwa Messages postés 440 Date d'inscription jeudi 24 juillet 2003 Statut Membre Dernière intervention 21 juillet 2006 479
19 juil. 2005 à 13:22
Ben, fais comme j'ai mis ci-dessus... ta requête, c'est une variable. Tu peux donc la remplir en plusieurs passes au sein d'une boucle.


sinon, fais voir ton code que je jette un coup d'oeil.
0
mouss debute
19 juil. 2005 à 13:26
<?
$table = $_POST['ma_table'];
$nombre_champ = $_POST['nbr_champ'];

include ("connecter.php");
if (!$connexion)
{
echo "Impossible de se connecter a la base de données!!";
}
else if (! mysql_select_db($bdd,$connexion))
{
echo "La selection de la base de données est impossible!";
}
else{
$requete="CREATE TABLE '".$_POST["ma_table"]." ('
for ($j=0;$j<$nombre_champ;$j++)
{
$requete .= 'champ' . $j . ' ' . $_POST['type' . $j] . ' ' . $_POST['taille' . $j]
}
$requete .= ')";

$execute=mysql_query($requete);
}
?>


<body bgcolor="#FF9966">
<table border="0" align="center">
<tr>
<td><hr></td>
</tr>
<tr>
<?echo "<td>Vous venez de créer la table $table</td>";?>
</tr>
<tr>
<td><hr></td>
</tr>

</table>
0
Timon1102 Messages postés 354 Date d'inscription jeudi 2 juin 2005 Statut Membre Dernière intervention 30 décembre 2010 109
19 juil. 2005 à 13:27
amon avis manque un point virgule ici
$requete .= 'champ' . $j . ' ' . $_POST['type' . $j] . ' ' . $_POST['taille' . $j] 
puis met un espace avant champ sinon les mots vont etre collés
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
grofwa Messages postés 440 Date d'inscription jeudi 24 juillet 2003 Statut Membre Dernière intervention 21 juillet 2006 479
19 juil. 2005 à 13:30
Ouais bon, c'est une histoire de ' et "...

$requete="CREATE TABLE '".$_POST["ma_table"]." ("
for ($j=0;$j<$nombre_champ;$j++)
{
$requete .= 'champ' . $j . ' ' . $_POST['type' . $j] . ' ' . $_POST['taille' . $j]
}
$requete .= ")";


corrige deja avec ceci...
0
g un message d erreur :

Parse error: parse error in f:\projet_admin_prenium\administration_medium\concevoir_table.php on line 16

l16 c la ligne du for
0
Timon1102 Messages postés 354 Date d'inscription jeudi 2 juin 2005 Statut Membre Dernière intervention 30 décembre 2010 109
19 juil. 2005 à 13:52
il te manque un ; a la ligne d'avant
0
maintenant gun bug ligne 18 ($requete....)

$requete="CREATE TABLE '".$_POST["ma_table"]." (";
for ($j=0;$j<$nombre_champ;$j++)
{
$requete .= ' . $_POST['champ' . $j] . ' ' . $_POST['type' . $j] . ' ' . $_POST['taille' . $j];
}
$requete .= ")";
}
0
Timon1102 Messages postés 354 Date d'inscription jeudi 2 juin 2005 Statut Membre Dernière intervention 30 décembre 2010 109
19 juil. 2005 à 14:19
$requete .= ' '. $_POST['champ' . $j] ...
0
djbenvik Messages postés 7 Date d'inscription samedi 27 décembre 2003 Statut Membre Dernière intervention 8 août 2006
19 juil. 2005 à 14:30
derniere fois :

Notice: Undefined index: champ0 in f:\projet_admin_prenium\administration_medium\concevoir_table.php on line 18

Notice: Undefined index: type0 in f:\projet_admin_prenium\administration_medium\concevoir_table.php on line 18

Notice: Undefined index: taille0 in f:\projet_admin_prenium\administration_medium\concevoir_table.php on line 18
0
grofwa Messages postés 440 Date d'inscription jeudi 24 juillet 2003 Statut Membre Dernière intervention 21 juillet 2006 479 > djbenvik Messages postés 7 Date d'inscription samedi 27 décembre 2003 Statut Membre Dernière intervention 8 août 2006
19 juil. 2005 à 14:47
commence ton for à 1 au lieu de 0...
0
grofwa Messages postés 440 Date d'inscription jeudi 24 juillet 2003 Statut Membre Dernière intervention 21 juillet 2006 479
19 juil. 2005 à 14:31
dis, mouss, faudrait p'tet que tu fasses un petit effort de debug toi-même, non ?
0
djbenvik Messages postés 7 Date d'inscription samedi 27 décembre 2003 Statut Membre Dernière intervention 8 août 2006
19 juil. 2005 à 14:38
oui sophat il fait nptk!!! on s en occupe!
0