Documentación de Velneo
30
30
  • Introducción
  • Velneo
    • Requerimientos de Velneo
    • Notas de la versión
    • Funcionalidades comunes a los componentes de Velneo
      • Instalación
      • Conexión con Velneo vServer
      • Cambiar el estilo de visualización
      • Ver u ocultar barras de herramientas
      • Mensajería interna entre usuarios
      • Soporte de alta resolución (HighDPI)
      • Carpetas de trabajo de los componentes de Velneo
      • Numeración de versiones de Velneo
      • Certificado de firma digital para componentes de Windows
    • Tipos de archivo generados por Velneo
    • Velneo Web
      • Plataformas y navegadores compatibles
      • Acceso a recursos del sistema
      • Siempre https
      • Funcionamiento de vatp por websocket
      • CORS para llamadas xmlhttprequest
  • Velneo vDevelop
    • ¿Qué es Velneo vDevelop?
    • Identificación de usuario
    • Interfaz de Velneo vDevelop
      • Menú Soluciones
      • Menú Proyectos
      • Menú Objetos
      • Menú Scripts
      • Menú Edición
      • Menú Ver
      • Menú Componentes
      • Menú Ayuda
    • Lista de teclas aceleradoras de Velneo vDevelop
    • Soluciones y proyectos
    • Control y edición de proyectos
    • Herencia
    • Inspectores
    • Proyectos objetos y editores
      • Proyecto de datos
      • Proyecto de aplicación
        • Crear CSS para aplicar a objetos en edición
      • Objeto
        • Refactorización automátca
      • Objetos de proyecto de datos
        • Indice complejo
        • Tabla
          • Actualización
          • Campo
          • Enlace
          • Indice
          • Plural
          • Traspaso de campo
          • Trigger
        • Tabla estática
        • Variable
      • Objetos de proyecto de aplicación
        • Acción
        • Alternador de lista
        • Arbol visor de tablas
        • Bloc de formularios
        • Casillero
        • Cesta
        • ComboView
        • Control SVG
        • Dispositivo serie
        • Formulario
          • Controles de visualización
            • Texto estático
            • Nombre de campo
            • Visor HTML
            • Dibujo
            • Imagen SVG
            • Caja de grupo
            • Menú arbolado
            • Barra de progreso
            • Reloj
            • Manómetro
            • Termómetro
          • Controles de edición
            • Caja de texto
            • Caja de texto enriquecido
            • Data catcher edit
            • Edición alfabética
            • Edición fecha
            • Edición fecha/hora
            • Edición fórmula
            • Edición hora
            • Edición numérica
            • Edición senda fichero
            • Edición senda directorio
            • Objeto dibujo
          • Controles de entrada
            • Botón
            • Botón de check
            • Botón de radio
            • Calendario
            • ComboBox
            • Deslizador
            • Dial
            • ListBox
            • Rueda
          • Contenedores
            • Área de scroll
            • Caja de formularios
            • Pila de formularios
            • Separador de formularios
            • Splitter
            • Vista de datos
          • Layout
          • Tree widget
          • Controles SVG
          • Extensión de ficha
        • Formulario QML
        • Gráfico
        • Imagen SVG
        • Impresora lógica
        • Informe
          • Editor de informes
          • Agrupamiento
          • Sección
          • Cálculo
        • Informe personalizable
          • Diseñando un informe personalizable básico
          • Diseño avanzado
          • Diseñando un informe personalizable
          • Añadiendo orígenes de datos
          • Añadiendo elementos al informe
          • Características avanzadas
          • Etiquetas
          • Asistente de scripts
          • Impresión de gráficos
          • Opciones html
        • ListView
        • Lista QML
        • Localizador
        • Marco
        • Menú
        • Multivista
        • Protocolo TCP-IP
        • Reemplazo
        • Rejilla
          • Propiedades de columna de rejilla
        • Rejilla avanzada
          • Propiedades de columna de rejilla avanzada
        • Toolbar
        • ViewFlow
        • Sub-objetos de vistas de datos
          • Conexión de evento
          • Drop
          • Inserción
          • Manejador de evento
      • Objetos comunes a proyecto de datos y de aplicación
        • Búsqueda
        • Cola
        • Constante
        • Dibujo
        • Esquema de tablas
        • Fichero adjunto
        • Función
        • Librería externa
        • Lupa
        • Proceso
          • Indice de comandos de instrucción de proceso
          • Comandos de base de datos
            • API
            • Bases de datos externas
            • Búsquedas
            • Campos (grupo de comandos)
            • Cestas
            • Fichas
            • Fichas seleccionadas
            • Listas
            • Tablas
            • Tubos
          • Básicos
            • Controles de flujo
            • Debug
            • Ejecución
            • Salida/retornos
            • Scripts (grupo de comandos)
            • Transacciones (comandos)
            • Variables
          • Comunicación
            • GPS
            • Internet
            • Protocolo TCP
            • Puerto serie
            • SDV
          • Interfaz
            • Acciones (comandos)
            • Control
              • Ejemplo de CSS
            • Diálogos
            • Formularios - comandos
            • Localizadores
            • Objeto - grupo de comandos
            • Ventana principal
            • Vista de datos - comandos
          • Sistema
            • Comandos de Sistema
            • Configuración
            • Directorios
            • Ficheros
        • Tubo de ficha
        • Tubo de lista
        • Variable local
      • Editores
        • Asistente de fórmulas
          • Operadores
          • Funciones estándar
            • Funciones API
            • Funciones básicas
            • Funciones de cadenas
              • Expresiones regulares
            • Funciones científicas
            • Funciones de Cliente-servidor
            • Funciones de color
            • Funciones de códigos
            • Funciones de directorios
            • Funciones de fechas
            • Funciones de ficha en curso
            • Funciones de horas
            • Funciones JSON
            • Funciones de Internet
            • Funciones de juegos de caracteres
              • Codecs
            • Funciones numéricas
            • Funciones de sistema
            • Funciones de tiempo
            • Funciones trigonométricas
          • Funciones de dll
          • Funciones de proceso
          • Funciones de campo
          • Campos
          • Constantes
          • Variables globales
          • Variables locales
          • Variables del sistema
          • Verificador de fórmulas
          • Conversión automática de datos
          • Introducción de datos literales
          • Secuencias de escape en cadenas de caracteres
          • Composición de sendas en fórmulas
          • Operar con datos de tipo fecha, hora y tiempo
        • Editor de imágenes
        • Selector de fuentes
    • Scripts
      • Lenguajes
        • JavaScript
          • Procesos JavaScript
          • Fórmulas JavaScript
          • Clases
            • Funciones globales
            • Objetos
            • VAbstractBrowser
            • VAbstractDataView
            • VAbstractListDataView
            • VAdvandedGridListDataView
            • VAlternatorListDataView
            • VApp
              • VApp: enumeraciones
              • VApp: ejemplos
            • VBoundFieldComboBox
            • VBoundFieldEdit
            • VBoundFieldEditBrowser
            • VBoundFieldListBox
            • VByteArray
            • VCheckBox
            • VClipboard
            • VClockWidget
            • VComboBox
            • VComboListDataView
            • VCoverFlowListDataView
            • VCWebView
            • VDataCatcherEdit
            • VDataCatcherEditBrowser
            • VDataView
            • VDataViewDialog
            • VDateEdit
            • VDateEditBrowser
            • VDateTimeEdit
            • VDateTimeEditBrowser
            • VDial
            • VDir
              • VDir: enumeraciones
            • VExtension
              • VExtension: enumeraciones
            • VFile
              • VFile: enumeraciones
            • VFileInfo
            • VFilePathEditBrowser
            • VFinder
            • VFont
              • VFont: enumeraciones
            • VFormBlockListDataView
            • VFormDataView
            • VFormulaEditBrowser
            • VGaugeWidget
            • VGPS
            • VGridListDataView
            • VGroupBox
            • VImage
            • VImageEdit
            • VImageWidget
            • VInstancesList
            • VInstance
            • VInstances
            • VItemRegisterPattern
            • VLabel
            • VLineEdit
            • VLineEditBrowser
            • VListBox
            • VListDataView
            • VLogin
            • VMainWindow
              • VMainWindow: enumeraciones
            • VMdiView
            • VMimeData
            • VMultiDataView
            • VNumberSpinBox
            • VNumberSpinBoxBrowser
            • VObjectInfo
              • VObjectInfo: enumeraciones
            • VObjectInstance
            • VProcess
            • VProgressBar
            • VProjectInfo
            • VPushButton
            • VQmlFormDataView
            • VQmlListDataView
            • VQmlListModel
            • VQuery
            • VRadioButton
            • VRegister
            • VRegisterList
            • VReportListDataView
            • VRequest
            • VResponse
            • VRoot
            • VScreen
            • VScrollArea
            • VServerAdmin
            • VSettings
            • VSlider
            • VSlotListDataView
            • VSolutionInfo
            • VSplitter
            • VSqlDatabase
            • VSSLCertificate
            • VSSLInfo
            • VSSLSessionCipher
            • VStackedWidget
            • VSvgButton
            • VSvgSlideSwitch
            • VSvgToggleSwitch
            • VSvgWidget
            • VSysInfo
              • VSysInfo: enumeraciones
            • VTableInfo
              • VTableInfo: enumeraciones
            • VTabWidget
            • VTextEdit
            • VTextFile
            • VThermometerWidget
            • VThumbWheel
            • VTimeEdit
            • VTimeEditBrowser
            • VToolBox
            • VTreeItem
            • VTreeItemRegister
            • VTreeListDataView
            • VTreeMenu
            • VTreeMultiTableListDataView
            • VTreeWidget
            • VUser
            • VUserGroup
            • VUserGroupList
            • VUserList
            • VXmlReader
            • VXmlWriter
            • Widget
            • XMLHttpRequest
        • QML
          • Tipos QML
          • Funciones específicas de QML
    • Depuración
      • Depuración de procesos de Velneo
      • Depuración de procesos JavaScript
      • Monitor de vClient
    • Extensiones de Velneo vDevelop
    • Acceso directo a una solución desde vDevelop
    • Buenas prácticas
      • Buenas prácticas de organización
        • Proyectos
        • Organización de carpetas
        • Proyecto de datos
        • Proyecto de aplicación
      • Buenas prácticas de codificación
        • Identificadores
        • Teclas aceleradoras
        • Documenta
        • Diseña los formularios como si no existiesen los layouts
      • Buenas prácticas de rendimiento
        • Arquitectura
          • Listas de registros
          • Lista de resultados de una búsqueda
          • Las cestas
          • Las variables globales
          • La caché de fichas
          • Programa en cloud
        • Formularios
          • Condiciones de visible y activo
          • Carga de subformularios en pestaña, caja o pila
        • Base de datos
          • Campos
          • Indices
          • Actualizaciones
          • Eventos de tabla o triggers
          • Variables globales y constantes
          • Tablas en memoria vs tablas en disco
          • Optimizar migraciones de datos
          • Búsquedas en el servidor ¿Cuándo y Cómo?
          • Campos fórmula vs campos en disco
          • Indices condicionados vs búsquedas complejas
          • ¿Cuándo usar tablas de extensión?
          • Indices de trozos y palabras
          • ¿Cuándo usar cada tipo de campo alfa?
        • Procesos y funciones y eventos
          • 1º, 2º, 3º y 4º plano ¿Cuándo usar cada uno?
          • Bloqueo blando vs bloqueo duro
          • Pasar información del cliente al servidor
          • ¿Cómo optimizar transacciones grandes?
          • ¿Cómo gestionar las transacciones?
          • Grabaciones optimizadas para el usuario
        • Carga de registros en objetos de lista
          • Rejillas
            • Campos punteros a singular
            • Totales
            • Condiciones de activo, visible y color en columna
            • Campos de tipo objeto
        • Conoce los límites
      • Imágenes
      • Buenas prácticas para el desarrollo en equipo
      • Modo mantenimiento
    • Análisis de bases de datos para aplicaciones de Velneo
      • Un centro de enseñanza
      • Facturas de un cliente
      • Repartos de obras de teatro
      • Galería de arte
      • Gestión de un colegio
      • Instalación de lunas para vehículos
      • Libros y autores
      • Tienda de discos
      • Últimos pedidos de un proveedor
      • Existencias por almacén y precios por cliente
      • Generación de tickets para un quiosco
      • Navegación por facturas
  • Velneo vDevelop Web
  • Velneo vAdmin
    • ¿Qué es Velneo vAdmin?
    • Gestión de usuarios
    • Gestión de aplicaciones
      • Soluciones
      • Instancias
      • Disco
    • Monitorización
      • Lista de comandos
    • Tareas
    • Acceso directo
    • Velneo vAdmin Web
  • Velneo vClient
    • ¿Qué es Velneo vClient?
    • Movilidad
    • Funcionalidades de Velneo vClient
      • Accesos directos y VRL
      • Cambiar idioma
      • Panel de procesos en 2º plano
      • Manejo de rejillas
        • Submenú de filtros
      • Uso de la rejilla avanzada
      • Manejo de cestas
      • Refrescos
      • Caché local
      • Edición de campos enlazados a maestro
      • Edición de campos de tipo fecha
      • Capturar imagen desde una cámara
      • Asignar impresoras lógicas
      • Actualización automática
      • Personalización de la ventana de conexión de Velneo vClient
      • Instalador personalizado de Velneo vClient
      • Ordenación de listas
  • Velneo vServer
    • ¿Qué es Velneo vServer?
    • Instalación y configuración
      • Activación de la licencia
      • Línea de comandos de Velneo vServer
      • Parámetros configurables de Velneo vServer
      • Estructura de directorios
    • Iniciar y detener Velneo vServer
    • Funcionalidades
      • Protocolo VATP
      • Protocolo VATPS
      • Multi-hilo
      • Integridad referencial
      • Refrescos terciarios
      • Sistema transaccional
      • Sistema de bloqueos
      • Tecnología bigkey
      • Hilo de control
    • Mensajes de log de sistema
    • vPacker
  • Velneo vInstallBuilder
    • ¿Qué es Velneo vInstallBuilder?
    • Configurar una instalación
    • Probar una instalación
    • Crear el instalable
    • Accesos directos
  • Velneo vModApache
    • ¿Qué es Velneo vModApache?
    • Instalación y configuración
    • Nomenclatura de objetos en urls
    • Uso de ficheros adjuntos
    • Caché local de Velneo vModApache
  • Velneo vDataClient
    • ¿Qué es Velneo vDataClient?
    • Iniciar Velneo vDataClient
    • Interfaz de Velneo vDataClient
    • Procesos
    • Utilidades
    • Acceso directo a una instancia de datos
    • Velneo vDataClient Web
  • Velneo vTranslator
    • ¿Qué es Velneo vTranslator?
    • Importación y exportación basada en XLIFF
    • Acceso directo a una solución
  • Velneo ODBC Driver
    • ¿Qué es velneo ODBC Driver?
    • Referencia de comandos SQL
  • Velneo vVersion
    • ¿Qué es Velneo vVersion?
  • Velneo vERP
    • ¿Qué es Velneo vERP?
    • Manual del programador
    • Documentación de la ApiRest
    • Novedades de la versión
  • Velneo vTutor
    • ¿Qué es vTutor?
    • Tutores de objetos básicos
      • Tutor de árboles visores de tablas arboladas
      • Tutor de búsquedas
      • Tutor de cestas
      • Tutor de formularios
      • Tutor de informes
      • Tutor de localizador básico
      • Tutor de marcos
      • Tutor de rejillas
      • Tutor de rejillas avanzadas
    • Tutores de objetos avanzados
      • Tutor de alternadores de lista
      • Tutor de comboview
      • Tutor de drag and drop
      • Tutor de eventos
      • Tutor de tablas de extensión y extensiones de ficha
      • Tutor de tubos de ficha y de lista
      • Tutor de grabación de fichas
      • Tutor de gráficos
      • Tutor de impresión de informes
      • Tutor de lupas
      • Tutor de protocolo TCP/IP
      • Tutor de reemplazo
    • Tutores de controles
      • Tutor de botones de menú
      • Tutor de controles SVG
      • Tutor de edición numérica
      • Tutor de visor html dinámico
      • Tutor de vistas de datos de lista
    • Tutores de procesos y manejadores de evento avanzados
      • Tutor de cambio de marco
      • Tutor de comandos de interfaz y acciones
      • Tutor de importación y exportación de ficheros ASCII
      • Tutor de portapapeles
      • Tutor de procesos
      • Tutor de SDV
    • Tutores de scripts
      • QML: hola mundo
      • QML: tutor básico
      • QML: tutor de vistas
      • Tutor de XMLHttpRequest (webServices)
  • Velneo cloud
    • ¿Qué es Velneo Cloud?
    • Panel de control vServer cloud
      • URC
      • vServer
      • Apache
      • SFTP
      • Usuarios
    • Copias de seguridad
    • Velneo cloud API
      • Uso de Velneo cloud API
    • Explorador de archivos cloud sFTP
    • TCP en Velneo cloud
    • Dominios de empresa y certificados
    • Velneo vModApache en cloud
    • SLA
    • Hora de los servidores en el cloud de Velneo
    • ¿Qué puedo hacer si tengo una incidencia en mi servidor cloud?
