Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MySQL
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 05-09-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.141
Poder: 36
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Ya he afinado un poquitín más el asunto y he actualizado el archivo Zip que contiene la última versión del código fuente de Loturak, por si queréis echar un vistazo, lo digo.

En cuanto a lo que dices Emilio, me queda la duda de no haber utilizado (siempre se está a tiempo) una Cookie, pero, desde luego, no creo que el tema haya quedado farragoso.

Fíjate. ¿Qué ha sido necesario hacer? Crear una tabla en la base de datos de nombre Opciones, con tres campos, el ID de las opciones, el ID del usuario de estas, y el propio campo que contiene las opciones.

Ahora bien. ¿Ha sido necesario hacer algo más en la base de datos? No. ¿Hemos tenido que añadir algo a la tabla Opciones para que la cosa funcione? No. ¿Los usuarios notarán algo raro mientras no cambien sus opciones? No.

¿Básicamente qué es lo que hacemos? Hemos escrito una clase Opciones para tratar con estas en la base de datos de una forma más o menos sencilla... y la hemos escrito en un momento, como aquél que dice, y sabemos ya que puede ampliarse... que abre posibilidades...

De acuerdo, pero, ¿realmente es complicado acceder a las opciones, determinar qué camino a seguir en función de estas, qué es lo que nos cuesta averiguar la información que nos ofrece una opción? Veamos la única que existe ahora mismo, ¿cómo la utilizamos?

