mayo 29, 2006

Los cuatro puntos de la cardinalidad de la relación durante el diseño de la BD.

Hay una restricción importante que se declara gráficamente en las relaciones en el diagrama Entidad-Relación y se llama la cardinalidad, la cual representa qué tantos de una cosa se relacionan con otra. La cardinalidad de la relación es particularmente importante debido a que forma la base de muchas decisiones de diseño. La cardinalidad se expresa con un valor para un mínimo y para un máximo. El valor mínimo describe si la relación es opcional o requerida. El valor máximo describe si la relación es singular o plural. Debido a que las relaciones se indican en ambas direcciones entre las dos entidades, la cardinalidad mínima y máxima también debe ser indicada en ambas direcciones. Esto significa que para cada relación del modelo se requieren cuatro puntos de cardinalidad para expresar adecuadamente la naturaleza de la relación (mínimo y máximo en ambas direcciones).

A continuación veremos mediante un ejemplo el uso de las cuatro preguntas de la cardinalidad de la relación. Vamos a suponer que estamos elaborando una aplicación de facturación, para lo cuál vamos tomar las entidades de este modelo. Decimos que un Cliente compra Productos, entonces existe una relación entre ambas entidades.









Ahora identificamos la cardinalidad de la relación, para ello nos plantemos las siguientes cuatro preguntas –preguntas de la cardinalidad de la relación-

1. Debe un CLIENTE comprar un PRODUCTO? No. Para ser cliente efectivamente alguna vez nos compró, pero después no, así que ya es CLIENTE, pero no necesariamente debe comprarnos productos, después de la primera vez.

2. Puede un CLIENTE comprarnos más de un PRODUCTO? Si. Esto depende de la naturaleza de operación de la organización, pero lo común es que al levantar un pedido a un CLIENTE este puede solicitarnos a más de un PRODUCTO.

3. Debe un PRODUCTO ser comprador por un CLIENTE? No. Porque no podemos forzar a que un PRODUCTO sea comprador por un CLIENTE.

4. Puede un PRODUCTO ser comprador por más de un CLIENTE? Si. Esto es viendo desde el concepto de PRODUCTO y no como una pieza fisica.

Podemos observar que las dos primeras preguntas van enfocadas del CLIENTE al PRODUCTO y las otras dos preguntas del PRODUCTO al CLIENTE.

La pregunta 1 está diseñada para obtener la cardinalidad mínima.
La pregunta 2 está diseñada para determinar si la misma instancia de la entidad A puede participar en relaciones con varias instancias de la entidad B al mismo tiempo.

Cuando quedan determinadas las respuestas a las preguntas 1 y 2, el analista puede poner la cardinalidad mínima y máxima en el diagrama para expresar las reglas de negocio. La notación de la cardinalidad mínima es un cero que significa opcional, o un uno que significa requerida. La notación para la cardinalidad máxima es un uno, que significa solamente uno o un par de patas de gallo significa muchos.









La cardinalidad mínima y máxima debe ser expresada en ambas direcciones para definir adecuadamente la regla de negocio.



Así es como se ve nuestro modelo después de aplicar las cuatro preguntas de cardinalidad.



Pero como sabemos que las relaciones muchos a muchos no se soportan en un RDBMS, entonces nace debe crearse una nueva entidad asociativa que resuelva este tipo de cardinalidad y ésta es FACTURA.


Después de aplicar las cuatros preguntas de cardinalidad, nuestro modelo queda así:



Podemos observar que ahora ha aparecido otra relación muchos a muchos y que es necesario resolver, yo lo llamaré DETALLE_FACTURA. En la siguiente figura se expone el cómo se vería nuestro modelo Entidad-Relación terminado.





Una nota importante a la hora de aplicar las cuatro preguntas de la cardinalidad es el verbo que se nombra entre la relación de ambas entidades, por ejemplo el cliente compra, el producto se incluye, etc.

mayo 28, 2006

Cómo funciona y por qué usar AJAX?

No hace mucho tiempo me enteré de una nueva tecnología que aprovecha a XML y javascript para hacer a nuestras aplicaciones WEB más responsivas y en la web encontré lo que a continuación expreso.

El Web y Ajax

Problema: La recarga de una vista o página anteriormente cargada cuando lo único que se va a modificar entre request y request son sólo datos. La vista sigue siendo la misma. Es decir de evita el rearmado de la vista con los nuevos datos y el viaje de la misma desde el servidor.