Con tecnología de GitBook
En esta página
  • Crea siempre los índices de campos punteros a maestros
  • Evita el cambio de código de maestro siempre que sea posible
  • Evita los índices "duplicados" que tienen la parte izquierda común
  • ¿Cuándo usar índices condicionados?
  • Los índices acepta repetidas ocupan 4 bytes más
  • Los índices de clave única son más rápidos
  • Usa la longitud y conversión de la parte del índice para reducir el tamaño
  • Índices de trozos y palabras
  • Índices complejos
  • Por cada índice complejo crea código para regenerarlo la primera vez que se instancia
  • ¿Cuándo debo usar un índice complejo?

¿Te fue útil?

  1. Velneo vDevelop
  2. Buenas prácticas
  3. Buenas prácticas de rendimiento
  4. Base de datos

Indices

Última actualización hace 4 años

¿Te fue útil?

Crea siempre los índices de campos punteros a maestros

La base de datos Velneo tiene algunos automatismos realmente interesantes, uno de ellos es la creación automática de los enlaces plurales, este subobjeto es totalmente dinámico y se crea en tiempo de ejecución en base a los índices existentes en las tablas, de tal forma que si las primeras partes de un índice coinciden con el índice ID de una tabla maestra se crea automáticamente el subobjeto enlace plural. Este subobjeto permite navegar por la información desde la tabla maestra a su plural.

