Documentación de Velneo
29
29
  • 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?
    • 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
      • 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
            • 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
            • VBoundFieldComboBox
            • VBoundFieldEdit
            • VBoundFieldEditBrowser
            • VBoundFieldListBox
            • VByteArray
            • VCheckBox
            • VClipboard
            • VClockWidget
            • VComboBox
            • VComboListDataView
            • VCoverFlowListDataView
            • VCWebView
            • VDataCatcherEdit
            • VDataCatcherEditBrowser
            • VDataView
            • VDataViewDialog
            • VDateEdit
            • VDateEditBrowser
            • VDateTimeEdit
            • VDateTimeEditBrowser
            • VDial
            • VDir
            • VExtension
            • VFile
            • VFileInfo
            • VFilePathEditBrowser
            • VFinder
            • VFont
            • VFormBlockListDataView
            • VFormDataView
            • VFormulaEditBrowser
            • VGaugeWidget
            • VGridListDataView
            • VGroupBox
            • VImage
            • VImageEdit
            • VImageWidget
            • VInstancesList
            • VInstance
            • VInstances
            • VItemRegisterPattern
            • VLabel
            • VLineEdit
            • VLineEditBrowser
            • VListBox
            • VListDataView
            • VLogin
            • VMainWindow
            • VMdiView
            • VMimeData
            • VMultiDataView
            • VNumberSpinBox
            • VNumberSpinBoxBrowser
            • VObjectInfo
            • 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
            • VTableInfo
            • 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
    • 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 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 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
    • 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

¿Te fue útil?

La pieza más importante en el análisis de una aplicación es sin duda la base de datos. Podríamos afirmar que un buen diseño de base de datos garantiza rendimiento y mantenibilidad mientras que un mal diseño nos garantiza problemas que se irán agravando con el paso del tiempo.

Demos tratar de diseñar nuestra base de datos con la mayor sencillez posible, de lo contrario cualquier corrección, mejora o evolución se convierte en una tarea compleja y por lo tanto mucho más costosa. A continuación vamos a ver algunas buenas prácticas a la hora de diseñar la estructura de base de datos de nuestra aplicación.

Una base de datos, un responsable

Dada la importancia de la base de datos es fundamental que esté bajo la tutela de un único responsable. Esto no significa que solo una persona pueda hacer cambios, que también puede ser una buena práctica, sino que no debería de realizarse ningún cambio en la base de datos sin que el responsable esté informado y valide dicho cambio. Ya que de no hacerse así corremos el riesgo de que la base de datos contenga campos que ya no se utilizan pero que nadie se atreve a borrar, índices duplicados en tablas muy grandes donde es más difícil controlar todo lo que ya existe, etc. En definitiva, cada base de datos debe tener un responsable único.

Esquemas

Crea esquemas para documentar las tablas

Cuando comenzamos a desarrollar una aplicación lo haremos desarrollando la estructura de base de datos, para realizar esa tarea es recomendable crear un objeto esquema que nos permitirá crear las tablas de forma visual y además dejarlo documentado para en el futuro poder recordar de un vistazo las relaciones entre las diferentes tablas. El objeto esquema hace bueno el dicho "Una imagen vale más que mil palabras".

Conviene crear las tabla directamente desde el esquema ya que además de crear el objeto ya lo dejamos incrustado en el esquema lo que nos facilitará crear las relaciones de forma visual.

Crea múltiples esquemas

A medida que vamos añadiendo tablas a nuestro proyecto conviene crear múltiples esquemas con el doble objetivo de evitar tener un esquema con tantas tablas y relaciones que resulta muy complicado ver la estructura y entenderla, y por otro lado nos permite tener esquemas específicos con la estructura de sub módulos o funcionalidades específicas, consiguiendo que otros desarrolladores entienda la estructura de tablas y sus relaciones rápidamente.

Número de tablas y tamaño de registros

¿El número de tablas influye en el rendimiento?

Salvo que estemos hablando de miles de tablas, en cuyo caso podría afectarnos en el tiempo de reinicio de la instancia en el servidor, a nivel de ejecución hay que tener en cuenta que nos afectan las tablas en uso, no las declaradas en el proyecto.

¿El tamaño de registro de una tabla como influye?

