Class Function
java.lang.Object
org.iplass.mtp.entity.query.value.ValueExpression
org.iplass.mtp.entity.query.value.primary.PrimaryValue
org.iplass.mtp.entity.query.value.primary.Function
- All Implemented Interfaces:
Serializable
,ASTNode
関数を表す。
Oracle、MySQL、Postgresql共通で次のファンクションを利用可能。
文字列関数
- REPLACE('変換対象文字列','変換前文字','変換後文字') :String :文字列を置換する
- UPPER('変換対象文字列') :String :文字列を大文字変換する
- LOWER('変換対象文字列') :String :文字列を小文字変換する
- CONCAT('結合対象文字列1','結合対象文字列2') :String :文字列を結合する
- SUBSTR('文字列',開始文字index,切り出す文字列の長さ) :String :文字列を切り出す。indexは1始まり。切り出す文字列の長さは省略可能
- INSTR('文字列','検索文字列') :Long :検索文字列が最初に出現したindexを返す。indexは1始まり。
- CHAR_LENGTH('文字列') :Long :文字列の長さを取得する
数値関数
- MOD(数値式,割る数) :Double/BigDecimal/Long :余りを計算する。引数の数値の型により返却される型は異なる
- SQRT(数値式) :Double :平方根を計算する
- POWER(数値式,指数) :Double/BigDecimal/Long :冪乗を計算する。引数の数値の型により返却される型は異なる
- ABS(数値式) :Double/BigDecimal/Long :絶対値を計算する。引数の数値の型により返却される型は異なる
- CEIL(数値式) :Long :小数部を切り上げする
- FLOOR(数値式) :Long :小数部を切り下げする。TRUNCATEとの違いは、数値式が負数の場合の処理。
- ROUND(数値式,小数位) :BigDecimal/Long :数値式を四捨五入(数値式がDouble型の場合は銀行丸め処理)する。引数の数値の型により返却される型は異なる。小数位の指定が、0以下の場合はLong
- TRUNCATE(数値式,小数位) :BigDecimal/Long :数値式を切り捨てする。引数の数値の型により返却される型は異なる。小数位の指定が、0以下の場合はLong
- SIN(数値式) :Double :サインを計算する
- COS(数値式) :Double :コサインを計算する
- TAN(数値式) :Double :タンジェントを計算する
- ASIN(数値式) :Double :アークサインを計算する
- ACOS(数値式) :Double :アークコサインを計算する
- ATAN(数値式) :Double :アークタンジェントを計算する
- ATAN2(数値式,数値式) :Double :y/xのアーク・タンジェントを計算する
日付関数
- YEAR(日付) :Long :日付の年を取得する
- MONTH(日付) :Long :日付の月(1~12)を取得する
- DAY(日付) :Long :日付の日(1~31)を取得する
- HOUR(日付) :Long :日付の時間(0~23)を取得する
- MINUTE(日付) :Long :日付の分(0~59)を取得する
- SECOND(日付) :Long :日付の秒(0~59)を取得する
- DATE_ADD(日付,加算する値,単位) :Timestamp :指定の日付に指定の値を加算する。単位には'YEAR','MONTH','DAY','HOUR','MINUTE','SECOND'を指定可能。例:DATE_ADD('2012-12-12'D, 5, 'DAY')
- DATE_DIFF(単位,日付1,日付2) :Long :日付1と日付2の差分を指定の単位で取得する。日付1の方が大きい場合、結果は負の値が返却される。単位には'YEAR','MONTH','DAY','HOUR','MINUTE','SECOND'を指定可能。例:DATE_DIFF('DAY', '2012-12-12'D, '2012-12-31'D)
- CURRENT_DATE() :Date :現在の日付(年月日)を取得する
- CURRENT_TIME() :Time :現在の時刻を取得する
- CURRENT_DATETIME() :Timestamp :現在の日時を取得する
- LOCALTIME(日時) :Timestamp :日時をテナントに設定されたローカル時間を示す値に変換する。例(テナントローカルのタイムゾーンの時間を取得):HOUR(LOCALTIME(CURRENT_DATETIME()))
- See Also:
-
Constructor Summary
ConstructorDescriptionFunction()
Function
(String name, List<ValueExpression> arguments) Function
(String name, ValueExpression... arguments) -
Method Summary
Modifier and TypeMethodDescriptionaccept
(ASTTransformer transformer) void
accept
(ValueExpressionVisitor visitor) boolean
getName()
int
hashCode()
void
setArguments
(List<ValueExpression> arguments) void
toString()
Methods inherited from class org.iplass.mtp.entity.query.value.ValueExpression
newValue
-
Constructor Details
-
Function
public Function() -
Function
-
Function
-
-
Method Details
-
getName
-
setName
-
getArguments
-
setArguments
-
toString
-
accept
- Specified by:
accept
in classValueExpression
-
accept
-
hashCode
public int hashCode() -
equals
-