Causas: La coomunicación entres el cliente y el servidor es a través de request -peticiones- Y se deja que le servidor genere una nueva vista, pero con los nuevos datos cargados para que el cliente los visualice, cuando en realidad la misma sigue igual, sólo modifica sus datos.

Solución: Separar los datos de la vista. Mediante el uso de un pequeño controlador invoker del lado del cliente dentro de la vista, que administre los datos. Mediante el uso del modelo de objetos del navegador y scripting del lado del cliente se realiza la carga y manejo de datos sobre la vista anteriormente solicitada sin necesidad de realizar un request cuando es posible con los datos actuales. Y al momento de necesitar una acción del servidor para obtener más datos, se realiza la misma evitando la recarga de la vista que continuo siendo la misma.

Ventajas:
1) Solución simple de implementar.
2) Permite obtener datos bajo demanda y luego visualizarlos sin recargar las vistas.
3) Las vistas no se ven afectadas en cuanto a tamaño y éstas pueden ser cacheadas por el navegador ya que las mismas no expirarían continuamente ya que sus datos son manejados independientemente de la presentación.
4) Las vistas no son reescritas por el servidor por lo que separa más la vista en si de los datos, permitiendo un mejor manejo por los diseñadores.

Desventajas:
1) Utiliza frames ocultos.
2) Utiliza más scriptting del lado del cliente

Resumen: Con Ajax se evita la recarga de las vistas cunado no es necesario cambiarla, sino que busca los datos y carga a los mismo en la vista.

Identificación de Reglas de Negocio

Durante la etapa de análisis la toma de requierimientos es de extrema importancia para lograr el éxito del proyecto y no llegar la final con "una solución elegante a un problema equivocado" y como parte de esta etapa está la identificación de las fomosas "REGLAS DE NEGOCIO".


Qué son las Reglas de Negocio? En el libro "UML y Patrones" de Craig Larman dice:
"Las reglas del dominio dictan en modo en el que podrán operar un dominio o negocio. No son requisitos de ninguna aplicación, aunque, a menudo, los requisitos de una apliación se ven afectados por las reglas del dominio. Las políticas de la compañía, leyes físicas y leyes gubernamentales, son reglas de dominio típicas.

Se demoninan comunmente reglas del negocio, que son el típico más común, pero ese término está limitado, ya que existen aplicaciones de software que no son de gestión de un negocio, como la simulación del clima o la logística militar. Una simulación del clima incluye reglas del dominio, relacionadas con las leyes y relaciones físicas que afectan a los requisitos de la aplicación.

Avertencia: Las reglas no son requisitos de la aplicación. No registre las caracteristicas del sistema como reglas. Las reglas describen las restricciones y comportamientos del modo de trabajar del dominio, no de la aplicación"

Como ven los parrafos anteriores son muy interesantes, pero a continuación aquí hat algo más que encontré en la web sobre las reglas de negocio:

1. Criterios para identificar reglas de negocio o del dominio.

- Condiciones que se deben satisfacer para considerar válidos los datos. Por ejemplo sólo se puede enviar la mercancía hasta que el cliente haya pagado.

- Condiciones que deben ser evitadas.
Por ejemplo que el inventario de cierto producto llegue a cero.

- Secuencias en las que los eventos deben de ocurrir.
Se debe determinar que hacer cuando el inventario llega a cero o cuando un pago para una orden es recibido.

2. Métodos para implementar reglas de negocio.

- Directamente en la base de datos.
DataTypes, Default Values, Rules, Keys y Triggers. (En una palabra constraints de Base de Datos).

- Programación dentro o fuera de la base de datos.
Store Procedures, objetos de negocio, validación directamente en la capa del cliente.

Clasificación de los reportes durante el desarrollo de sistemas.

Los reportes son las salidas de la información que las organizaciones utilizan para la toma de desiciones o para realizar tareas o procesos de negocio y como desarrolladores estamos comprometidos a crear a la hora de implementar una aplicación.

Cuando trabajé en en un proyecto y que participé desde la fase de toma de requerimientos los usuarios nos empapelaron de solictudes de reportes que según ellos eran necesarios que el sistema les dejará imprimir, yo le comenté a mi jefe sobre está situación y le mencioné que desde mi punta de vista consideraba que muchos de ellos eran imprácticos e innecesarios, entonces él los revisó y aquí es donde él me explicó: existen dos tipo de reportes que se implementan en el desarrollo de sistema: los reportes soporte a la operación y los reportes soporte a la toma de decisiones y que cuando para una aplicación no se ha hecho una adecuada toma de requerimientos, entonces lo que no puede exponer el programa el desarrollador lo hace con reporte(s). Y cuáles son los reportes soporte a la operación: son los reportes escenciales y que necesariamente se tienen que implementar pues la solución no tienen razón de ser si estos no son implementados, por ejemplo la impresión de una factura en un sistema de facturación, la impresión de una receta médica en un sistema de consultas médicas, la impresión de un cheque en un RP, el ticket en un sistema de punto de ventas, etc. Existen muchos de estos casos de reportes. Luego tenemos los reportes soporte a la toma de desiciones y cuyo objetivo es mostrar concentrados de información o información resumen cuyo objetivo es permitirle a los usuarios o empleados de la organización tomar de desiciones, por ejemplo un reporte que concentré las ventas del año pasado agrupadas por mes, un reporte de inventarios por categoria de producto, etc. Y para la demás información no se requiere un reporte pues está en pantalla, de ahí lo que me decia mi exjefe Ing. Arnulfo González si haz hecho una buena toma de requerimientos el sistema lo contendrá y no tendrás que elaborar un reportes excepto para los casos de reportes soporte a la operación o a la toma de decisiones. Así que desarrolladores cuando el usuario les pida reportes, ustedes identifiquen a que tipo de estás dos clasificaciones pertenece y lo que les sobre será información que estará presente en todo momento en pantalla y que no es necesario su impresión -como los de soporte a la operación cuya impresión es 100% necesaria.

Qué lenguaje de programación utilizar: VB.NET o C#

El pasado 26 de mayo de 2006 se realizó la tercera reunión de la comunidad .NET del D.F, en el auditorio "Carlos Graef" de la facultad de Ciencias de la UNAM. Se expusieron temas muy intersantes y por ahí alguien le preguntó a Octavio Telis sobre que lenguaje era mejor si VB.NET o C# y creo que su pregunta fue muy certera, pues el mencionó que en las primeras versiones había cosas que hacia C# y que no hacia VB.NET -cómo los tipos sin signo, etc- pero que esas diferencias ahora ya no existian entre ambos lenguajes, pero déspues mencionó lo que yo creo es lo más importante: "El objetivo del lenguaje es lo que está debajo de él: el Framework". Yo considero que está fue una respuesta muy intersante y cierta. A continuación pongo unos diagramitas que por ahí encontré en la web y que consideron que son muy importantes y que hacen alusión a este post.

mayo 23, 2006

El manejo de fechas en SQL Server

En algún momento hice una pequeña aplicación que seleccionaba n número de renglones de una tabla en SQL Server 2000, pero al ejecutarla ésta seleccionaba un número de registros menor a los que yo espera estuvieran en ese rango de fechas. Lo primero que yo pensé fue en la configuración regional del equipo y que éste tenia un formato de fecha diferente al que yo quería "dd-mm-aaaa" y que cómo ustes saben nuestros primos los gringos usan "mm-dd-aaaa", y ooh! sorpresa estaba bien la configuración regional, entonces le pregunte a un amigo y me dijo que era el lenguaje que tenia definido el SQL Server y que incluso esto era independiente del lenguaje de mi SQL Server puesto que es un valor configurable.

Y aquí encontré esta página que expone como utilizar las fechas independientemente del lenguaje con el que esté configurado SQL Server.



http://www.microsoft.com/spanish/msdn/comunidad/mtj.net/voices/art157.asp

Uso de XML con SQL Server 2000 para operaciones que requieren transacciones con n registros

En algún momento que leía un libro de SQL Server 2000 me sorprendió encontrar una forma de utilizar XML con SQL Server 2000 para poder insertar n registros en una sola operación -también llamada transacción-. Para poder lograr esto SQL Server 2000 cuenta con un procedimiento almacenado llamado: "sp_xml_preparedocument" que es el encargado de leer la cadena con formato XML y cargarla en la memoria para poder recorrerla.

A continuación expongo un ejemplo del caso de la inserción de un objeto Factura en la Base de Datos utilizando XML. Como todos sabemos una factura se compone de dos conceptos: un encabezado y un detalle, el encabezado es el que expone datos del cliente, la fecha y otros, estos datos conforman un registro o renglón en la Base da datos y se inserta en una tabla llamada Factura. El siguiente concepto u apartado que conforman a una factura es el Detalle, éste contiene a todos los registros o renglones de los conceptos que se están facturando al cliente y que pueden ser uno o más (ver figura del modelo Entidad/Relación) y aquí es en donde XML viene a facilitarnos la vida para poder insertar los dos objetos -el encabezado y el detalle- en una sola operación.











La solución se expone como un store procedure que recibe los datos que componen al encabezado y la cadena XML que compone a los del detalle, así que la única condición para que sp_xml_preparedocument pueda leer la cadena XML es que ésta sea válida.

Espero que les sea de mucha utilidad, porque casi que yo siempre la utilizó en los proyectos que desarrollo, pues el patrón maestro-detalle por lo regular siempre está presente de alguna forma en todo proyecto.

----------------------------------------------------------------------------
/*
Este procedimiento almancenado inserta un Encabezado-Detalle de una Factura.
El Detalle se pasa como una cadena XML con la siguiente estructura:

*/

CREATE PROCEDURE dbo.spInsertXMLEncDetFactura
(
@IdCte int,
@FechaFactura datetime,
@IVA numeric(8,2),
@SubTotal numeric(8,2),
@xmlDetFactura varchar(8000)--o tipo Text -Cadena XML con el detalle de la factura.
)
AS

DECLARE @idoc int --xmlDoc
DECLARE @IdFactura int --Nueva Folio Factura

--Ejecutar el sp que carga en memoria el docuemnto XML.
EXEC sp_xml_preparedocument @idoc output, @xmlDetFactura

--SET NOCOUNT ON
DECLARE @CurrentError int

--Comienza la transacción
BEGIN TRANSACTION
--Agregar el encabezado de la factura.

INSERT INTO FACTURA
(IdCte, FechaFactura, IVA, SubTotal)
VALUES (@IdCte, @FechaFactura, @IVA, @SubTotal);

--Verificar si hubo errores
SELECT @CurrentError = @@Error
IF @CurrentError != 0
GOTO ERROR_HANDLER


--Obtener el nuevo Identity de la tabla FACTURA.
SELECT @IdFactura = @@IDENTITY

--Agregar conceptos de FACTURA a la tabla DET_FACTURA.
INSERT INTO DET_FACTURA (IdFactura, IdProducto, CantidadProducto, PrecioProductoVta)
SELECT @IdFactura, IdProducto, CantidadProducto, PrecioProductoVta
FROM OPENXML (@idoc, '/DetFactura/Concepto')
WITH DET_FACTURA

--Verificar si hubo errores
SELECT @CurrentError = @@Error
IF @CurrentError != 0
GOTO ERROR_HANDLER


--Finalizar la Transacción
COMMIT TRANSACTION
SET NOCOUNT OFF

--Descargar documento XML de la memoria.
EXEC sp_xml_removedocument @idoc
--Retornar el nuevo No. de Solcitud de Compra.
RETURN @IdFactura

--Manejador de Error.
ERROR_HANDLER:
ROLLBACK TRANSACTION
--Descargar documento XML de la memoria.
EXEC sp_xml_removedocument @idoc
SET NOCOUNT OFF
RETURN 0
GO

mayo 15, 2006

Acceso a tu computadora virtual desde el navegador.

Hace unos días platiqué con mi amigo Alex y me comentó sobre un sitio desde el cual era posible acceder a una comútadora virtual desde el navegador, así que la visité y me sorprendió mucho la interfaz y las ventajas que da tener acceso a ésta. A mi me gusto lo de poder compartir carpetas con otros usuarios registrados. La interfaz es muy parecida a un ambiente gráfico de una distribución de Linux y lo más increíble es que es free. Aquí algunas de las caracteristicas que te ofrece son:

- Acceso a la computadora sólo tienes que escribir en la barra del navegador Computadora.de/usuario desde cualquier máquina conectada a Internet

- Correo.de.- Al registrarte en Computadora.de obtienes automáticamente una cuenta de correo electrónico y una adicional si elegiste un "alias"; ambas con terminación @correo.de. (uusario@@correo.de)

- Calendario.de.- Organízate y no llegues tarde, Calendario.de te avisa de tus citas pendientes.

- Directorio.de.- Almacena la información de toda la gente que conoces dentro de un programa en donde puedes consultarla con rapidez y eficiencia

- DiscoDuro.de.- Obtienes en tu DiscoDuro.de 100MB de espacio. Toda la información de tu computadora virtual, mensajes, documentos, citas y contactos, están disponibles donde quiera que estés. Crea nuevos directorios, sube tus tareas, fotos y accédelos desde cualquier máquina, sin tener que andar cargando diskettes. De necesitar espacio adicional, por favor haz doble clic en el icono de "Comprar espacio en disco duro"

