You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@beam.apache.org by "Rui Wang (JIRA)" <ji...@apache.org> on 2018/11/08 22:17:00 UTC
[jira] [Closed] (BEAM-5963) LPAD
[ https://issues.apache.org/jira/browse/BEAM-5963?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Rui Wang closed BEAM-5963.
--------------------------
Resolution: Done
Fix Version/s: Not applicable
> LPAD
> ----
>
> Key: BEAM-5963
> URL: https://issues.apache.org/jira/browse/BEAM-5963
> Project: Beam
> Issue Type: Sub-task
> Components: dsl-sql
> Reporter: Rui Wang
> Assignee: Rui Wang
> Priority: Major
> Fix For: Not applicable
>
>
> LPAD(original_value, return_length[, pattern])
> Returns a value that consists of original_value prepended with pattern. The return_length is an INT64 that specifies the length of the returned value. If original_value is BYTES, return_length is the number of bytes. If original_value is STRING, return_length is the number of characters.
> The default value of pattern is a blank space.
> Both original_value and pattern must be the same data type.
> If return_length is less than or equal to the original_value length, this function returns the original_value value, truncated to the value of return_length. For example, LPAD("hello world", 7); returns "hello w".
> If original_value, return_length, or pattern is NULL, this function returns NULL.
> This function returns an error if:
> return_length is negative
> pattern is empty
> Return type
> STRING or BYTES
> Examples
> SELECT t, len, FORMAT("%T", LPAD(t, len)) AS LPAD FROM UNNEST([
> STRUCT('abc' AS t, 5 AS len),
> ('abc', 2),
> ('例子', 4)
> ]);
> t len LPAD
> abc 5 " abc"
> abc 2 "ab"
> 例子 4 " 例子"
> SELECT t, len, pattern, FORMAT("%T", LPAD(t, len, pattern)) AS LPAD FROM UNNEST([
> STRUCT('abc' AS t, 8 AS len, 'def' AS pattern),
> ('abc', 5, '-'),
> ('例子', 5, '中文')
> ]);
> t len pattern LPAD
> abc 8 def "defdeabc"
> abc 5 - "--abc"
> 例子 5 中文 "中文中例子"
> SELECT FORMAT("%T", t) AS t, len, FORMAT("%T", LPAD(t, len)) AS LPAD FROM UNNEST([
> STRUCT(b'abc' AS t, 5 AS len),
> (b'abc', 2),
> (b'\xab\xcd\xef', 4)
> ]);
> t len LPAD
> b"abc" 5 b" abc"
> b"abc" 2 b"ab"
> b"\xab\xcd\xef" 4 b" \xab\xcd\xef"
> SELECT
> FORMAT("%T", t) AS t,
> len,
> FORMAT("%T", pattern) AS pattern,
> FORMAT("%T", LPAD(t, len, pattern)) AS LPAD
> FROM UNNEST([
> STRUCT(b'abc' AS t, 8 AS len, b'def' AS pattern),
> (b'abc', 5, b'-'),
> (b'\xab\xcd\xef', 5, b'\x00')
> ]);
> t len pattern LPAD
> b"abc" 8 b"def" b"defdeabc"
> b"abc" 5 b"-" b"--abc"
> b"\xab\xcd\xef" 5 b"\x00" b"\x00\x00\xab\xcd\xef"
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)