-
Vaya … apostaba a que esa sería la solución.
Cuando me pasan estas cosas sin sentido lo que hago es mostrar el contendio de las variables. En tu caso con un echo $query podras ver el texto exacto de la query que se intenta ejecutar sin exito.
Si sigues sin detectar nada raro con la cadena devuelta, prueba a copiarla y ejecutarla directamente en phpmyadmin, y ver si desde allí te da una definición mas clara del error de mysql que se produce.
Por ultimo si hasta sigues sin pistas … prueba a hacer esa insercion en phpmyadmin desde la opción insertar registro y compara la cadena que genera la aplicacion (siempre es valida) con la que estas usando. Compara las diferencias y comentanos. -
INSERT INTO entradas (fecha, hora, '01') VALUES ('24-11-2004','4','1') es la consulta ejecutada (con las comillas simples en $sala), y tanto en phpMyAdmin como en MySQL-Front los errores devueltos son siempre el mismo:
You have an error in your SQL syntax near '01) VALUES ('24-11-2004','4','1')' at line 1
o bien si pongo las comillas a $salas:
You have an error in your SQL syntax near ''01') VALUES ('24-11-2004','4','1')' at line 1Ahora bien, phpMyAdmin suelta un numero de error que consultado en la pagina de error hadling de mysql.com es:
Error: 1046 SQLSTATE: 3D000 (ER_NO_DB_ERROR) Message: No database selectedo lo que es lo mismo, que no selecciona la base de datos entradas, pero ¿porque?
-
Bufffff … no me di cuenta de algo ... :vayatela: ... el formato de la fecha no es el correcto ... en mysql es "YYYY-MM-DD" y no 'DD-MM-YYYY' como lo tienes en tu consulta. :sisi:
A ver si con eso terminamos con el problema ... espero
-
tranqui, la columna fecha esta definida como char, no como date, asi que ese no puede ser el problema
-
Prueba a poner:
$query = "INSERT INTO entradas ( fecha, hora, 01) VALUES
('$fecha','$hora','$entradas')";A ver si así lo pilla y por lo menos aislamos el problema.
Otra cosa. Está permitido que el nombre de un campo sean solo números?? Yo nunca lo he probado pero puede ser que no te permita que un campo se llame "01".
-
Otra cosa. Está permitido que el nombre de un campo sean solo números?? Yo nunca lo he probado pero puede ser que no te permita que un campo se llame "01".
Si Vallekano, es valido … siempre que mysql lo entienda como texto ... por eso lo de las comillas. Yo he usado una campo que se llamaba 360 (para un campo que almacenaba nombres de imagenes 360º) y solo me dio problemas cuando intente llamarlo en las consultas como 360 y no '360'.
El problemilla se esta poniendo peliagudo. Si desde Mysql te da el mismo error, la consulta es erronea. Prueba lo que te dije ... inserta un registro con esos valores en phpmyadmin (previa seleccion de la BD) y observa la consulta que genera y comparala con la tuya.
Nos tiene intrigados. :susto:
-
Haciendo una insercion desde phpMyAdmin como me aconsejaste he logrado solucionarlo, ahora inserta el registro perfectamente :vayatela:
La linea ha quedado tal que asi:
$query = "INSERT INTOentradas
(fecha
,hora
,$sala
) VALUES ( '$fecha', '$hora', '$entradas' )";
que comparada a la primera consulta:
$query = "INSERT INTO entradas ( fecha, hora, $sala ) VALUES
('$fecha','$hora','$entradas')";solo difiere del tipo de comillas :rolleyes: la verdad que no lo entiendo, pero si funciona, como dice el dicho, NO LO TOQUES xD
-
Si, el phpmyadmin este pone las comillas esas raras (apostrofes,no?), pero debería de funcionar con las comillas simples de to la vida. Vamos, yo siempre uso las comillas simples.
Sea como sea, me alegro de que esté solucionado.
-
Me alegro de que ya funcione. :sisi:
Como dice Vallekano el tipo de comillas no debe suponer una diferencia, así que no entiendo demasiado bien el problema.
Pero ya sabes … en estos casos "de locos"... conviene copiar la forma en que el propio phpmyadmin hace la consulta :risitas: .
-
weno, yo no se si estoy mu desfasao en esto, pero le veo unos cuantos errores no?? yo creo que si estás en php lo normal seria
$query= mysql_query ('INSERT INTO tabla VALUES (' ', , ' ',' $CONEX)las comillas dobles no son aconsejables, y debemos insertar valores en todos los campos, aunque vayan vacíos, eske no se pueden hacer inserciones selectivas de campos salteados…
-
No, hay te equivocas.
Tu puedes hacer una inserción en algunos campos solo, siempre y cuando el resto de campos tengan un valor predefinido, o permitan valores nulos.
Por ejemplo lo normal es tener un campo que sea el "ID" de la tabla, y dicho campo se define como clave y que se auto incremente. En ese campo nunca insertarás un valor poruq no sabes cual toca, pero si está definido así MySQL inserta automáticamente el siguiente numerito.
Pues igual con el resto de campos.
Y porque dices que las comillas dobles no son aconsejables???
Además en tu caso daría un error porque te va a tomar varias cadenas:
$query= mysql_query ('INSERT INTO tabla VALUES (' ', , ' ',' $CONEX)- 'INSERT INTO tabla VALUES ('
- ', , '
- ','
- $CONEX)
Pero que no están concatenadas asique se va a hacer la picha un lio.
Creo que no es que estés desfasado, esque o no sabes o no te acuerdas xDxD
-
ke yo no se php??? el ke se está ekivocando eres tú
1.- Siempre tienes ke insertar todos los campos, y si alguno no te interesan los tienes ke insertar vacíos (siempre ke en la tabla te permitan los nulls)
2.- Las ' ', y eso lo he puesto como demostración, indicando que cuando introduzcamos caracteres hay ke poner ' ' y cuando sean datos enteros o float no se pone nada.
3.- Totalmente prohibido comillas dobles cuando programemos html y php mixto. Porque, dirás tu???
Pues porque cuando estamos en php y abrimos html, debemos poner echo" …..................."; Y si nosotros en php abrimos comillas "", este se va a creer ke lo ke va después es código html cuando no lo va a ser... hombre pofavó!!!jeje -
y ademas, ese nota creo ke se está ekivocando porke kiere insertar en el campo $sala un valor, y un campo ke sea variable sala no lo veo yo mu bien eso, no sé…
-
Pues lo había dicho de coña pero ahora si que pienso que no tienes ni pajolera idea. O esque no nos entendemos.
1.- Siempre tienes ke insertar todos los campos, y si alguno no te interesan los tienes ke insertar vacíos (siempre ke en la tabla te permitan los nulls)
Entonces como insertas las claves que son por ejemplo un entero?? Lees el último registro y luego insertas sumandole uno??
….............. sin comentarios. Solo te digo una cosa: http://www.php.net/3.- Totalmente prohibido comillas dobles cuando programemos html y php mixto. Porque, dirás tu??? Pues porque cuando estamos en php y abrimos html, debemos poner echo" …..................."; Y si nosotros en php abrimos comillas "", este se va a creer ke lo ke va después es código html cuando no lo va a ser... hombre pofavó!!!jeje
entonces no puedo poner en php?:
$micadena = "En un lugar de la mancha"; echo $micadena;
Eh??? No puedo poner eso???
Yo lo que creo es que no sabes bien como funciona el php. PHP no "piensa" que es HTML y que no. PHP procesa todo el código y envía el texto resultante de ese proceso, que puede HTML, una hoja excel, o lo que te de la gana.
Ádemás, nada de lo que haya entre lo va a tomar como HTML. Todo lo que valla ahí en medio es código PHP. Otra cosa es el resultado que de ese código.
Y no seas tan chulito por favor, que creo que en ningún momento me he puesto de esa manera. Que ya he visto un par de post tuyos que escribes de una manera que parece que te crees el que más sabes y no es así. Ni tu, ni yo ni nadie. Hay que hablar con más humildad.
-
y ademas, ese nota creo ke se está ekivocando porke kiere insertar en el campo $sala un valor, y un campo ke sea variable sala no lo veo yo mu bien eso, no sé…
Pues si te leyeses el post verías que al final le ha funcionado asique ese nota , como tu dices, no estaría haciendo algo tan mal echo.
-
weno weno, amo a relajanno, si he paresio chulito, perdon, anke sea mi forma de escribir pero hay ke adaptarla
y eso, eske amo a ve, yo eske no se que estais usando para programar, pero desde luego si usamos la combinación php y mysql, las consultas son así, mas ke na porke yo las pruebo y funcionan.
Los campos ke tu dices autonumericos, depende de los tipos de tabla ke tengamos definios, se tragará una forma u otra de insertarlos. Pero desde luego, en una tabla siempre debemos (recomendablemente) insertar los campos, y los ke no keramos, dejarlos en blanco, siempre ke la tabla tenga esos campos ke permitan valores por defecto o valores nulos, y eso no me puedes decir ke estoy ekivocao porke está comprobao. Además, yo digo el nota por decir el chaval de antes, es dialecto andalú embrutesio jeje! ke eso, ah, otra cosa ke no veo (ke no kiero con esto decir ke este mal) es
$query= 'Insert yo no se ké'
cuando kieras realizar funciones query sobre una tabla debemos poner
$query= mysql_query ('INSERT TA TA TA TA TA') NO??? (sin ánimo de ofender, solamente preguntando para mi informacion)
y lo de las comillas es asi por ejemplo
echo "el resultado es:";
$resul=mysql_query ("select * from …...... ", $conex) esas comillas dobles van a crear conflictos, lo mejor es ponerlas simples y kitarse de problemas, digo yo no?? (y repito, siento el tono de antes)
Gracias -
perdon, rectifico, he estao mirando unos php ke hice pa un instituto y es cierto
case 'FUTBITO': case 'BALONCESTO': case 'VOLEIBOL':
{
echo "<title>DEPORTES DE EQUIPO</title><center>ENFRENTAMIENTOS DE ".$deportes;
echo "</center>
";
$resul=mysql_query("select distinct encuentros.Equipo1, encuentros.Equipo2, encuentros.Marcador_del_1, encuentros.Marcador_del_2, encuentros.CodCat, encuentros.Deporte
from encuentros, equipos, categorias, deportes
where encuentros.Deporte='$deportes' and encuentros.CodCat='$categoria'
and encuentros.Equipo1=equipos.Nombreequipo
and encuentros.CodCat=categorias.CodCat
and encuentros.Deporte=deportes.CodigoDeporte",$link);
echo "";
LAS COMILLAS DOBLES FUNCIONAN para echo ""; y para php ahí arriba podemos ver ke se combinan todo dentro de un case y funciona
uy uy, hay ke repasar más los apuntes de vé en cuando ninchi…
perdon| Equipo Local | Equipo visitante | Marcador Local | Marcador Visitante | Categoría | **
<center>Deporte</center>
** |
-
Bueno bueno, pare que al final reculas algo y nos ponemos de acuerdo. Asique paso de comentar nada más.
Solo un consejo:
Cuando vas a escribir mucho código con un "echo". Como tienes echo un par de veces en tu código, es mejor cerrar el php, ponerlo comocódigo HTML normal y luego volver a abrir. Osea:en vez de:
echo $mivariable1."jshfka sfhasd fhask dhfksjad fhksaj dfhksjda fksadh fkjshda fkhds fksa".$mivariable2;
?>Poner:
jshfka sfhasd fhask dhfksjad fhksaj dfhksjda fksadh fkjshda fkhds fksa
Así el servidor tiene que procesar mucho menos código y ganas dos cosas:
1. El servidor se carga menos.
2. El código HTML resultante se genera antes y va todo más rápido.Es solo un consejo.
-
pues eso no lo sabía…pero si, ara ke lo dices, se ve...lo ke pasa es ke es un poco más comodo ponerlo todo dentro de un echo "" ke tener ke abrir y cerrar scripts no? (tó es por flojera, ves, jeje)
pero ke eso, yo el único fallo ke le veía a la consulta de nittaku es ke kería insertar un valor en un nombre de campo que era $sala (y creo ke una variable no puede ir como nombre de campo) además, eske antes estaba confundío entre hacer consultas con php y hacer consultas con el editor mysql por eso era lo de las comillas, jo, ke paranoya mas mala,
weno, po de colegueo entonce no?
enga -
weno, po de colegueo entonce no?
Si hombre, no soy rencoroso, pero esque últimamente estoy un poco quemadito con el tema foros. No por este en especial, si por otros en particular xD, pero esque hay mucho listillo por ahí suelto. Al igual que hay mucho niñato. Y no digo que seas ninguna de las dos cosas, pero hay comentarios o ciertas formas de hablar de la gente que me comen por dentro.