Una buena práctica a seguir es no modificar en absoluto el core de Yii Framework, esto es más que importante ya que si modificamos el core del framework y luego lo actualizamos a una nueva versión, todo lo modificado se va a perder y nos puede causar muchos problemas en nuestra aplicación. En este artículo quiero mostrarles la forma para que puedan personalizar gii y adaptarlo a sus necesidades, en mi caso lo uso para que todo lo generado tenga soporte multilenguaje y también le agrego opciones para exportar a pdf y excel dentro de la vista admin. Lo primero… Continuar leyendo


Un reporte es un Documento, generado por el Sistema, que nos presenta de manera Estructurada y/o Resumida, datos relevantes guardados o generados por la misma aplicación de tal manera que se vuelvan útiles para fines concretos. Los reportes generalmente agrupan los datos de acuerdo a un interés específico; por ejemplo el reporte «Cheques emitidos». Estos datos normalmente son traidos a travez de consultas SQL. Los componentes Qreport no viene instalado por defecto en Delphi. Instalacion del paquete Qreport. 1. Component 2. Install Packages.. 3. Add 4. C:\Archivos de programa\Borland\Delphi7\Bin\dclqrt70.bpl Creando el reporte. 1. Crear un formulario nuevo y colocar los… Continuar leyendo


DBLookupComboBox En que caso usaremos?..   Supongamos que tenemos un formulario y queremos mostrar los datos de una tabla, por ejemplo la tabla «distrito». Primero hacemos la conexion con la base de datos (con IBDatabase e IBTransaction) y luego conectamos con un IBTable. Asignamos la tabla distrito al IBTable. Este IBTable solo traera los campos id_distrito, distrito, id_departamento y poblacion que pertenecen a la tabla distrito. El DBLookupComboBox es un componente parecido al ComoboBox en apariencia pero permite enlazar a travez de la clave externa (foreign key) dos tablas y mostrar el campo que deseemos de la otra tabla. Para… Continuar leyendo


IBTable vs IBQuery El IBQuery es muy similar al IBTable en cuanto al manejo de datos. Pero la diferencia está en que el IBTable solo permite traer datos de una sola tabla y el IBQuery permite hacer una consulta SQL y traer datos de más de una tabla. Una vez que los datos son traidos a la aplicacion el IBQuery lo maneja como si fuera una sola tabla. Ejemplo: De las siguientes tablas el IBTable solo permitirá traer los campos de la tabla nominas o solo los campos de la tabla trabajadores. En cambio con el IBQuery podemos traer los… Continuar leyendo


Diferencia entre DBNavigator y botones individuales Las opciones que trae el dbnavigator (agregar, editar, eliminar, guardar, cancelar, y para recorrer los registros) se pueden programar por separado, con qué fin hacemos esto?, para tener más control sobre cada botón. Por ejemplo: podemos des habilitar los botones «guardar» y «cancelar» cuando la aplicación inicia. Codigo básico para cada boton. Agregar:  ibtable1.Append; //agrega un registro en blanco a la tabla. Editar: ibtable1.Edit; //habilita el registro para poder editar. Eliminar: ibtable1.Delete; //elimina el registro seleccionado de la tabla ibtable1.ApplyUpdates; //actualiza los cambios Guardar: ibtable1.Post;  //guarda ibtable1.ApplyUpdates; //aplica los cambios ibtable1.Refresh; // actualiza Cancelar: ibtable1.CancelUpdates; // cancela los… Continuar leyendo


¿Como registrar una base de datos con IBCONSOLE? 1. Iniciamos IBConsole. Y nos del menu Server seleccionamos «login» para iniciar. User name SYSDBA y password masterkey. 2. Para registrar una base de datos debemos: 2.1. Seleccionar «Register..» del menu Database. 2.2. En Database colocamos la direccion de la base de datos. Para ver el archivo cambiamos el tipo de archivo, colocamos all. 2.3. Presionamos ok. 3. Doble click sobre el nombre de la base de datos que se agrego al arbol. * Ahora tenemos preparado la base de datos para conectar con Delphi. Conectar aplicacion con base de datos: IBDatabase, … Continuar leyendo


¿Que son las tablas? Son las encargadas de almacenar los datos. El almacenamiento de los mismos se realiza de forma organizada gracias a la estructura de las tablas, la buena estructuración de las tablas es imprescindible para realizar con eficacia todas las operaciones necesarias. Las tablas son los elementos principales en una base de datos. Si no hay tablas, no tienen sentido el resto de los elementos propios de una base de datos. ¿Que son las tablas temporales?. Son tablas que se crean en tiempo de ejecucion y solo permanecen durante la sesion de el/los usuarios. Existen 2 tipos de… Continuar leyendo


¿Que son los formularios? Un formulario es un documento con espacios (campos) en donde se pueden escribir o seleccionar opciones. Cada campo tiene un objetivo, por ejemplo, el campo «Nombre» se espera que sea llenado con un nombre, el campo «año de nacimiento», se espera que sea llenado con un número válido para un año, etc. Los formularios presentan una visión ordenada de múltiple información sobre algo, y son útiles para llenar bases de datos. En internet y sistemas informáticos, los formularios pueden ser llenados de forma online con validación de datos, y son muy útiles para las encuestas, registración de… Continuar leyendo


Códigos útiles ¿Como hago para que un componente cambie su estado de visible a invisible? nombre_del_componente.visible:=true; //muestra el componente. nombre_del_componente.visible:=false; //no muestra el componente. ¿Como hacemos para habilitar y deshabilitar un componente? nombre_del_componente.Enabled:=true; //habilita el componente. nombre_del_componente.Enabled:=false; //deshabilita el componente. ¿Para agregar un retorno de carro (enter) en un memo? Colocamos el siguiente codigo en el lugar que queremos que sea el retorno de carro: #13#10. Ejemplo: memo1.Text:=’Economico’+#13#10+#13#10+’   Mayor velocidad, menos consumo de tinta..’; ¿Como sabemos que item esta seleccionado en el ListBox? Con el siguiente codigo: ListBox1.ItemIndex. Si devuelve -1 no está seleccionado ninguno. ¿Como rescatamos el texto del… Continuar leyendo


El PageControl A veces, la cantidad de información que es necesario solicitar o mostrar excede la capacidad habitual de una ventana, siendo preciso usar varias para poder gestionar todos los controles requeridos. Una alternativa a la creación de múltiples ventanas consiste en definir varias páginas en la misma ventana, lo cual es posible mediante varios de los controles incluidos en Delphi. Entre ellos existe uno que nos permite gestionar varias páginas en un form. Este control se llama TPageControl y dispone de las siguientes propiedades: Propiedades Tipo Contenido ActivePage TTabSheet Página actualmente activa MultiLine Boolean Indica si se permiten varias… Continuar leyendo