Código PHP:
if($usuario->opciones->Leer(APP_OPC_FORZAR_DESCRIPCION'0') == '0')
{
  
// No forzar la descripción del enlace
}
else
{
  
// Forzar la descripción del enlace

No parece muy complicado. Se busca una opción, se ofrece un valor "por defecto" en caso de que no exista la opción y obramos en consecuencia.

Pero, ¿Y qué hacemos para actualizar las opciones? Veámoslo:

Código PHP:
$usuario->opciones->Escribir(APP_OPC_FORZAR_DESCRIPCION1);
$usuario->opciones->Actualizar(); 
Es decir, se escribe el valor de las opciones que sean menester y se actualizan en consecuencia. No he querido "actualizar" en el propio método "Escribir", precisamente, para poder guardar varias opciones de un golpe, y, sobre todo, para no tener que hacerlo una a una...

Ahora bien, ¿dónde ves la complicación en todo esto Emilio? Estoy dispuesto a rectificar si encuentro que lo que hasta ahora hay hecho sirve, por supuesto.

Al contrario, yo creo que la cosa ha quedado tan sencilla que escama un poco... que seguro que se están dejando cabos sueltos, pero, la opción añadida actualmente está cumpliendo, y, al menos similares a esa, estamos ya seguros de poder añadir más si nos es preciso, y con relativa sencillez.
__________________
David Esperalta
www.decsoftutils.com

Última edición por dec fecha: 05-09-2006 a las 00:46:39.
Responder Con Cita
  #2  
Antiguo 05-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
La verdad que yo tampoco entendo el pero Emilio. Lo que ha hecho dec aquí es sencillo y servirá para guardar las opciones del usuario. Cierto que si sólo se tratase de una opción pues sería mucho hacer pero es claro que dec lo está pensando para más cosas.

Por otra parte, tanto puñetar empieza a mosquearme. No sé en España como sea la costumbre, pero llamarme puñetero tantas veces empieza a incomodarme. Confío en que sólo sea una diferencia de costumbres.

// Saludos
Responder Con Cita
  #3  
Antiguo 05-09-2006
Avatar de Emilio
*Emilio* Emilio is offline
Capo
 
Registrado: may 2003
Ubicación: Palma de Mallorca
Posts: 2.639
Poder: 10
Emilio Va por buen camino
Cita:
Empezado por roman
Por otra parte, tanto puñetar empieza a mosquearme. No sé en España como sea la costumbre, pero llamarme puñetero tantas veces empieza a incomodarme. Confío en que sólo sea una diferencia de costumbres.
Bueno aquí incluso se toma como alago que te llamen cabronazo, hijo de la gran pu... y cosas así ¿eso no se estila por ahí?
__________________
Saludos
Emilio
Responder Con Cita
  #4  
Antiguo 05-09-2006
Avatar de Emilio
*Emilio* Emilio is offline
Capo
 
Registrado: may 2003
Ubicación: Palma de Mallorca
Posts: 2.639
Poder: 10
Emilio Va por buen camino
Cita:
Empezado por dec
Ahora bien, ¿dónde ves la complicación en todo esto Emilio? Estoy dispuesto a rectificar si encuentro que lo que hasta ahora hay hecho sirve, por supuesto.
Mi estimado dec, creo que en esta ocasión el que debe rectificar soy yo, después de atender con detalle al código, veo cuales son las intenciones que no he visto inicialmente y de ahí mi anterior opinión, lo cierto es que incluso debo decir que ahora hasta me gusta y posiblemente te lo pinche para alguna que otra cosa que tengo entre manos

Eso si, a ese código le falta la función resultados() que en ella debes hacer la consulta, pero bueno eso no es imprescindible, se sobreentiende.
__________________
Saludos
Emilio
Responder Con Cita
  #5  
Antiguo 05-09-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.141
Poder: 36
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Román, lo cierto es que el diccionario no hace esta vez una correcta descripción de la que es al menos una de las acepciones de las palabra puñetero. En mi tierra se dice cariñosamente, claro que vuelve a pasar lo mismo otra vez: dicho, o sea, de viva voz, suena de distinto modo, porque ahí está el quid, en el tono que se le dé a la palabra. Pasa con otras como cabrón, que no es necesariamente un insulto, puede incluso ser todo lo contrario. Pero, supongo que el lenguaje escrito no permite todas las posibilidades del lenguaje hablado. Permite otras, claro.

Cita:
Empezado por Emilio
Mi estimado dec, creo que en esta ocasión el que debe rectificar soy yo, después de atender con detalle al código, veo cuales son las intenciones que no he visto inicialmente y de ahí mi anterior opinión, lo cierto es que incluso debo decir que ahora hasta me gusta y posiblemente te lo pinche para alguna que otra cosa que tengo entre manos
Bueno. Desde luego la cosa es muy mejorable, de eso no me cabe duda. Por ejemplo, acabo de actualizar el código fuente de Loturak, porque estaba haciendo dos consultas a la base de datos para lo mismo. La clase Opciones ha cambiado también algo de lo que se puede ver arriba, aunque, básicamente, es lo que se ha comentado ya.

Cita:
Empezado por Emilio
Eso si, a ese código le falta la función resultados() que en ella debes hacer la consulta, pero bueno eso no es imprescindible, se sobreentiende.
Bueno. Ahora mismo nos valemos de la clase "BDatos" de Loturak para traer las opciones de la base de datos, pero, muy probablemente termine escribiendo un método en la clase "BDatos" a partir del cual la clase "Opciones" pueda hacerse con estas.

En realidad el resultado sería el mismo: lo único que cambiaría (que se me ocurra, y que además pretendemos y tratamos de seguir como norma) es que se dejaría la consulta SQL en la clase BDatos, junto al resto de consultas que se hacen, de manera que en caso de necesitar modificar la misma se sabría de antemano a dónde acudir.

Al comenzar Loturak la clase BDatos era cierta clase que escribí (en realidad casi copié, pero, adrede, para tratar de comprender su funcionamiento) hace ya tiempo (con ayuda de no poca gente, Román, por ejemplo, colaboró en ello). Pero en Loturak contamos con una clase que extiende esta BDatos, y que es la que aporta métodos que, fundamentalmente, hacen consultas a la base de datos. Es por eso, por tenerlo ahí, a mano, como aquel que dice, y no una consulta aquí, otra allí, otra acullá, etc.

Pero, creo que me enrrollo... joroba... ¡sí, me estoy enrrollando! Me gustaría encontrar un fragmento de cierto capítulo de Don Quijote de la Mancha en donde se explica porqué utilizar el término hijo de puta y llamárselo a alguien no tiene que ser un insulto... no recuerdo exactamente qué capítulo era, pero, como todos los del Quijote, es estupendo.

Podría acaso buscarse por Internet, puesto que el Quijote está digitalizado y probablemente el término "hideputa" o "hijo de puta" no aparezca demasiado (eso creo recordar). En fin, lo dejo ya, que ya está bien, qué pesao.
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #6  
Antiguo 05-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Ta bueno pues.

En cuanto a la clase bdatos, desconozco yo el uso exacto que le das, pero visto así desde lejos y a juzgar por su nombre, a mi me da que tal como tienes tu clase Opciones está muy bien. Esto es, tienes una clase bdatos que- estoy suponiendo-centraliza el acceso a la base de datos, lo cual está muy bien, pero no hagas de esta clase un dios que hace todo. Otras clases de tu aplicación, como Opciones hacen uso de ella en lugar de dejarle todo el trabajo a una sólo clase.

Vamos, en resumen, que a mi me parece bien tal como la tienes.

// Saludos puñetero
Responder Con Cita
  #7  
Antiguo 05-09-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.141
Poder: 36
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Capítulo XIII de la segunda parte del Quijote. Léase.

Y, por cierto,... ha sido leer un poco del texto para acordarme de que sí, en el Quijote se utiliza "hijo de puta" en más de una ocasión y más de dos...
__________________
David Esperalta
www.decsoftutils.com

Última edición por dec fecha: 05-09-2006 a las 02:10:10.
Responder Con Cita
  #8  
Antiguo 05-09-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.141
Poder: 36
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Sí; de hecho dudo en añadir un método (y seguramente más de uno sería necesario) en la clase BDatos, puesto que la clase Opciones está ahora bastante clara y limpia, y tampco estorban ahí las consultas SQL.

Empero, los métodos principales relacionados con la base de datos de la aplicación: realizar la conexión, la selección de la base de datos, ejecutar consultas de varias maneras... todo eso lo hace la clase BDatos,... que en realidad no se ha tocado en Loturak, es decir, que puede usarse en otra aplicación sin problemas (en principio) y de hecho yo la he utilizado en alguna otra aplicación o pruebas.

Ahora, lo que existe en Loturak es una clase que extiende (que hereda) de la clase BDatos "principal". Es en esta clase hija en donde se acumulan métodos como "NumEnlacesPublicos", "NumEnlacesPrivados", "EnlaceUsuario", etc., etc., etc., que, básicamente, puede decirse que conforman las consultas SQL. No se ejecutan, sólo se conforman, porque de la ejecución de las consultas, entre otras cosas, se encarga la clase padre de esta.

¿Entonces cuál es la intención de extender la clase BDatos? Pues, básicamente (y es posible que de forma equivocada) se hace para tener en un solo lugar la conformación de consultas SQL. Esto no se consigue del todo, hay sitios en la aplicación en donde se hacen consultas SQL (siempre a través de la clase BDatos), pero, la gran mayoría (y como norma general) se hacen en la clase BDatos, no en "cualquier sitio".

Ocurre un poco lo mismo con la clase Xhtml, que "encapsula" (es mucho decir) la salida del código XHTML de la apliación. En algunos sitios se genera código de salida, pero, prácticamente todo el código XHTML de salida está en la clase Xhtml, de manera que es algo más sencillo de "localizar", editar, etc. Al menos así lo estoy viendo yo de momento... porque está el problema del tamaño de los archivos... la clase BDatos no me preocupa, pero, la clase Xhtml, incluso luego de varios repasos, ocupa ya unos 130 KB.

Sin embargo, no noto problemas en eso (de momento) y todavía es posible darle más de un repaso y más de dos...
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #9  
Antiguo 05-09-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.141
Poder: 36
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Cita:
Empezado por Seoane
Ya te busco yo el fragmento
Muchas gracias Seoane. Unos párrafos más adelante de lo que has referido Seaoane, viene a caer Sancho en la verdad de que hijo de puta no es siempre un término ofensivo:

Cita:
(...)

-Por mi fe, hermano -replicó el del Bosque-, que yo no tengo hecho el estómago a tagarninas, ni a piruétanos, ni a raíces de los montes. Allá se lo hayan con sus opiniones y leyes caballerescas nuestros amos, y coman lo que ellos mandaren. Fiambreras traigo, y esta bota colgando del arzón de la silla, por sí o por no; y es tan devota mía y quiérola tanto, que pocos ratos se pasan sin que la dé mil besos y mil abrazos.

Y, diciendo esto, se la puso en las manos a Sancho, el cual, empinándola, puesta a la boca, estuvo mirando las estrellas un cuarto de hora, y, en acabando de beber, dejó caer la cabeza a un lado, y, dando un gran suspiro, dijo:

-¡Oh hideputa bellaco, y cómo es católico!

-¿Veis ahí -dijo el del Bosque, en oyendo el hideputa de Sancho-, cómo habéis alabado este vino llamándole hideputa?

-Digo -respondió Sancho-, que confieso que conozco que no es deshonra llamar hijo de puta a nadie, cuando cae debajo del entendimiento de alabarle. Pero dígame, señor, por el siglo de lo que más quiere: ¿este vino es de Ciudad Real?

-¡Bravo mojón! -respondió el del Bosque-. En verdad que no es de otra parte, y que tiene algunos años de ancianidad.

(...)
Véase el lenguaje de Cervantes (aunque traído al castellano "moderno"), pero, véase la maestría, la elegancia, la sencillez, la enjundia, el conocimiento, la cultura, lo que este hombre es capaz de decir en lo que escribe... ¡si no habéis leído el Quijote no dejéis de hacerlo cuando podáis, os aseguro risas, buenos ratos, sabiduría! ¡Y pongo las manos en el fuego por ello! No puede haber ser humano al que el Cervantes (no ya el Quijote) deje indiferente. Yo no sé cómo encarecerlo como se debe.
__________________
David Esperalta
www.decsoftutils.com

Última edición por dec fecha: 05-09-2006 a las 14:21:47.
Responder Con Cita
  #10  
Antiguo 05-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por dec
Ocurre un poco lo mismo con la clase Xhtml, que "encapsula" (es mucho decir) la salida del código XHTML de la apliación. En algunos sitios se genera código de salida, pero, prácticamente todo el código XHTML de salida está en la clase Xhtml, de manera que es algo más sencillo de "localizar", editar, etc. Al menos así lo estoy viendo yo de momento... porque está el problema del tamaño de los archivos... la clase BDatos no me preocupa, pero, la clase Xhtml, incluso luego de varios repasos, ocupa ya unos 130 KB.
La clase BDatos no te preocupa ahora y posiblemente funcione bien en esta aplicación. Pero sí es de pensarse qué pasa cuando toda una clase muy grande debe cargarse para cualquier mínima cosa. Esto realmente es pregunta. Es que hasta para la página más pequeñita, tu clase xhtml carga todo. Y aunque en esta aplicación BDatos no tiene tanta demanda, la naturaleza de la cuestión es la misma que en la clase xhtml.

No sé, no sé. Sería bueno saber

// Saludos
Responder Con Cita
  #11  
Antiguo 05-09-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.141
Poder: 36
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Cita:
Empezado por Román
Esto realmente es pregunta. Es que hasta para la página más pequeñita, tu clase xhtml carga todo (...)
Sobre eso diré que yo también me he preguntado algunas cosas y he estado a punto de comentarlo en los Foros, y, en fin, acaso ahora toca hacerlo.

En primer lugar no se me escapa que ciertas páginas, digamos, más o menos estáticas, podrían prescindir de la clase Xhtml, o, fuera como fuera, no necesitarían de métodos en esta clase, sino que, simplemente, cada página incluiría su código XHTML correspondiente (además del "general", que sí añadiría, por ejemplo, las cabeceras de las páginas, o el pie de estas). Puede hacerse, se ha pensado y no se descarta.

Peeeeeeeeeeeero... Lo cierto es que dudo que PHP carge los 130 KB del archivo de la clase Xhtml. Lo pongo en duda... ¡porque la carga de la página es bastante rápida, y, si tuviera que cargar los 130 de la clase Xhtml, los 30 de la clase BdatosEx, los 25 de la clase Login, los... tardaría mucho más de lo que tarda, fijo. Además nos hemos animado a echar para adelante (por lo menos hasta que no veamos que la cosa no escala, que no es posible seguir así) porque hemos visto clases en PHP de 300 KB...

Pero, sobre todo, porque los hechos contradicen a los números. Ya lo he dicho, si se "carga todo" la página tendría que ocupar unos 250 KB (no quiero exagerar) y, sin embargo, Loturak carga bastante rápido, desde luego, no cargaría así si tuviera que cargar con 250 KB... y lo dice alguien que cuenta con una conexión vía módem de 56 kbs y que notaría esos KB de qué manera...

¿Entonces? Pues no sé... no llego a tanto... es lo que quería preguntar, ¿cómo se las ingenia PHP? No lo sé, pero, desde luego, se las ingenia. No sé. Debe haber algo parecido al caché de los navegadores, o a lo que hace Apache (que no sirve páginas si no han cambiado desde la última vez), me parece, o MySQL, que no actualiza un registro (aunque se lo digas) si esto es innecesario, porque los datos del mismo son iguales... o al compilador JIT (Just in time) de .NET, que compila el código la primera vez que es necesario, pero, luego ya no hace sino ejecutar el código previamente compilado...

Mecanismos de optimización que van más allá de mi conocimiento, pero, que, deben existir, pues de lo contrario se vería enseguida, se notaría la diferencia y bastante además, ya digo.

Pensad en que la clase Xhtml no va sola... que se apoya en otra clases (de algún modo) y antes de su declaración puede verse:

Código PHP:
<?php

require(DIR_LIBS.'captcha.class.php');
require(
DIR_LIBS.'filtros.class.php');
require(
DIR_LIBS.'servidor.class.php');
require(
DIR_LIBS.'etiquetas.class.php');
require(
DIR_LIBS.'validarex.class.php');
require(
DIR_LIBS.'compresion.class.php');
require(
DIR_LIBS.'administrar.class.php');

class 
XHtml


  
/* ... */
Estas clases son mucho menos pesadas (del orden de 10 KB ó menos), pero, lo cierto es que ahí están... y, como digo, Loturak no carga "lenta" ni noto "en local" un excesivo consumo de recursos o algo parecido... ¡qué sé yo! Alguien tiene que explicarnos esto.

Edito: Me doy cuenta ahora de que acaso he mezclado churras con merinas en parte de lo que he dicho, pero, no voy a buscarle las vueltas, porque, me parece que se entiende lo que más o menos quiero explicar. Ea. ¡Saludos!
__________________
David Esperalta
www.decsoftutils.com

Última edición por dec fecha: 05-09-2006 a las 03:25:45.
Responder Con Cita
  #12  
Antiguo 05-09-2006
Avatar de seoane
[seoane] seoane is offline
Miembro Premium
 
Registrado: feb 2004
Ubicación: A Coruña, España
Posts: 3.717
Poder: 26
seoane Va por buen camino
Cita:
Empezado por dec
Pero, creo que me enrrollo... joroba... ¡sí, me estoy enrrollando! Me gustaría encontrar un fragmento de cierto capítulo de Don Quijote de la Mancha en donde se explica porqué utilizar el término hijo de puta y llamárselo a alguien no tiene que ser un insulto... no recuerdo exactamente qué capítulo era, pero, como todos los del Quijote, es estupendo.

Podría acaso buscarse por Internet, puesto que el Quijote está digitalizado y probablemente el término "hideputa" o "hijo de puta" no aparezca demasiado (eso creo recordar). En fin, lo dejo ya, que ya está bien, qué pesao.
Ya te busco yo el fragmento:

Cita:
A lo que respondió Sancho, algo mohíno:

-Ni ella es puta, ni lo fue su madre, ni lo será ninguna de las dos, Dios quiriendo, mientras yo viviere. Y háblese más comedidamente, que, para haberse criado vuesa merced entre caballeros andantes, que son la mesma cortesía, no me parecen muy concertadas esas palabras.

-¡Oh, qué mal se le entiende a vuesa merced -replicó el del Bosque- de achaque de alabanzas, señor escudero! ¿Cómo y no sabe que cuando algún caballero da una buena lanzada al toro en la plaza, o cuando alguna persona hace alguna cosa bien hecha, suele decir el vulgo: "¡Oh hideputa, puto, y qué bien que lo ha hecho!?" Y aquello que parece vituperio, en aquel término, es alabanza notable; y renegad vos, señor, de los hijos o hijas que no hacen obras que merezcan se les den a sus padres loores semejantes.

-Sí reniego -respondió Sancho-, y dese modo y por esa misma razón podía echar vuestra merced a mí y hijos y a mi mujer toda una putería encima [...]
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
¿Cómo ver a los usuarios conectados desde mi aplicacion? federiconqn21 Conexión con bases de datos 3 23-07-2006 01:56:09
Problema al ejecutar un procedimiento dos usuarios distintos en aplicacion asp.net mamen .NET 5 04-05-2006 14:58:23
lanzo aplicación para que sea terminada por usuarios de internet unreal4u Varios 0 25-11-2004 19:34:03
Usuarios conectados en mi aplicacion ? Jorge Taveras MS SQL Server 8 29-06-2004 22:18:41
opciones para grabar un video jfgonzalez OOP 2 11-08-2003 16:25:42


La franja horaria es GMT +2. Ahora son las 16:39:32.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi