Saltar al contenido principal
Versión: Siguiente

SET INDEX

SET INDEX ( unCampo ; index {; *} )

ParámetroTipoDescripción
unCampoCampo🡒Campo del cual crear o borrar el índice
indexBooleano, Entero🡒• True=Crear el índice, False=Borrar el índice, o • Crear un índice de tipo: -1=palabras claves, 0=por defecto, 1=B-Tree estándar, 3=B-Tree cluster
*🡒Si se pasa * indexación asincrónica

Nota de compatibilidad

SET INDEX, aunque es un comando heredado, todavía es totalmente compatible y puede permanecer en su aplicación, no es necesario volver a escribir el código existente. Sin embargo, sería mejor utilizar CREATE INDEX y DELETE INDEX para administrar los índices porque brindan más funcionalidades.

Descripción

El comando SET INDEX acepta dos sintaxis:

  • Si pasa un booleano en el parámetro index, el comando crea o borra el índice para el campo que pasó en campo.
  • Si pasa un entero el parámetro index, el comando crea un índice del tipo especificado.

index = Booleano

Para indexar el campo, pase True en index. El comando crea un índice del tipo por defecto. Si el índice ya existe, el comando no hace nada.
Si pasa False en index, el comando borrará todos los índices estándar (es decir, no compuestos ni palabras claves) asociados al campo. Si el índice no existe, el comando no hace nada.

index = Entero
En este caso, el comando crea un índice del tipo especificado por campo. Puede pasar una de las siguientes constantes, que se encuentran en el tema “Tipo de índice”:

ConstanteTipoValorComentario
Cluster BTree IndexEntero largo3Índice de tipo B-Tree utilizando clusters. Este tipo de índice se optimiza cuando el índice contiene pocas palabras claves, es decir cuando los mismos valores se presentan con frecuencia en los datos.
Default Index TypeEntero largo04D define el tipo de índice (excepto los índices de palabras claves) que es el más optimizado en función del contenido del campo.
Keywords IndexEntero largo-1Permite la indexación palabra por palabra del contenido del campo. Este tipo de índice sólo puede utilizarse con campos de tipo Texto o Alfa.
Standard BTree IndexEntero largo1Índice de tipo B-Tree clásico. Este tipo de índice multi propósito se utiliza en las versiones anteriores de 4D

Nota: un índice B-Tree asociado a un campo de tipo texto almacena como máximo los primeros 1024 caracteres del campo. Por lo tanto en este contexto, las búsquedas en las cadenas que contengan más de 1024 caracteres fallarán.

SET INDEX no indexará registros bloqueados; el comando esperará a que el registro sea desbloqueado.

El parámetro opcional * indica una indexación asincrónica (simultánea). Una indexación asincrónica permite al método llamante continuar su ejecución inmediatamente después de la llamada, bien sea que la indexación haya terminado o no. Sin embargo, la ejecución se detendrá si un comando requiere la indexación.

Notas:

  • Los índices creados por este comando no tienen nombres. No pueden ser borrados por el comando DELETE INDEX utilizando la sintaxis basada en el nombre.
  • Este comando no permite crear o borrar índices compuestos.
  • Este comando no permite borrar un índice de palabras claves creado por el comando CREATE INDEX.

Nota para despliegue

Dado que este comando modifica la estructura de la base de datos, no puede utilizarse en el contexto de una aplicación empaquetada de sólo lectura (archivo .4dc instalado en la carpeta Archivos de programa o archivo .4dz).

Ejemplo 1

El siguiente ejemplo indexa el campo [Clientes]ID:

 UNLOAD RECORD([Clientes])
 SET INDEX([Clientes]ID;True)

Ejemplo 2

Usted quiere indexar el campo [Clientes]Nombre en modo asincrónico:

 SET INDEX([Clientes]Nombre;True;*)

Ejemplo 3

Creación de un índice de palabras claves:

 SET INDEX([Libros]Summary;Keywords Index)

Ver también

CREATE INDEX
DELETE INDEX
GET FIELD PROPERTIES
ORDER BY
QUERY