Справка по 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. Ниже приводится несколько примеров написания шаблонов.