Sintassi per la ricerca libera

Una espressione di ricerca si compone di uno o più termini legati tra loro da uno o più operatori. Essa può avvalersi di due tipi di termini: termini esatti o radice di termini esatti ossia troncati a destra. L'operatore di troncamento a destra è $.
(Ad es.
metr$ recupera i record da cui sono stati estratti i termini esatti con radice metr quali metrica, metro, metronomo).

Operatori logici booleani

+

OR

A + B

A oppure B oppure entrambi

*

AND

A * B

contemporaneamente A e B

^

AND  NOT

A AND  NOT B

A ad esclusione di quelli che contengono B

Operatori di prossimità

Sono più restrittivi dell'operatore * e recuperano i record che contengono i due termini

(G)

A (G) B

nello stesso campo
(F)

A (F) B

nella stessa occorrenza

.

A . B

distanti tra loro non più di n* parole

$

A $ B

distanti tra loro esattamente n* parole
* n è il numero di punti o dollari meno uno

Notare che gli operatori . e $ devono essere preceduti e seguiti da uno spazio.

Operatore di campo

Per default ISIS ricerca in tutti i campi indicizzati. L'operatore di campo specifica e limita la ricerca ad un campo o gruppo di campi da cui il termine è stato estratto. La sintassi è termine/(i1,i2,i3,in) (es.: storia/(11,62)) dove:

Sintassi delle espressioni di ricerca

Si possono combinare due o più termini con gli operatori di ricerca e come nell'algebra normale si può far uso delle parentesi tonde per modificare l'ordine di priorità di esecuzione degli operatori che è il seguente:

(più alto) $ e .; (F); (G); * e AND NOT ; + (più basso)

Es.: ((A + B) * C + (D + E) * F) AND NOT G