Además de la navegación desde el maestro a su plural este subobjeto permite el funcionamiento a otro automatismo de la base de datos, el despliegue del cambio de código del maestro a sus plurales. Es decir, si un maestro tiene el código 100 y por algún motivo necesitamos ponerle el código 200, al hacerlo la base de datos de Velneo se encarga de cambiar el código en todas las tablas plurales que apuntan a este registro maestro.

Para que el cambio de código funcione bien y no nos llevemos ninguna sorpresa es necesario que existe un enlace plural. Por este motivo es fundamental que creemos siempre un índice en la tabla plural a través del campo puntero a maestro, en el caso de las tablas submaestras el índice tiene varias partes pero el funcionamiento es similar. Este índice se crea automáticamente cuando creamos el campo puntero a maestro con las herramientas del editor de esquemas o con el selector de tabla maestro en el editor de tabla. Si añadimos el campo manualmente o copiando de otro campo debemos tener la precaución de crear el índice.

Debemos tener en cuenta que en muchas ocasiones tenemos índices condicionados, es decir que indexan a través del campo puntero a maestro pero solo indexan algunos registros, los que cumplen la condición. Esto debemos tenerlo presente ya que en ese caso el cambio de código solo se aplicaría en los registros que cumplen la condición, pero nos quedarían otros registros con el código antiguo lo que supondría un gran problema. Por ejemplo, si tenemos la familia A100, y en la tabla de artículos solo tenemos un índice por familia que indexa los que tienen existencia. Si cambiamos el código de la familia a B200, solo se cambiaría en los artículos con existencia, quedando erróneamente otros artículos con el código de familia A100, que en caso de ser reutilizado supondría tener una base de datos errónea. Por este motivo, si tenemos que crear índices condicionados es conveniente también tener un índice al maestro sin ninguna condición, es decir que indexe todos los registros.

Evita el cambio de código de maestro siempre que sea posible

Es cierto que no es habitual cambiar los códigos ID de las tablas maestras, y en muchos casos ese dato ni se visualiza en pantalla ni se deja cambiar al usuario, pero en una base de datos existen muchas tablas con circunstancias "especiales", por ejemplo tablas cuyos registros nacen de la importación de información de otro sistema o que son claves que cambian con el tiempo.

Lo más recomendable en Velneo es crear siempre la tabla maestra con el campo ID y añadir otros campos de códigos externos que pueden cambiar, pero dejando siempre como enlace entre el maestro y sus plurales a través del ID que genera Velneo. Esto es lo más habitual y recomendable, porque aunque los artículos tengan referencias o códigos de barras y los clientes tengan un CIF o un DNI siempre será más óptimo indexar y apuntar a tablas del campo ID numérico que tendrá un máximo de 4 bytes. De esta forma ganamos espacio y rendimiento.

Si en alguna tabla, por ejemplo de tipo arbolada, necesitamos usar códigos que nos vienen dados por terceros, debemos tener en cuenta lo comentado en el punto anterior sobre tener siempre índices en las tablas plurales sin condicionar que nos aseguren que cualquier cambio en el código del maestro se aplicará en todos sus plurales.

Evita los índices "duplicados" que tienen la parte izquierda común

En tablas grandes con muchos campos y muchos índices hay que tener especial precaución con los índices que se crean ya que es muy fácil crear índices "duplicados" si no tomamos medidas para evitarlo.

¿Qué es un índice duplicado? Obviamente el primer caso de índices duplicados es aquél en que ambos índices son exactamente iguales, pero también podemos considerar que un índice está duplicado cuando sus partes coinciden con las primeras partes de otro índice. Veamos un ejemplo.

Es muy habitual que a medida que va creciendo el proyecto se vayan creando nuevos índices, en el ejemplo anterior es posible que inicialmente se haya creado el índice ART_EMP con esas 2 partes y posteriormente se creó el índice ART_EMP_ALM con 7 partes, si el responsable de base de la base de datos no tiene cuidado quedarían los 2 índices creados cuando realmente no es necesario ya que podemos utilizar el índice ART_EMP_ALM buscando por parte izquierda resolviendo solo el artículo y empresa, obteniendo de esta forma el mismo resultado que si usamos el índice ART_EMP. Cuando encontremos un caso de estos nos quedaremos con el índices de más partes y refactorizaremos los objetos que usaban ART_EMP para que usen ART_EMP_ALM por parte izquierda o incluso también se puede usar entre límites.

La mejor forma de evitar tener índices duplicados es poner buenos identificadores a los índices para que expresen bien sus partes y organizar los índices de las tablas por orden alfabético. De esta forma detectamos fácilmente las duplicidades de un vistazo, como se puede apreciar en la siguiente captura.

Es evidente que ver un índice ART_EMP al lado de otro que se llamada ART_EMP_ALM es un claro indicativo de que puede haber una duplicidad, aunque podría darse la circunstancia de que tengan diferente condición de indexación, algo que debería reflejarse en el identificador.

¿Cuándo usar índices condicionados?

Los índices condicionados son una gran herramienta para el programador. En principio su uso es totalmente aconsejable ya que con ellos mejoramos el rendimiento de nuestras aplicaciones al evitar búsquedas más complejas o filtrados.

Es cierto que el tiempo de indexación de un índice condicionado es aproximadamente un 30% superior a un índice sin condicionar, al tener que evaluarse la fórmula de la condición, pero este tiempo además de que solo nos penaliza una única vez en el alta, baja o modificación, es muy pequeño, por lo que podemos asumirlo sin ningún problema dadas las ventajas que nos aporta.

Siempre que tengamos estados de registros, los índices condicionados son un gran aliado ya que podemos obtener de forma directa los registros adecuados ordenados en función de las partes definidas. Sin duda alguna una herramienta a tener en cuenta y usar de forma constante.

Hay dos casos en los que no merece la pena crear índices condicionados:

  1. Si un índice condicionado solo se usa una vez al año para un informe concreto, no tiene mucho sentido crear en la tabla un índice que estará infrautilizado para ganar unos segundos en un informe que apenas se utiliza.

  2. Si tengo decenas de estados, en lugar de crear decenas de índices condicionados tiene más sentido crear un índice por el campo estado y buscar de forma directa un estado.

