/// <summary>
        /// Cancela una venta.
        /// </summary>
        /// <param name="venta">La venta a cancelar.</param>
        /// <exception cref="ReglasNegocioException">Si ocurre un error de negocio.</exception>
        public void CancelarVenta(Venta venta)
        {
            BaseDatos db = new BaseDatos();

            try {
                db.Conectar();
                db.ComenzarTransaccion();

                string sql = "DELETE ItemsVenta WHERE Codigo = @codigo";
                foreach (ItemVenta item in venta.Items)
                {
                    db.CrearComando(sql);
                    db.AsignarParametroEntero("@codigo", item.Codigo);
                    db.EjecutarComando();
                }

                sql = "DELETE Ventas WHERE Codigo = @codigo";
                db.CrearComando(sql);
                db.AsignarParametroEntero("@codigo", venta.Codigo);
                db.EjecutarComando();

                db.ConfirmarTransaccion();
            } catch (BaseDatosException ex) {
                db.CancelarTransaccion();
                throw new ReglasNegocioException("Error al cancelar la venta.", ex);
            } finally {
                db.Desconectar();
            }
        }
        /// <summary>
        /// Confirma una venta registrando sus ítems en el sistema.
        /// La venta debe poseer items.
        /// </summary>
        /// <param name="venta">La venta a registrar.</param>
        /// <exception cref="ReglasNegocioException">Si ocurre un error de negocio.</exception>
        public void ConfirmarVenta(Venta venta)
        {
            if (venta.Items.Count.Equals(0))
            {
                throw new ReglasNegocioException("La venta no contiene ningún ítem.");
            }

            BaseDatos db = new BaseDatos();

            try {
                db.Conectar();
                db.ComenzarTransaccion();

                string sql = "INSERT ItemsVenta (CodigoVenta, CodigoProducto, Cantidad) VALUES (@venta, @producto, @cantidad); SELECT @@IDENTITY";
                foreach (ItemVenta item in venta.Items)
                {
                    db.CrearComando(sql);
                    db.AsignarParametroEntero("@venta", venta.Codigo);
                    db.AsignarParametroEntero("@producto", item.Producto.Codigo);
                    db.AsignarParametroEntero("@cantidad", item.Cantidad);
                    item.Codigo = db.EjecutarEscalar();
                }
                db.ConfirmarTransaccion();
            } catch (BaseDatosException ex) {
                db.CancelarTransaccion();
                throw new ReglasNegocioException("Error al registrar la venta.", ex);
            } finally {
                db.Desconectar();
            }
        }