- Mensajero.de.- Comunícate de forma instantánea con todos tus amigos, sin tener que configurar nada

- Programas.de.- Crea y guarda tus documentos con programas de procesador de palabras y hoja de cálculo compatibles y fáciles de usar

- PaginaWeb.de.- En tu DiscoDuro.de se encuentra una carpeta con este nombre donde podrás poner tu página hogar con imágenes, sonidos y lo que desees. Para acceder a tu página sólo tienes que escribir en la barra del navegador PaginaWeb.de/tu_usuario


http://computadora.de/

Script 2 para otorgar permisos de ejecución a sp a un usuario de SQL Server.

Este es otro script que permite otorgar permisos de ejecución a todos los procedimientos almacenados de una base de datos para un usuario en particular.

*****************************SCRIPT*********************************************
--Otorga permisos a todos los stores procedures para un determinado usuario.
--Precondiciones: establecer el nombre de la base de datos de uso y el nombre del usuario al que se desea otorgar los permisos.

Use x
--Nombre de Usuario al que se desea otorgar permiso.
Declare @user varchar(100)
Set @user = 'User1'

--Seleccionar a todos los objetos del tipo store procedure.
declare curse cursor for
SELECT name
FROM sysobjects
WHERE type = 'P' AND category = 0

OPEN CURSE
declare @proc varchar(100)
declare @stmt nvarchar(200)

fetch next from curse into @proc
while @@fetch_status=0
begin
--ejecuta el otorgamiento de permisos.
set @stmt='grant execute on '+@proc+' to ' +@user
exec SP_EXECUTESQL @STMT
print '***El usuario: ' + @user + ' puede ejecutar al store procedure: ' + @proc + '***'
fetch next from curse into @proc
end
--desocupa el cursor.
close curse
deallocate curse
GO
**************************FIN*SCRIPT*********************************************

Script 1 para otorgar permisos de ejecución a sp en SQL Server .

Recientemente yo tenía que otorgar permisos a muchos usuarios a muchos store procedures en SQL Server 2000 y hacerlo manualmente era una tarea tediosa, así que por ahí me encontré algo en internet para poder hacer esto.

Cuando ejecuten este script sólo especifiquen el nombre de la base de datos.
Después de ejecutarlo les aparecerán ciertos mensajes de error y que no afectan para
el objetivo. Este error se da porque en la consulta:

SELECT name FROM master..sysxlogins
WHERE srvid IS NULL AND name <> 'sa'

Se extraen a todos los usuarios en la base de datos y muy probablemente los usuarios
a los que desea otorgar permisos de ejecución a los SP no existen en la base de datos especificada, pero si los otorgará a los que si existen, de esta manera el
motor de SQL Server excluirá automáticamente a estos y lo expresará mediante un mensaje de error.

--*********************************SCRIPT****************************************
--Otorga permisos de ejecución a todos los sp a todos los usuarios de una base de datos.
--Especifique la BD que desea usar para otorgar.

Use NombreBD

--Variables de uso
Declare @login varchar(50), @proc varchar(100), @stmt nvarchar(200)

DECLARE loginBD CURSOR FOR
--Extraer a todos los logins, no importa que no estén en la BD de uso.
SELECT name FROM master..sysxlogins
WHERE srvid IS NULL AND name <> 'sa'

-- Avanzamos un registro y cargamos en las variables los valores encontrados en el primer registro
OPEN loginBD

FETCH NEXT FROM loginBD
--Vaciar el valor obtenido por el curos en una variable.
INTO @login

WHILE @@FETCH_STATUS = 0
BEGIN
Declare curse cursor for
--Obtener a todos los SP de la base de datos actual.
SELECT name
FROM sysobjects
WHERE type = 'P' AND category = 0
OPEN CURSE
fetch next from curse into @proc
while @@fetch_status=0
Begin
--Ejecutar los permisos
set @stmt='grant execute on '+@proc+' to ' +@login
exec SP_EXECUTESQL @STMT
If @@Error<> 0
print ''
Else
print '***El usuario: ' +@login + ' puede ejecutar al store procedure: ' + @proc
fetch next from curse into @proc
end
--Desocupar el cursor
close curse
deallocate curse

-----Siguiente Login
FETCH NEXT FROM loginBD
--Vaciar el siguiente valor obtenido por el curos en una variable.
INTO @login
END

--Desocupar el cursor.
CLOSE loginBD
DEALLOCATE loginBD
GO
--*****************************FIN*SCRIPT****************************************

mayo 10, 2006