Los índices acepta repetidas ocupan 4 bytes más

El tamaño de un índice viene dado por la suma de tamaño de las partes que lo componen, sin embargo en un índice de tipo acepta repetidas debemos tener en cuenta que Velneo añade 4 bytes al tamaño del índice. Esto lo hace porque aunque acepte claves repetidas la base de datos necesita poder apuntar a cada registro de forma única. Al añadir 4 bytes Velneo permite hasta 4.000 millones de repeticiones de una clave. Es decir que aunque para nosotros a nivel de programación se aceptan claves duplicadas, internamente se comporta como si fuese un índice de clave única, aunque nosotros como programadores nunca veremos los 4 bytes adicionales que componen el índice.

Los índices de clave única son más rápidos

A la hora de regenerar una tabla o indexar alguno de sus índices podemos observar que los índices de clave única son más rápidos en estas operaciones que los de acepta repetidas, lógicamente en este proceso influye lo comentado en el apartado anterior del control de claves repetidas. Además, cuanta menos repetición de claves tengamos más rápido se indexa un índice.

En un índice acepta repetidas el orden de los registros vendrá dado por el orden de creación de dicho registro, este comportamiento puede ser deseado o no. En caso de que queramos garantizar un orden específico conviene añadir más partes a nuestro índice, intentando siempre en la medida de los posible crear el índice con el menor tamaño posible. Por ejemplo, en la tabla de facturas podemos crear un índice por el cliente de tipo acepta repetidas, pero puede ser mucho más interesante crearlo con las partes cliente y fecha, de esta forma cuando carguemos plurales de facturas del cliente nos aparecerán ordenadas por fecha, si además en el índice añadimos el ID o el número de la factura y podemos poner el índice de tipo clave única, además de ser un índice más rápido para la reindexación conseguiremos que en caso de que un cliente tenga más de una factura en la misma fecha salgan ordenadas por número.

En definitiva, que es más recomendable tener índices de clave única para lo cual en las tablas maestras siempre podremos conseguirlo de forma sencilla añadiendo el ID como última parte del índice.

Usa la longitud y conversión de la parte del índice para reducir el tamaño

Cuando tenemos que indexar un campo alfabético con un tamaño grande (>50 caracteres) puede ser muy buena opción aplicar una indexación parcial. Salvo que sea necesario indexar de clave única, podemos utilizar la propiedad longitud para reducir el tamaño del índice.

En el ejemplo anterior vemos como al especificar la propiedad longitud en el campo NAME nos permite reducir el tamaño del índice a 12 bytes. De esta forma solo se indexarán los primeros caracteres del campo, algo que en la mayoría de las ocasiones no supone ningún problema ya que no es habitual que coincidan, y en el caso de que coincidan estarían juntos en la lista.

Por otro lado la propiedad conversión nos permite indicar que aunque el campo sea de tipo Alfa 256, a la hora de indexarlo, en el índice se indexe como Alfa 128, Alfa 64 o Alfa 40 consiguiendo de esta forma que se puedan encontrar los registros tanto en minúsculas como en mayúsculas y sobre todo que con una longitud de 12 bytes en el índice estemos indexando por los 18 primeros caracteres del campo NAME.

Índices de trozos y palabras

