Справка по SQL | страница 5



10



Переименование столбцов и вычисления в результирующем наборе



Имена столбцов, указанные в предложении SELECT, можно переименовать. Это делает результаты более читабельными, поскольку имена полей в таблицах часто сокращают с целью упрощения набора. Ключевое слово AS, используемое для переименования, согласно стандарту можно и опустить, т.к. оно неявно подразумевается.

Например, запрос


>SELECT ram AS Mb, hd Gb

>FROM Pc

>WHERE cd = '24x';


переименует столбец ram в Mb (мегабайты), а столбец hd в Gb (гигабайты). Этот запрос возвратит объемы оперативной памяти и жесткого диска для тех компьютеров, которые имеют 24-скоростной CD-ROM:


Mb

Gb

64

8

32

10


Переименование особенно желательно при использовании в предложении SELECT выражений для вычисления значения. Эти выражения позволяют получать данные, которые не находятся непосредственно в таблицах. Если выражение содержит имена столбцов таблицы, указанной в предложении FROM, то выражение подсчитывается для каждой строки выходных данных. Так, например, чтобы вывести объем оперативной памяти в килобайтах, можно написать:


>SELECT ram * 1024 AS Kb, hd Gb

>FROM Pc

>WHERE cd = '24x';


Теперь будет получен следующий результат:


Kb

Gb

65536

8

32768

10


Иногда бывает необходимо выводить поясняющую информацию рядом с соответствующим значением. Это можно сделать, добавив строковое выражение как дополнительный столбец. Например, запрос


>SELECT ram, 'Mb' AS ram_units, hd, 'Gb' AS hd_units

>FROM Pc

>WHERE cd = '24x';


даст следующий результат:


ram

ram_units

hd

hd_units

64

Mb

8

Gb

32

Mb

10

Gb


Если же явно не указать имя для выражения, то будет использован способ именования по умолчанию, который зависит от используемой СУБД. Так в MS Access будут использованы имена типа выражение1 и т.д., а выходной столбец в MS SQL Server вообще не будет иметь заголовка.

Проверка наличия подстроки. Предикат LIKE



Синтаксис LIKE::=


[NOT] LIKE


[ESCAPE ]

Предикат LIKE сравнивает строку, указанную в первом выражении для вычисления значения строки, называемого проверяемым значением, с шаблоном, который определен во втором выражении для вычисления значения строки. В образце разрешается использовать два трафаретных символа:

* Символ подчеркивания (_), который можно использовать вместо любого единичного символа в проверяемом значении.

* Символ процента (%), который заменяет набор любых символов (число символов в наборе может быть от 0 и более) в проверяемом значении.

Если проверяемое значение соответствует образцу с учетом трафаретных символов, то значение предиката равно TRUE. Ниже приводится несколько примеров написания шаблонов.