Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Consultas SQL universales

Estas en el tema de Consultas SQL universales en el foro de PHP en Foros del Web. Hola amigos, Voy a desarrollar una aplicación en la que muchas páginas van a ser iguales en su formato. Por ejemplo habrá una página de ...
  #1 (permalink)  
Antiguo 21/01/2015, 14:59
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Consultas SQL universales

Hola amigos,

Voy a desarrollar una aplicación en la que muchas páginas van a ser iguales en su formato. Por ejemplo habrá una página de clientes donde al pinchar en un cliente se verán los detalles del mismo. Lo mismo se hará por ejemplo con proveedores...

Quisiera no estar programando siempre la misma consulta "SELECT" donde lo único que cambia es el nombre de la tabla y los campos de ella.

Me gustaría programar una función por ejemplo algo así:

funcion select_detalle(clientes,id_cliente)

En la que el valor "clientes" es el nombre de la tabla y el valor "id_cliente" es el Id del registro que quiero mostrar.

Y que esta función haga la consulta y genere las variables con los valores de los campos. Igual sería para los INSERT y los UPDATES.

De esta forma entiendo que en cada formulario no tendría que programar siempre lo mismo, solo es llamar a esta función e imprimir las variables.

El concepto lo tengo claro, pero como hacerlo estoy algo confuso. No sé programar objetos que entiendo sería lo ideal.

Si alguién sabe dond ever un ejemplo de código de esto, le agradezco.

Saludos
  #2 (permalink)  
Antiguo 21/01/2015, 15:13
Avatar de hhs
hhs
Colaborador
 
Fecha de Ingreso: junio-2013
Ubicación: México
Mensajes: 2.995
Antigüedad: 10 años, 10 meses
Puntos: 379
Respuesta: Consultas SQL universales

Lo que quieres hacer ya se a realizado antes de muchas formas. así que dale un vistazo a notORM: http://www.notorm.com/
__________________
Saludos
About me
Laraveles
A class should have only one reason to change.
  #3 (permalink)  
Antiguo 21/01/2015, 15:21
 
Fecha de Ingreso: junio-2014
Mensajes: 18
Antigüedad: 9 años, 10 meses
Puntos: 0
Respuesta: Consultas SQL universales

buenas tardes florenmadrid

Lo que puedes hacer es, en un archivo aparte agregas todas las funciones, por ejemplo un archivo configuración.php y un ejemplo de una función:

Código HTML:
function instruccionSql($sql) {
		include("conectar.php");
		//$vista = mysql_query($sql, $conexion);
		$vista = pg_exec($conexion, $sql);
		if (!$vista) {
			echo"<br><center><font color='red'><b>Error: $sql</b></font><br><br>
            El servidor dice ".pg_last_error();
            exit;
        }
		return $vista;
	}
y cuando necesites utilizarlo debe hacer un include en donde lo requieras asi

include("configuración.php");

y utilizar la función así por ejemplo:

Código HTML:
$cons = instruccionSql($sql_existe);

Espero te sirva!!
  #4 (permalink)  
Antiguo 21/01/2015, 15:43
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Respuesta: Consultas SQL universales

.- hhs, no quiero utilizar librerías. Gracias

.- esteban308, gracias por la respuesta. La idea va por ahí... generar funciones por cada tipo de consulta, osea que con una sola función y cambiando solo los valores de las variables, ejecute la consulta que precise.

Pero sigo sin tener claro como hacer por ejemplo una función para hacer los SELECT de las tablas, modificando solo el nombre de la tabla
  #5 (permalink)  
Antiguo 21/01/2015, 16:00
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Consultas SQL universales

Cita:
.- hhs, no quiero utilizar librerías. Gracias
Bueno, ¿y sería posible que revises el código de alguna de ellas tal vez?

Vamos, que lo que buscas ya se ha solucionado antes, ¿para qué volverlo a hacer?

Cita:
Pero sigo sin tener claro como hacer por ejemplo una función para hacer los SELECT de las tablas, modificando solo el nombre de la tabla
Eso es bien fácil:

Código PHP:
Ver original
  1. function makeSELECT($table, $cols) {
  2.   return "SELECT $cols FROM $table";
  3. }

Y si aún así quieres seguir en la terquedad de "no quiero utilizas librerías" al menos podrías leer el código de alguna librería que haga eso: y aprender de ello.

Si tu no tienes tiempo de utilizar librerías ya existentes entonces nosotros no tenemos tiempo de enseñarte a hacer tus propias librerías sólo porque así lo deseas.

Suerte.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #6 (permalink)  
Antiguo 21/01/2015, 16:13
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Respuesta: Consultas SQL universales

pateketrueke:

Te iba a responder en el mismo tono que tu lo has hecho, pero... paso de ti y del montón de mierda que tienes por cerebro y por educación...
  #7 (permalink)  
Antiguo 21/01/2015, 16:45
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Consultas SQL universales

Cita:
Iniciado por florenmadrid Ver Mensaje
pateketrueke:

Te iba a responder en el mismo tono que tu lo has hecho, pero... paso de ti y del montón de mierda que tienes por cerebro y por educación...
Si necesitas más ideas puedes revisar lo siguiente: https://github.com/pateketrueke/grocery

