式には、SQL処理で使用する値を指定します。
式は、算術演算子、比較演算子、文字列またはバイナリ演算子、ビット演算子、あるいはこの章で説明する任意の関数で連結された1つまたは複数のプライマリで構成できます。プライマリは、SQL構文に示された項目から算出される、符号付きまたは符号なしの値です。
{ColumnName | ROWID | {? | :DynamicParameter} |
AggregateFunction | Constant | (Expression)}
または
[[+ |-] {ColumnName | SYSDATE | TT_SYSDATE|GETDATE() |
{? | :DynamicParameter} | AggregateFunction |
Constant | {~ | + | -} Expression}]
[...]
または
Expression1 [& | | | ^ | + | / | * | - ] Expression2
または
Expression1 | | Expression2
または
Expression
構成要素 | 説明 |
+, - | 単項プラスと単項マイナス。単項マイナスはプライマリの符号を変更します。デフォルトの設定では、符号は変更しません。 |
ColumnName | 値を取得する列の名前。列名については「名前」を参照してください。 |
ROWID | 表に保存される各行には、ROWIDと呼ばれる一意のIDが割り当てられます。ROWIDのデータ型はBINARY(16)です。ROWIDの値は、ROWIDという名前の擬似列から取得されます。 |
? :DynamicParameter | 動的パラメータのプレースホルダ。 動的パラメータの値は、実行時に設定されます。 |
AggregateFunction | 計算された値。「集計関数」を参照してください。 |
Constant | 特定の値。「定数」を参照してください。 |
(Expression) | カッコで囲まれた式。 |
Expression1 Expression2 | |
* | 2つのプライマリを乗算します。 |
/ | 2つのプライマリを除算します。 |
+ | 2つのプライマリを加算します。 |
- | 2つのプライマリを減算します。 |
& | 2つのオペランドのビット単位のAND。Expression1およびExpression2の対応するビットがどちらも1の場合にのみビットを1に設定し、ビットが異なるかどちらも0の場合にビットを0に設定します。 |
| | 2つのオペランドのビット単位のOR。Expression1およびExpression2の対応するビットのいずれかまたは両方が1の場合にビットを1に設定し、対応するビットの両方が0の場合にビットを0に設定します。 |
~ | オペランドのビット単位のNOT。Expressionを1つのみ取り出し、オペランドの各ビットを逆にして、すべての1を0(ゼロ)に、0(ゼロ)を1に変更します。 |
^ | 2つのオペランドの排他OR。Expression1およびExpression2の対応するビットが異なる場合にビットを1に設定し、同じ場合に0(ゼロ)に設定します。一方のビットが0(ゼロ)で他方のビットが1の場合、対応する結果ビットは1に設定されます。それ以外の場合、対応する結果ビットは0(ゼロ)に設定されます。 |
| | | 両方の式が文字列の場合に、Expression1とExpression2を連結します。両方の式の値を含む、新しい文字列値を作成します。「CONCAT」も参照してください。 |
10 * 2 - 1 = 19
ではなく10 * (2 - 1) = 10
とします。
WHERE ROWID = :v1 OR ROWID = :v2
WHERE ROWID IN (:v1, :v2)
SELECT文のWHERE句:
SELECT *
FROM Purchasing.Orders
WHERE PartNumber = ?
AND OrderNumber > ?
ORDER BY OrderNumber
UPDATE文のWHERE句およびSET句:
UPDATE Purchasing.Parts
SET SalesPrice = :DynamicParameter1
WHERE PartNumber = :DynamicParameter2
DELETE文のWHERE句:
DELETE FROM Purchasing.OrderItems
WHERE ItemNumber BETWEEN ? AND ?
INSERT文のVALUES句です。この例では、?と:DynamicParameterの両方をPurchasing.OrderItems
表の2番目と4番目の列の両方に対応する:DynamicParameter1
で使用します。そのため、この式には、2番目と4番目の列の両方に使用する2番目のパラメータを使用して、4つの動的パラメータのみを渡す必要があります。
INSERT INTO Purchasing.OrderItems VALUES
(?,:DynamicParameter1,
:DynamicParameter2,
:DynamicParameter1,?)
この例には、?および:DynamicParameterの両方を同じSQL文で使用できることと、両方のタイプの動的パラメータを繰り返すことの意味上の違いが示されています。
ビット単位演算子の例を次に示します。
Command> SELECT 0x183D & 0x00FF from dual;
< 003D >
1 row found.
Command> SELECT ~255 FROM dual;
< -256 >
1 row found.
Command> SELECT 0x08 | 0x0F FROM dual;
< 0F >
1 row found.