Sin duda son los índices más potentes de la base de datos de Velneo, su gran virtud es la potencia de búsqueda su mayor problema es el tamaño en disco y la reindexación. Por este motivo hay que equilibrar su uso.

En tablas con pocos registros no hay ningún problema generar ambos índices, pero en tablas con millones de registros tenemos que tratar de evitar que el índice nos cause problemas de rendimiento, en algunos casos puede ser conveniente generar solo el índice por palabras ya que es mucho más reducido que el de trozos, pensemos que la palabra “Amortiguador” generaría una única entrada en el índice de palabras, pero 10 entradas (Amo, mor, ort, rti, tig, igu, gua, uad, ado, dor) en el índice por trozos, lo que supone una gran ocupación en disco y un mayor tiempo de reindexación.

Debemos evitar siempre crear, siempre que sea posible, varios índices de trozos y palabras. Es decir, no tiene sentido crear el índice por palabras para el campo nombre y otro índice por palabras para el campo dirección, en ese caso debemos crear un único índice por palabras añadiendo ambos campos como partes del mismo índice, además de tener menos índices lo que mejora el tiempo de reindexación ya que solo se lee el registro una vez para reindexar ambos campos sino que además nos permite que el usuario busque por cualquier de los dos datos a la vez sin tener que pedirle dos datos en pantalla o tener que hacer 2 búsquedas y cruzarlas.

Hay que tener en cuenta que podemos incluir en los índices por trozos y palabras campos de tipo objeto texto y objeto texto enriquecido, en este último caso Velneo se encarga de quitar las etiquetas HTML e indexar solo el contenido del campo. Debemos ser precavidos a la hora de indexar este tipo de campos por trozos o palabras ya que el número de entradas en el índice puede ser gigantesco dependiente de lo que grabemos en dichos campos ya que debemos recordar que son de longitud variable y si el usuario quiere puede meter en un campo el contenido de un libro. Además de la ocupación en disco, dar de alta un registro que tenga que indexar un gran volumen de palabras o trozos de palabras puede suponer un retardo que produzca una mala experiencia para el usuario.

Índices complejos

Este tipo de índice como su nombre indica es un objeto sencillo de definir pero con una funcionalidad realmente compleja que resuelve casos que requieren mucha programación o que gracias al uso de este tipo de índice se consiguen unos rendimientos que no podemos alcanzar mediante programación.

Por cada índice complejo crea código para regenerarlo la primera vez que se instancia

Es muy importante tener en cuenta que aunque los índices complejos se reindexan automáticamente al cambiar las partes tienen el hándicap de que no se indexan la primera vez que se crean, algo que debemos tener en cuenta si creamos un índice complejo sobre tablas que contienen datos. Una buena práctica consiste en crear el código necesario para forzar su indexación inicial cuando instalamos la versión de nuestra aplicación.

¿Cuándo debo usar un índice complejo?

Poder indexar registros de una tabla por datos que se encuentran almacenados en otras tablas nos ayuda a reducir el tamaño de las tablas al no tener que duplicar información redundante para poder indexarla, nos evita programación adicional para reflejar los cambios de datos en la tabla donde queremos indexar, sin embargo, también tiene como pro que regenerar índices complejos de tablas grandes va a requerir tiempo y puede que mucho espacio en disco, en función del tamaño de las partes a indexar.

Ejemplos típicos de índices complejos son:

  • Indexar contactos por sus direcciones, teléfonos, emails.

  • Indexar ventas por las palabras del artículo.

  • Indexar facturas por los trozos del nombre del cliente.

Por este motivo hay que tener precaución a la hora de generar índices complejos de tablas con millones de registros con un índice por trozos o palabras ya que estaríamos creando un índice enorme en tamaño y con un tiempo de reindexación muy elevado. Esto no quiere decir que no podamos crear un índice complejo por trozos o palabras del nombre del artículo indexando las líneas de venta, pero sí debemos tener en cuenta el tamaño y la ocupación para decidir si por ejemplo solo lo generamos por palabras que será mucho más pequeño que si lo hacemos por trozos.