Grupos de Noticias de Productos Microsoft.

De vez en cuando entrar a los grupos de discusión de Microsoft suele ser muy bueno porque de acuerdo al tema uno puede ayudar o otras personas o aprender de lo que se expone como pregunta-respuesta.


http://support.microsoft.com/newsgroups/


Despúes de ingresar a la página sólo seleccionen el idioma y un producto para ver las preguntas expuestas.

Tip de performance al usar una conexión de BD a través de un SqlDataAdapter.

Navegando en la web encontré un link que me llevó a un blog muy interesante y ahí en un post encontré información a cerca del manejo del pool de conexiones que hace ADO.NET cuando se utiliza un SqlDataAdapter. Se sabe que al ejecutar el método Fill del objeto SqlDataAdapter el objeto connection al que se ligaba se abre y cierra automáticamente, pero existen ocasiones en que en una msma secuencia de operaciones ejecutamos más de una vez un método Fill de un SqlDataAdapter y entonces, para cada caso se abre y cierra la conexión, pero en este blog expone que para obtener un mejor performance es recomendable abrir y cerrar la conexión manualmente abrirlá al momento de iniciar el primer Fill de un SqlDataAdapter y cerrarla después de ejecutar el último fill del SqlDataAdapter.

En el siguiente link esta el post que leí, además de que expone un ejemplo.


http://davidhayden.com/blog/dave/archive/2005/11/03/2554.aspx

Control Calendario para ASP.NET 1.1 y 2.0

Navegando en la red encontre un control calendario para ASP.NET 2003 y 2005. La descarga incluye una guia de instalación de este control e incluye ejemplos en C# y VB.Net. El control es realmente muy bueno y tiene varios conceptos de configuración.
Pueden desarcargarlo y probarlo de:


http://www.gotdotnet.com/Community/UserSamples/Details.aspx?SampleGuid=FED8B3BE-67E2-4BFC-BE34-404799B17D77

¿En dónde quedo el Enterprise Manager en SQL Server 2005 Express?

Cuando yo instalé SQL Server 2005 versión express, lo primero que yo quería hacer después de la instalación era navegar por las base de datos, conocer su nueva interfaz y ooh!! sorpresa no encontraba una aplicación tipo Enterprise Manager como la de SQL Server 2000, así que me puse a investigar en la web y encontré que Microsoft adicionalmente al motor de base de datos liberó una herramienta grafica llamada: Microsoft SQL Server Management Studio Express (SSMSE).

El link de donde es posible realizar su descarga es:


http://www.microsoft.com/downloads/details.aspx?familyid=82afbd59-57a4-455e-a2d6-1d4c98d40f6e&displaylang=en

mayo 02, 2006

Escucha música en línea.

Cuando estoy en la computadora siempre estoy escuchando música y he aquí un buen sitio de estaciones de radio que mi querida amiga Maru me recomendo. Si tienes una buena conexión a internet podrás disfrutar de las estaciones de música expuestas en esta página y aunque la página es brasileña existen estaciones que pasan música en inglés y otros idiomas.

http://radios.com.br

MP3 a muy bajo precio!!!

Hola! mi primo César encontró un link muy intersante para poder descargar música mp3 a muy bajo costo, incluso pueden escuchar un pequeño fragmento de la canación que desan descagar antes de pagarla, pueden comprar todo un álbum o determinado track de un álbum. Una vez que compran el track o el álbum este se encuentra disponible durante 24 horas para que lo puedan descargar a la hora qu quieran dentro de este lapso.

http://www.mp3sugar.com/

Modelos Entidad Relación disponibles.

Hola! hoy en día casi que cualquier tipo de aplicación que desarrollemos hace persistencia de datos en una base de datos relacional y como desarrolladores de aplicaciones es importante saber modelar la información en un modelo entidad-relación, pues éste diagrama es la base sobre la que comenzaremos a construir nuestra aplicación.

En el siguiente link podremos obtener muy buenas ideas en la construcción de nuestros modelos de Entidad-Relación.

http://www.databaseanswers.org/data_models/index.htm

SQL Server Express 2005

Hola! hace unos días descargué la versión Express de SQL Server y una vez instalado esperaba ver algo así como el Enterprise Manager de SQL Server 2000 y ohh!!! sorpresa no lo había, así que me puse a buscar en la web y encontré una página que expone todos los elementos que debes descargar para poder configurar y comenzar a utilizar el SQL Server 2005 Express.

href="http://www.ukaug.co.uk/TPExpress.asp">