Alink的Sql组件支持一组用于数据转换的内置函数。Sql组件使用标准的ANSI SQL语法。
比较函数
SQL语法 |
描述 |
value1 = value2 |
等于。 |
value1 <> value2 |
不相等。 |
value1 > value2 |
比…更大。 |
value1 >= value2 |
大于或等于。 |
value1 < value2 |
少于。 |
value1 <= value2 |
小于等于。 |
value IS NULL |
如果value为null,则返回TRUE。 |
value IS NOT NULL |
如果value不为null,则返回TRUE。 |
value1 IS DISTINCT FROM value2 |
如果两个值不相等则返回TRUE,将null值视为相同。 |
value1 IS NOT DISTINCT FROM value2 |
如果两个值相等则返回TRUE,将null值视为相同。 |
value1 BETWEEN [ASYMMETRIC SYMMETRIC] value2 AND value3 |
|
value1 NOT BETWEEN value2 AND value3 |
如果value1小于value2或大于value3,则返回TRUE。 |
string1 LIKE string2 |
如果string1匹配模式string2,则返回TRUE。 |
string1 NOT LIKE string2 |
如果string1与模式string2不匹配,则返回TRUE。 |
string1 SIMILAR TO string2 |
如果string1匹配正则表达式string2,则返回TRUE。 |
string1 NOT SIMILAR TO string2 |
如果string1与正则表达式string2不匹配,则返回TRUE。 |
value IN (value [, value]* ) |
如果表达式存在于给定的表达式列表中,则返回TRUE。这是多个OR条件的简写。如果测试集包含NULL,则如果找不到该元素,则结果为NULL;如果可以找到,则结果为TRUE。如果元素为NULL,则结果始终为NULL。例如“42 IN(1,2,3)”导致FALSE。 |
value NOT IN (value [, value]* ) |
如果value不等于列表中的每个值,则返回TRUE。 |
EXISTS (sub-query) |
如果子查询返回至少一行,则返回TRUE。仅在可以在连接和组操作中重写操作时才支持。 |
value IN (sub-query) |
如果value等于子查询返回的行,则返回TRUE。尚未在流式传输环境中支持此操作。 |
value NOT IN (sub-query) |
如果value不等于子查询返回的每一行,则返回TRUE。尚未在流式传输环境中支持此操作。 |
逻辑函数
SQL语法 |
描述 |
boolean1 OR boolean2 |
如果boolean1为TRUE或boolean2为TRUE,则返回TRUE。支持三值逻辑。 |
boolean1 AND boolean2 |
如果boolean1和boolean2都为TRUE,则返回TRUE。支持三值逻辑。 |
NOT boolean |
如果boolean不为TRUE,则返回TRUE;?如果布尔值为UNKNOWN,则返回UNKNOWN。 |
boolean IS FALSE |
如果boolean为FALSE,则返回TRUE;?否则返回TRUE。如果布尔值为UNKNOWN,则返回FALSE。 |
boolean IS NOT FALSE |
如果boolean不为FALSE,则返回TRUE;否则返回TRUE。如果布尔值为UNKNOWN,则返回TRUE。 |
boolean IS TRUE |
如果boolean为TRUE,则返回TRUE;如果布尔值为UNKNOWN,则返回FALSE。 |
算术函数
SQL语法 |
描述 |
+ numeric |
返回数字。 |
- numeric |
返回负数字。 |
numeric1 + numeric2 |
返回numeric1加上numeric2。 |
numeric1 - numeric2 |
返回numeric1减去numeric2。 |
numeric1 * numeric2 |
返回numeric1乘以numeric2。 |
numeric1 / numeric2 |
返回numeric1除以numeric2。 |
POWER(numeric1, numeric2) |
返回numeric1上升到numeric2的幂。 |
ABS(numeric) |
返回numeric的绝对值。 |
MOD(numeric1, numeric2) |
返回numeric1的余数(模数)除以numeric2。仅当numeric1为负数时,结果才为负数。 |
SQRT(numeric) |
返回数字的平方根。 |
LN(numeric) |
返回的自然对数(以e为底)的数字。 |
LOG10(numeric) |
返回数字的基数10对数。 |
EXP(numeric) |
返回e提升到数字的幂。 |
CEIL(numeric) |
将数字向上舍入,并返回大于或等于numeric的最小数字。 |
CEILING(numeric) |
|
FLOOR(numeric) |
将数字向下舍入,并返回小于或等于numeric的最大数字。 |
SIN(numeric) |
计算给定数字的正弦值。 |
COS(numeric) |
计算给定数字的余弦值。 |
TAN(numeric) |
计算给定数字的正切值。 |
COT(numeric) |
计算给定数字的余切值。 |
ASIN(numeric) |
计算给定数字的反正弦值。 |
ACOS(numeric) |
计算给定数字的反余弦值。 |
ATAN(numeric) |
计算给定数字的反正切值。 |
DEGREES(numeric) |
将数字从弧度转换为度数。 |
RADIANS(numeric) |
将数字从度数转换为弧度。 |
SIGN(numeric) |
计算给定数字的符号。 |
ROUND(numeric, int) |
将给定数到整数位权小数点。 |
PI() |
返回比pi更接近任何其他值的值。 |
E() |
返回比e更接近任何其他值的值。 |
RAND() |
返回介于0.0(包括)和1.0(不包括)之间的伪随机双精度值。 |
RAND(seed integer) |
返回0.0(包括)和1.0(不包括)初始种子之间的伪随机双精度值。如果两个RAND函数具有相同的初始种子,则它们将返回相同的数字序列。 |
RAND_INTEGER(bound integer) |
返回介于0.0(包括)和指定值(不包括)之间的伪随机整数值。 |
RAND_INTEGER(seed integer, bound integer) |
返回0.0(包括)之间的伪随机整数值和具有初始种子的指定值(不包括)。如果两个RAND_INTEGER函数具有相同的初始种子和相同的绑定,则它们将返回相同的数字序列。 |
LOG(x numeric), LOG(base numeric, x numeric) |
返回指定数量的指定基数的自然对数。如果使用一个参数调用,则此函数返回自然对数x。如果使用两个参数调用,则此函数返回x基数的对数b。x必须大于0.?b必须大于1。 |
字符串函数
SQL语法 |
描述 |
string1 || string1 |
连接两个字符串。 |
CHAR_LENGTH(string) |
返回字符串中的字符数。 |
UPPER(string) |
返回转换为大写的字符串。 |
LOWER(string) |
返回转换为小写的字符串。 |
POSITION(string1 IN string2) |
返回第一次出现的位置字符串1的字符串2。 |
TRIM( { BOTH,LEADING,TRAILING } string1 FROM string2) |
从string2中删除前导和/或尾随字符。默认情况下,两侧的空格都被删除。 |
OVERLAY(string1 PLACING string2 FROM integer [ FOR integer2 ]) |
用string2替换string1的子字符串。 |
SUBSTRING(string FROM integer) |
返回从给定点开始的字符串的子字符串。 |
SUBSTRING(string FROM integer FOR integer) |
返回从具有给定长度的给定点开始的字符串的子字符串。 |
INITCAP(string) |
返回字符串,每个字转换器的第一个字母为大写,其余为小写。单词是由非字母数字字符分隔的字母数字字符序列。 |
CONCAT(string1, string2,…) |
返回连接参数产生的字符串。如果任何参数为NULL,则返回NULL。例如CONCAT(“AA”, “BB”, “CC”)返回AABBCC。 |
CONCAT_WS(separator, string1, string2,…) |
返回使用分隔符连接参数产生的字符串。在要连接的字符串之间添加分隔符。返回NULL如果分隔符为NULL。CONCAT_WS()不会跳过空字符串。但是,它会跳过任何NULL参数。例如CONCAT_WS(““, “AA”, “BB”, “”, “CC”)返回AABB~~CC |
BOOLEAN REGEXP(String str, String pattern) |
指定str的字符串是否匹配指定的pattern进行正则匹配,str或者pattern为空或NULL返回false。 |
String REGEXP_REPLACE(String str, String pattern, String replacement) |
用字符串replacement替换字符串str中正则模式为pattern的子串,返回新的字符串。正在匹配替换, 参数为null或者正则不合法返回null。 |
String REGEXP_EXTRACT(String str, String pattern, INT index) |
使用正则模式pattern匹配抽取字符串str中的第index个子串,index 从1开始 正在匹配提取, 参数为null或者正则不合法返回null。 |
条件函数
SQL语法 |
描述 |
CASE value WHEN value1 [, value11 ] THEN result1 [ WHEN valueN [, valueN1 ] THEN resultN ]* [ ELSE resultZ ] END |
简单的案例。 |
CASE WHEN condition1 THEN result1 [ WHEN conditionN THEN resultN ]* [ ELSE resultZ ] END |
搜索案例。 |
NULLIF(value, value) |
如果值相同,则返回NULL。例如,NULLIF(5, 5)返回NULL; NULLIF(5, 0)返回5。 |
COALESCE(value, value [, value ]* ) |
如果第一个值为null,则提供值。例如,COALESCE(NULL, 5)返回5。 |
类型转换功能
SQL语法 |
描述 |
CAST(value AS type) |
将值转换为给定类型。type的取值包括:VARCHAR, BOOLEAN, TINYINT, SMALLINT, INTEGER/INT,, BIGINT, REAL/FLOAT, DOUBLE, DECIMAL, DATE, TIME, TIMESTAMP(3) |
时间函数
SQL语法 |
描述 |
DATE string |
将“yy-mm-dd”形式的日期字符串解析为SQL日期。 |
TIME string |
将“hh:mm:ss”形式的时间字符串解析为SQL时间。 |
TIMESTAMP string |
将“yy-mm-dd hh:mm:ss.fff”形式的时间戳字符串解析为SQL时间戳。 |
INTERVAL string range |
对于SQL间隔为毫秒,以“dd hh:mm:ss.fff”形式解析间隔字符串,对于SQL间隔月,解析“yyyy-mm”。的间隔范围可以是例如DAY,MINUTE,DAY TO HOUR,或DAY TO SECOND的毫秒时间间隔; YEAR或YEAR TO MONTH间隔数月。例如INTERVAL ‘10 00:00:00.004’ DAY TO SECOND,INTERVAL ‘10’ DAY或INTERVAL ‘2-10’ YEAR TO MONTH返回间隔。 |
CURRENT_DATE |
以UTC时区返回当前SQL日期。 |
CURRENT_TIME |
以UTC时区返回当前SQL时间。 |
CURRENT_TIMESTAMP |
以UTC时区返回当前SQL时间戳。 |
LOCALTIME |
返回本地时区的当前SQL时间。 |
LOCALTIMESTAMP |
返回本地时区的当前SQL时间戳。 |
EXTRACT(timeintervalunit FROM temporal) |
提取时间点或时间间隔的部分内容。将部件作为long值返回。例如,EXTRACT(DAY FROM DATE ‘2006-06-05’)导致5。 |
FLOOR(timepoint TO timeintervalunit) |
将时间点向下舍入到给定单位。例如,FLOOR(TIME ‘12:44:31’ TO MINUTE)导致12:44:00。 |
CEIL(timepoint TO timeintervalunit) |
将时间点舍入到给定单位。例如,CEIL(TIME ‘12:44:31’ TO MINUTE)导致12:45:00。 |
QUARTER(date) |
返回SQL日期的一年中的四分之一。例如,QUARTER(DATE ‘1994-09-27’)导致3。 |
(timepoint, temporal) OVERLAPS (timepoint, temporal) |
确定两个锚定时间间隔是否重叠。时间点和时间被转换为由两个时间点(开始,结束)定义的范围。该函数评估leftEnd >= rightStart && rightEnd >= leftStart。例如,(TIME ‘2:55:00’, INTERVAL ‘1’ HOUR) OVERLAPS (TIME ‘3:30:00’, INTERVAL ‘2’ HOUR)导致真实; (TIME ‘9:00:00’, TIME ‘10:00:00’) OVERLAPS (TIME ‘10:15:00’, INTERVAL ‘3’ HOUR)导致错误。 |
DATE_FORMAT(timestamp, format) (备注:该函数用的是GMT-0时区而不是本地时区) |
timestamp使用指定format字符串格式化为字符串。格式必须与date_parse函数使用的MySQL日期格式语法兼容。格式规范在下面的日期格式说明表中给出。例如DATE_FORMAT(ts, ‘%Y, %d %M’),字符串格式为的结果”2017, 05 May”。 |
DATE_FORMAT_LTZ(timestamp, format) (备注:该函数用的是本地时区) |
timestamp使用指定format字符串格式化为字符串。格式必须与date_parse函数使用的MySQL日期格式语法兼容。格式规范在下面的日期格式说明表中给出。例如DATE_FORMAT(ts, ‘%Y, %d %M’),字符串格式为的结果”2017, 05 May”。 |
TIMESTAMPADD(unit, interval, timestamp) |
将(带符号)整数间隔添加到时间戳。某一间隔的单元由单元参数,它应为以下值中的一个给定的:SECOND,MINUTE,HOUR,DAY,WEEK,MONTH,QUARTER,或YEAR。例如,TIMESTAMPADD(WEEK, 1, ‘2003-01-02’)导致2003-01-09。 |
String DATE_SUB(String startdate, INT days);String DATE_SUB(TIMESTAMP time, INT days) |
为日期减去天数,日期格式可以是yyyy-MM-dd hh:mm:ss或yyyy-MM-dd或TIMESTAMP,返回String格式的日期yyyy-MM-dd,若有参数为null或解析错误,返回null。 |
String DATE_ADD(String startdate, INT days);String DATE_ADD(TIMESTAMP time, INT days) |
返回指定startdate日期间隔后days天数的一个全新的String类型日期,日期格式可以是yyyy-MM-dd hh:mm:ss或yyyy-MM-dd或timestamp,返回string格式的日期yyyy-MM-dd,若有参数为null或解析错误,返回null。 |
INT DATEDIFF(String enddate, String startdate);INT DATEDIFF(TIMESTAMP enddate, String startdate);INT DATEDIFF(String enddate, TIMESTAMP startdate);INT DATEDIFF(TIMESTAMP enddate, TIMESTAMP startdate) |
计算从enddate到startdate两个时间的天数差值,日期格式可以是yy-MM-dd HH:mm:ss或yy-MM-dd或timestamp,返回整数,若有参数为null或解析错误,返回null |
TIMESTAMP TO_TIMESTAMP(BIGINT time);TIMESTAMP TO_TIMESTAMP(String date);TIMESTAMP TO_TIMESTAMP(String date, String format) |
将bigint类型的日期或者String类型的日期转换成TimeStamp类型。 |
BIGINT UNIX_TIMESTAMP();BIGINT UNIX_TIMESTAMP(String date);BIGINT UNIX_TIMESTAMP(String date, String format) |
两个参数,均为可选,无参数时返回当前时间的时间戳,单位为秒,第一个参数是字符串类型的时间,第二个参数是时间的格式,默认为yyyy-MM-dd hh:mm:ss,返回值是第一个参数转换成的长整型的时间戳,单位为秒,若有参数为null或解析错误,返回null。 |
String FROM_UNIXTIME(BIGINT unixtime [ String format]) |
第一个参数unixtime为长整型,是以秒为单位的时间戳,第二个参数format可选,为日期格式,默认为yyyy-MM-dd HH:mm:ss,返回String类型的符合指定格式的日期,若有参数为null或解析错误,返回null。返回值为String类型的日期值, 默认日期格式:yyyy-MM-dd HH:mm:ss,若指定日期格式按指定格式输出 任一输入参数是NULL,返回NULL。 |
BIGINT NOW() |
返回当前时区时间的时间戳,单位为秒,可以接受一个整型参数作为偏移值(单位:秒) |
聚合函数
SQL语法 |
描述 |
COUNT(value [, value]* ) |
返回值不为null 的输入行数。 |
COUNT(*) |
返回输入行数。 |
AVG(value) |
返回所有输入值的数值的平均值(算术平均值)。 |
SUM(value) |
返回所有输入值的数字总和。 |
MAX(value) |
返回的最大值值在所有的输入值。 |
MIN(value) |
返回的最小值的值在所有的输入值。 |
STDDEV_POP(value) |
返回所有输入值的数字字段的总体标准偏差。 |
STDDEV_SAMP(value) |
返回所有输入值的数字字段的样本标准偏差。 |
VAR_POP(value) |
返回所有输入值中数字字段的总体方差(总体标准差的平方)。 |
VAR_SAMP(value) |
返回所有输入值的数值字段的样本方差(样本标准差的平方)。 |
COLLECT(value) |
返回值 s 的多集。null输入值将被忽略。如果仅添加空值,则返回空的multiset。 |
CONCAT_AGG(value, sep) |
sep是分隔符,用指定的spearator做分隔符,连接value中的值。 |
分组函数
SQL语法 |
描述 |
GROUP_ID() |
返回唯一标识分组键组合的整数。 |
GROUPING(expression) |
如果表达式在当前行的分组集中汇总,则返回1,否则返回0。 |
GROUPING_ID(expression [, expression]* ) |
返回给定分组表达式的位向量。 |
访问函数
SQL语法 |
描述 |
tableName.compositeType.field |
按名称访问Flink复合类型(如Tuple,POJO等)的字段并返回其值。 |
tableName.compositeType.* |
将Flink复合类型(例如Tuple,POJO等)及其所有直接子类型转换为平面表示形式,其中每个子类型都是单独的字段。 |
数组函数
SQL语法 |
描述 |
ARRAY ‘[’ value [, value ]* ‘]’ |
从值列表创建数组。 |
CARDINALITY(ARRAY) |
返回数组的元素数。 |
array ‘[’ index ‘]’ |
返回数组中特定位置的元素。指数从1开始。 |
ELEMENT(ARRAY) |
返回具有单个元素的数组的唯一元素。null如果数组为空,则返回。如果数组有多个元素,则抛出异常。 |
虽然并非每个SQL功能都已实现,但某些字符串组合已被保留为关键字以供将来使用。如果要将以下字符串之一用作字段名称,请确保使用反引号将其包围(例如value,count)。
A, ABS, ABSOLUTE, ACTION, ADA, ADD, ADMIN, AFTER, ALL, ALLOCATE, ALLOW, ALTER, ALWAYS, AND, ANY, ARE, ARRAY, AS, ASC, ASENSITIVE, ASSERTION, ASSIGNMENT, ASYMMETRIC, AT, ATOMIC, ATTRIBUTE, ATTRIBUTES, AUTHORIZATION, AVG, BEFORE, BEGIN, BERNOULLI, BETWEEN, BIGINT, BINARY, BIT, BLOB, BOOLEAN, BOTH, BREADTH, BY, C, CALL, CALLED, CARDINALITY, CASCADE, CASCADED, CASE, CAST, CATALOG, CATALOG_NAME, CEIL, CEILING, CENTURY, CHAIN, CHAR, CHARACTER, CHARACTERISTICTS, CHARACTERS, CHARACTER_LENGTH, CHARACTER_SET_CATALOG, CHARACTER_SET_NAME, CHARACTER_SET_SCHEMA, CHAR_LENGTH, CHECK, CLASS_ORIGIN, CLOB, CLOSE, COALESCE, COBOL, COLLATE, COLLATION, COLLATION_CATALOG, COLLATION_NAME, COLLATION_SCHEMA, COLLECT, COLUMN, COLUMN_NAME, COMMAND_FUNCTION, COMMAND_FUNCTION_CODE, COMMIT, COMMITTED, CONDITION, CONDITION_NUMBER, CONNECT, CONNECTION, CONNECTION_NAME, CONSTRAINT, CONSTRAINTS, CONSTRAINT_CATALOG, CONSTRAINT_NAME, CONSTRAINT_SCHEMA, CONSTRUCTOR, CONTAINS, CONTINUE, CONVERT, CORR, CORRESPONDING, COUNT, COVAR_POP, COVAR_SAMP, CREATE, CROSS, CUBE, CUME_DIST, CURRENT, CURRENT_CATALOG, CURRENT_DATE, CURRENT_DEFAULT_TRANSFORM_GROUP, CURRENT_PATH, CURRENT_ROLE, CURRENT_SCHEMA, CURRENT_TIME, CURRENT_TIMESTAMP, CURRENT_TRANSFORM_GROUP_FOR_TYPE, CURRENT_USER, CURSOR, CURSOR_NAME, CYCLE, DATA, DATABASE, DATE, DATETIME_INTERVAL_CODE, DATETIME_INTERVAL_PRECISION, DAY, DEALLOCATE, DEC, DECADE, DECIMAL, DECLARE, DEFAULT, DEFAULTS, DEFERRABLE, DEFERRED, DEFINED, DEFINER, DEGREE, DELETE, DENSE_RANK, DEPTH, DEREF, DERIVED, DESC, DESCRIBE, DESCRIPTION, DESCRIPTOR, DETERMINISTIC, DIAGNOSTICS, DISALLOW, DISCONNECT, DISPATCH, DISTINCT, DOMAIN, DOUBLE, DOW, DOY, DROP, DYNAMIC, DYNAMIC_FUNCTION, DYNAMIC_FUNCTION_CODE, EACH, ELEMENT, ELSE, END, END-EXEC, EPOCH, EQUALS, ESCAPE, EVERY, EXCEPT, EXCEPTION, EXCLUDE, EXCLUDING, EXEC, EXECUTE, EXISTS, EXP, EXPLAIN, EXTEND, EXTERNAL, EXTRACT, FALSE, FETCH, FILTER, FINAL, FIRST, FIRST_VALUE, FLOAT, FLOOR, FOLLOWING, FOR, FOREIGN, FORTRAN, FOUND, FRAC_SECOND, FREE, FROM, FULL, FUNCTION, FUSION, G, GENERAL, GENERATED, GET, GLOBAL, GO, GOTO, GRANT, GRANTED, GROUP, GROUPING, HAVING, HIERARCHY, HOLD, HOUR, IDENTITY, IMMEDIATE, IMPLEMENTATION, IMPORT, IN, INCLUDING, INCREMENT, INDICATOR, INITIALLY, INNER, INOUT, INPUT, INSENSITIVE, INSERT, INSTANCE, INSTANTIABLE, INT, INTEGER, INTERSECT, INTERSECTION, INTERVAL, INTO, INVOKER, IS, ISOLATION, JAVA, JOIN, K, KEY, KEY_MEMBER, KEY_TYPE, LABEL, LANGUAGE, LARGE, LAST, LAST_VALUE, LATERAL, LEADING, LEFT, LENGTH, LEVEL, LIBRARY, LIKE, LIMIT, LN, LOCAL, LOCALTIME, LOCALTIMESTAMP, LOCATOR, LOWER, M, MAP, MATCH, MATCHED, MAX, MAXVALUE, MEMBER, MERGE, MESSAGE_LENGTH, MESSAGE_OCTET_LENGTH, MESSAGE_TEXT, METHOD, MICROSECOND, MILLENNIUM, MIN, MINUTE, MINVALUE, MOD, MODIFIES, MODULE, MONTH, MORE, MULTISET, MUMPS, NAME, NAMES, NATIONAL, NATURAL, NCHAR, NCLOB, NESTING, NEW, NEXT, NO, NONE, NORMALIZE, NORMALIZED, NOT, NULL, NULLABLE, NULLIF, NULLS, NUMBER, NUMERIC, OBJECT, OCTETS, OCTET_LENGTH, OF, OFFSET, OLD, ON, ONLY, OPEN, OPTION, OPTIONS, OR, ORDER, ORDERING, ORDINALITY, OTHERS, OUT, OUTER, OUTPUT, OVER, OVERLAPS, OVERLAY, OVERRIDING, PAD, PARAMETER, PARAMETER_MODE, PARAMETER_NAME, PARAMETER_ORDINAL_POSITION, PARAMETER_SPECIFIC_CATALOG, PARAMETER_SPECIFIC_NAME, PARAMETER_SPECIFIC_SCHEMA, PARTIAL, PARTITION, PASCAL, PASSTHROUGH, PATH, PERCENTILE_CONT, PERCENTILE_DISC, PERCENT_RANK, PLACING, PLAN, PLI, POSITION, POWER, PRECEDING, PRECISION, PREPARE, PRESERVE, PRIMARY, PRIOR, PRIVILEGES, PROCEDURE, PUBLIC, QUARTER, RANGE, RANK, READ, READS, REAL, RECURSIVE, REF, REFERENCES, REFERENCING, REGR_AVGX, REGR_AVGY, REGR_COUNT, REGR_INTERCEPT, REGR_R2, REGR_SLOPE, REGR_SXX, REGR_SXY, REGR_SYY, RELATIVE, RELEASE, REPEATABLE, RESET, RESTART, RESTRICT, RESULT, RETURN, RETURNED_CARDINALITY, RETURNED_LENGTH, RETURNED_OCTET_LENGTH, RETURNED_SQLSTATE, RETURNS, REVOKE, RIGHT, ROLE, ROLLBACK, ROLLUP, ROUTINE, ROUTINE_CATALOG, ROUTINE_NAME, ROUTINE_SCHEMA, ROW, ROWS, ROW_COUNT, ROW_NUMBER, SAVEPOINT, SCALE, SCHEMA, SCHEMA_NAME, SCOPE, SCOPE_CATALOGS, SCOPE_NAME, SCOPE_SCHEMA, SCROLL, SEARCH, SECOND, SECTION, SECURITY, SELECT, SELF, SENSITIVE, SEQUENCE, SERIALIZABLE, SERVER, SERVER_NAME, SESSION, SESSION_USER, SET, SETS, SIMILAR, SIMPLE, SIZE, SMALLINT, SOME, SOURCE, SPACE, SPECIFIC, SPECIFICTYPE, SPECIFIC_NAME, SQL, SQLEXCEPTION, SQLSTATE, SQLWARNING, SQL_TSI_DAY, SQL_TSI_FRAC_SECOND, SQL_TSI_HOUR, SQL_TSI_MICROSECOND, SQL_TSI_MINUTE, SQL_TSI_MONTH, SQL_TSI_QUARTER, SQL_TSI_SECOND, SQL_TSI_WEEK, SQL_TSI_YEAR, SQRT, START, STATE, STATEMENT, STATIC, STDDEV_POP, STDDEV_SAMP, STREAM, STRUCTURE, STYLE, SUBCLASS_ORIGIN, SUBMULTISET, SUBSTITUTE, SUBSTRING, SUM, SYMMETRIC, SYSTEM, SYSTEM_USER, TABLE, TABLESAMPLE, TABLE_NAME, TEMPORARY, THEN, TIES, TIME, TIMESTAMP, TIMESTAMPADD, TIMESTAMPDIFF, TIMEZONE_HOUR, TIMEZONE_MINUTE, TINYINT, TO, TOP_LEVEL_COUNT, TRAILING, TRANSACTION, TRANSACTIONS_ACTIVE, TRANSACTIONS_COMMITTED, TRANSACTIONS_ROLLED_BACK, TRANSFORM, TRANSFORMS, TRANSLATE, TRANSLATION, TREAT, TRIGGER, TRIGGER_CATALOG, TRIGGER_NAME, TRIGGER_SCHEMA, TRIM, TRUE, TYPE, UESCAPE, UNBOUNDED, UNCOMMITTED, UNDER, UNION, UNIQUE, UNKNOWN, UNNAMED, UNNEST, UPDATE, UPPER, UPSERT, USAGE, USER, USER_DEFINED_TYPE_CATALOG, USER_DEFINED_TYPE_CODE, USER_DEFINED_TYPE_NAME, USER_DEFINED_TYPE_SCHEMA, USING, VALUE, VALUES, VARBINARY, VARCHAR, VARYING, VAR_POP, VAR_SAMP, VERSION, VIEW, WEEK, WHEN, WHENEVER, WHERE, WIDTH_BUCKET, WINDOW, WITH, WITHIN, WITHOUT, WORK, WRAPPER, WRITE, XML, YEAR, ZONE
日期格式说明符 |
描述 |
%a |
缩写的工作日名称(Sun.. Sat) |
%b |
缩写的月份名称(Jan.. Dec) |
%c |
月,数字(1.. 12) |
%D |
这个月的一天,英语后缀(0th,1st,2nd,3rd,…) |
%d |
每月的某天,数字(01.. 31) |
%e |
每月的某天,数字(1.. 31) |
%f |
第二个分数(打印6位数:000000… 999000;解析时为1 - 9位数:0..999999999)(时间戳被截断为毫秒。) |
%H |
小时(00.. 23) |
%h |
小时(01.. 12) |
%I |
小时(01.. 12) |
%i |
分钟,数字(00.. 59) |
%j |
一年中的某一天(001.. 366) |
%k |
小时(0.. 23) |
%l |
小时(1.. 12) |
%M |
月份名称(January.. December) |
%m |
月,数字(01.. 12) |
%p |
AM 要么 PM |
%r |
时间,12小时(hh:mm:ss其次是AM或PM) |
%S |
秒(00… 59) |
%s |
秒(00… 59) |
%T |
时间,24小时(hh:mm:ss) |
%U |
周(00.. 53),周日是一周的第一天 |
%u |
周(00.. 53),周一是一周的第一天 |
%V |
周(01.. 53),周日是一周的第一天; 用于%X |
%v |
周(01.. 53),周一是一周的第一天; 用于%x |
%W |
平日名称(Sunday.. Saturday) |
%w |
星期几(0.. 6),星期日是一周的第一天 |
%X |
星期日是星期的第一天的星期,数字,四位数; 用于%V |
%x |
一周的年份,星期一是一周的第一天,数字,四位数; 用于%v |
%Y |
年份,数字,四位数 |
%y |
年份,数字(两位数) |
%% |
文字%字符 |
%x |
x,对于x上面未列出的任何内容 |
常见错误
语句 |
错误信息 |
错误原因 |
解决办法 |
select average_pay, product_time as time, province from ${t0} |
“实验运行失败Invalid Node[SqlCmd]: SQL parse failed. Encountered “as time” at line 1, column 29. Was expecting one of: “ORDER” … “LIMIT” … “OFFSET” … “FETCH” … “FROM” … “,” … “AS” … “AS” … “AS” … “AS” … “AS” … “.” … “NOT” … “IN” … “<” … “<=” … “>” … “>=” … “=” … “<>” … “!=” … “BETWEEN” … “LIKE” … “SIMILAR” … “+” … “-“ … “*” … “/“ … “%” … “||” … “AND” … “OR” … “IS” … “MEMBER” … “SUBMULTISET” … “CONTAINS” … “OVERLAPS” … “EQUALS” … “PRECEDES” … “SUCCEEDS” … “IMMEDIATELY” … “MULTISET” … “[“ … “UNION” … “INTERSECT” … “EXCEPT” … “MINUS” .” |
列名’time’与Flink保留字冲突 |
用反引号引用,如: select average_pay, product_time as time, province from ${t0} |
if a < 0.5 |
|
不支持if |
需要换成case when |