Influye en el tamaño de las transacciones, en el nº de conexiones que un cliente tiene que establecer con el servidor para obtener los datos de una lista de registros y en los tiempos de regeneración de la tabla ante un cambio de estructura.

Por lo tanto debemos intentar reducir el tamaño de registro de una tabla en la medida de lo posible. Unas buenas prácticas podrían ser:

  • Evita crear campos que no se usan.

  • Si se necesitan campos alfabéticos muy largos (>100 caracteres) que se usan en un porcentaje bajo de registros, puede ser más óptimo crearlo de tipo objeto texto, de esta forma en el registro ocupa 8 bytes y en el contenedor las celdas que necesite de 512 bytes.

  • Evita la información repetida, por ejemplo, intenta no duplicar el nombre de los artículos en las líneas de movimientos.

  • Extrema el tamaño de registros en las tablas que vayan a contener millones de registros.

¿Es mejor tener muchas tablas con un único tipo de registro o es mejor tener una única tabla con múltiples tipos de registro?

Si el número de registros no es elevado, es decir no contendrá la tabla millones de registros) será más cómodo crear una única tabla con un campo que identifique el tipo de registro.

El campo de tipo de registro para que esté bien documentado debería apuntar a una tabla estática evitando así tener que documentar los valores del mismo por los diferentes lugares de la aplicación donde se use.

Otro factor a tener en cuenta es el número de índices que se van a crear. Si por ejemplo vamos a crear los típicos índices de código, nombre, palabras y trozos y tenemos 5 tipos de registros vamos a crear 20 índices. Este valor no es un problema, pero si vamos a tener que crear un número alto de índices (>200) tal vez debemos replantearnos el uso de tablas independientes.

Hay que tener en cuenta que aunque esta tabla tenga muchos índices, estarán condicionados de tal forma que en cada índice solo encontraremos los registros de un determinado tipo.

Tipos de tablas

¿Cuándo es conveniente usar una tabla de tipo maestro arbolada?

Cuando tengamos que representar los registros de dicha tabla en un árbol en el que cada nivel representa una relación de herencia entre los registros.

Ejemplo habituales son el plan de cuenta de contabilidad, clasificaciones de familias y subfamilias, etc.

¿Qué tamaño de campo ID debo usar en una tabla arbolada?

El menor posible que te permita contener el mayor código que se necesita grabar. Es decir, debemos evitar poner un campo código en el que dejemos un tamaño mayor "por si acaso".

Hay que tener en cuenta que el tamaño del ID influye en los índices y también en el tamaño de los campos que apuntan a esta tabla como maestra. Por lo tanto afecta al rendimiento, cuanto menor sea el código más rápido se manejará la tabla.

Por este motivo se suelen usar campos alfabéticos “comprimidos” como el Alfa 64 (Ahorro del 25%) y Alfa 40 (Ahorro del 33%) que nos permiten contener más caracteres en el código con una menor ocupación en disco.

¿Cuándo es conveniente usar tablas de tipo histórico?

Cuando se den las 2 siguientes circunstancias:

  1. La tabla no tiene un código único que identifique al registro sino que almacena información que no está codificada, o tiene múltiples maestros relacionados, todos ellos con el mismo peso.

  2. La tabla nunca será maestra de otra tabla plural. Esto se debe tener en cuenta para que en el caso de que exista un plural no nos veamos obligados a incluir múltiples campos punteros para resolver la clave única que se haya creada en esta tabla histórica.

¿Y si creo siempre todas las tablas maestras?

Es cierto, que evitar crear tablas históricas y en su lugar crearlas siempre como maestras nos evita la 2ª circunstancia de la pregunta anterior, y es cierto que en la mayoría de los casos nos servirá aplicar este criterio de todas maestros.

Sin embargo, existen algunas excepciones que debemos tener en cuenta.

Si tengo que apuntar a una tabla con punteros indirectos reales usando campos para resolver el índice de clave que no es el ID, no me sirve de nada que la tabla sea maestra, al contrario me obliga a mantener un campo y un índice innecesarios.

Si creamos la tabla como maestra y apuntamos a ella a través del código (ID) obteniéndolo con una búsqueda por otro de sus índices de clave única compuesto por uno o varios campos que no son el ID, tendré problemas de refactorización de datos en el caso de que cambien los campos que componen el índice de clave, esto me obligaría a tener que programar el control del cambio de valor de dichos campos. Por ese motivo es preferible apuntar los registros de este tipo de tablas con punteros indirectos que reaccionan automáticamente al cambio de valores con los que se resuelve el puntero al índice de clave única.

Por ejemplo, una tabla de estadística cuyo índice de clave única viene dado por los campos empresa, año, mes y cliente, deberíamos apuntar desde la tabla que actualiza sus datos a través de un puntero indirecto resuelto con campos de la tabla. En este caso definir la tabla como histórica puede ser una buena práctica.

¿Cuándo es conveniente usar tablas de extensión?

Esta tipo de tabla debemos verla siempre como una solución a un problema que no tenga otras alternativas y crearla solo cuando no nos quede más remedio.

Los casos más habituales son:

  1. Tengo que añadir campos a una tabla que está en un proyecto (núcleo estándar) que no puedo o quiero modificar porque cuando se vuelva a actualizar estaría obligado a repetir los cambios. En general son personalizaciones para un cliente concreto sobre una tabla estándar para todos mis clientes o los de un sector.

  2. Cuando tengo una tabla con cientos de miles o millones de registros y hay un grupo de campos que se usan en un % bajo de registros (<20%) y que hacen crecer el tamaño del registro de forma significativa, por ejemplo pasamos de un tamaño de registros de 400 bytes a 3.000 bytes.

¿Por qué hay que evitarla en la medida de lo posible? Fundamentalmente para aplicar el principio de sencillez que facilite su desarrollo y posterior mantenibilidad. Pero no debemos sacar la conclusión de que no debemos usarla, simplemente usarla con rigor y en los casos en los que sea estrictamente necesario.

¿Cuándo es conveniente usar tablas submaestras?

Como su nombre indica es conveniente cuando una tabla tiene una dependencia directa de una tabla maestra, de tal forma que podemos asegurar que no tiene sentido que exista un registro en la tabla submaestra sin que exista previamente el registro de la maestra.

Un caso típico de esta tabla son las tablas de líneas de detalle de las tablas de documentos de compra y ventas.

La ventaja de declarar esta tabla es que el índice ID está formado por el código de la maestra y el código numérico de la submaestra que se numera automáticamente. Si el código de la submaestra no es numérico entonces perdemos esta ventaja y no merece la pena hacerla submaestra.

El otro motivo por el que se desaconseja su uso es que si esta tabla va a tener plurales es mejor usarla de tipo maestra ya que de lo contrario nos encontraremos que para apuntar a un registro desde otra tabla plural vamos a necesitar mínimo 2 campos (maestro y código).

Por el mismo motivo tampoco es cómodo crear tablas submaestras de múltiples niveles ya que cada vez el índice ID tiene más partes y al relacionar otras tablas con esta submaestra se necesitan tantos campos como partes componen el índice, en cambio con una tabla maestra sabemos que podemos resolver la relación con un solo campo.

A continuación veamos unos consejos de buenas prácticas de rendimiento relativas a:

Última actualización hace 4 años

¿Te fue útil?

.

.

.

.

.

.

.

.

.

.

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

Base de datos

  • Una base de datos, un responsable
  • Esquemas
  • Crea esquemas para documentar las tablas
  • Crea múltiples esquemas
  • Número de tablas y tamaño de registros
  • ¿El número de tablas influye en el rendimiento?
  • ¿El tamaño de registro de una tabla como influye?
  • ¿Es mejor tener muchas tablas con un único tipo de registro o es mejor tener una única tabla con múltiples tipos de registro?
  • Tipos de tablas
  • ¿Cuándo es conveniente usar una tabla de tipo maestro arbolada?
  • ¿Qué tamaño de campo ID debo usar en una tabla arbolada?
  • ¿Cuándo es conveniente usar tablas de tipo histórico?
  • ¿Y si creo siempre todas las tablas maestras?
  • ¿Cuándo es conveniente usar tablas de extensión?
  • ¿Cuándo es conveniente usar tablas submaestras?
Campos
Índices
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 como?
Campos fórmula vs. campos en disco
Índices condicionados vs. búsquedas complejas
¿Cuándo usar una tabla de extensión?
Índices de trozos y palabras
¿Cuándo usar cada tipo de campo alfa?