Es un proyecto que hice hace años, precisamente para lo mismo, si quieres puedes copiar y usar todo el código que necesites de ahí: para que no tengas que escribirlo desde cero.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #8 (permalink)  
Antiguo 22/01/2015, 07:18
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Respuesta: Consultas SQL universales

pateketrueke antes de responder como lo has hecho en tu primera respuesta, no des por hecho nada. Si no quiero utilizar librerias que es lo mas cómodo, alguna razón importante habrá...

Esto es un foro de informática, donde nadie es obligado a responder, y si alguien desea responder o ayudar, no puede hacerlo con reproches... Si no te gusta lo que se consulta, te vas a otro post y resuelto.

Mi consulta ya la resolví ayer con la ayuda de gente de otro foro, donde curiosamente nadie me regañó como si tuviese 15 años y desde luego nadie se atrevió a juzgar mi duda, el que quiso me ayudó y punto.
  #9 (permalink)  
Antiguo 22/01/2015, 07:21
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Respuesta: Consultas SQL universales

Y por cierto, debes de haber sido tu el que ha dado por "solucionado" este post.... Que yo sepa las dudas las da por solucionadas el que las realiza...


De nuevo queda reflejado el pedazo de mierda que eres...
  #10 (permalink)  
Antiguo 22/01/2015, 07:26
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Consultas SQL universales

Me parece genial que hayas resuelto tu duda, ahora deberías devolver el favor a la comunidad y publicar la solución, de otra forma el conocimiento que has adquirido será sólo tuyo.

Además pienso que el sugerirte librería no siempre es para que las uses, al final eso depende de tu criterio, sin embargo también podrías revisarlas para entender cómo hacen las cosas ¿o pretendías hacer lo mismo desde cero y sin la menor pista de ello?

Porque vamos, el foro no está para esas cosas, acá tratamos de ayudar a resolver problemas objetivos.

Tampoco esperes a que te enseñemos a implementar un patrón de diseño sólo porque por razones desconocidas no puedes usar librerías ya escritas para ello.

__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #11 (permalink)  
Antiguo 22/01/2015, 07:31
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Respuesta: Consultas SQL universales

Es que ni te has molestado en leer mi consulta, no quiero una librería para una mierda de código que no ocupa mas de 10 lineas, tan solo necesitaba esto:

//Lista de todos los registros de una tabla con paginacion
function lista_tabla($tabla,$paginacion) {

//PAGINAR RESULTADOS
$sql = "SELECT * FROM $tabla";
//$consulta= $consulta." ORDER BY usuarioId DESC";
$rs = mysql_query($sql);
$total_registros = mysql_num_rows($rs);

// Limito la busqueda
if (isset($paginacion)){
$paginacion = $paginacion;
}else{
$paginacion = 15;
}
//examino la página a mostrar y el inicio del registro a mostrar
$pagina = isset($pagina) ? $pagina : NULL;
if (!$pagina) {
$inicio = 0;
$pagina = 1;
}else {
$inicio = ($pagina - 1) * $paginacion;
}//calculo el total de páginas
$total_paginas = ceil($total_registros / $paginacion);

// Consultamos y mostramos resultados
$sql = $sql." LIMIT $inicio,$paginacion";
//echo $sql;
$resultado = mysql_query($sql);

$lista_tabla_valor = array();
while ($row = mysql_fetch_array($resultado)){
$lista_tabla_valor[] = $row;

}


mysql_free_result($resultado);
}
  #12 (permalink)  
Antiguo 22/01/2015, 07:34
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Consultas SQL universales

Bien, ¿y si la columna principal no es "usuarioId" sino que es dinámica y cambia siempre qué harías?
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #13 (permalink)  
Antiguo 22/01/2015, 07:35
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Respuesta: Consultas SQL universales

Por eso esta comentada...
  #14 (permalink)  
Antiguo 22/01/2015, 07:46
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Consultas SQL universales

¿Y las columnas? ¿Siempre hará "SELECT *" por todas las columnas?

Aunque bueno, basta de preguntas así.

Me pregunto ¿si ya sabías hacer consultas que tan complicado era encapsular su lógica en funciones reutilizables?

Es un concepto tan básico en programación general que me sorprende que aún existan "programadores" que les gusta copiar y pegar código, sin abstracción alguna, repitiendo siempre lo mismo.

Te sugiero leer el manual al respecto, el poder de escribir funciones es brutal.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #15 (permalink)  
Antiguo 22/01/2015, 08:21
 
Fecha de Ingreso: julio-2014
Mensajes: 18
Antigüedad: 9 años, 9 meses
Puntos: 0
Respuesta: Consultas SQL universales

No te sorprendas tanto con lo de los demás y céntrate mas en ti y en mejorar tus formas, verás como así nos sorprenderás a todos y para bien.

Debes ser alguien bien joven porque solo alguien de corta edad anda prejuzgando permanentemente a los demás y peor de forma tan superficial...

Ahora si... TEMA CERRADO!!

Etiquetas: formulario, registro, select, sql, tabla, variable
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 00:34.