Amazon Athenaで表題の関数について。Amazon Athenaに限った話ではなくSQLの話だけれども…。
■ 環境
- Amazon Athena
■ きっかけ
やりたいこととしては単純に『カラムの値を連結したい』ということだけのはずだった。もうずっと単純なSQLしか書いていなかったのでここら辺の関数についていろいろ忘れておりはまってしまった。
■ CONCAT
文字列として連結したいんだから、”CONCAT“でいけるだろうと思い試してみたところ、下記のエラーが出た。
Error running query: SYNTAX_ERROR: line 1:185: Unexpected parameters (integer) for function concat. Expected: concat(array(E), E) E, concat(E, array(E)) E, concat(array(E)) E, concat(varchar)
あれ?と思いドキュメントを見ていると下記を発見。
Concatenating Arrays
https://docs.aws.amazon.com/ja_jp/athena/latest/ug/concatenating-arrays.html
いややりたいことは”文字列“としての連結であって、配列の連結ではない。ということでこれは違う。もう一度エラーメッセージをよく見てみると下記の通り。
concat(varchar)
できるはずである。としばし考えて気がついた。対象のカラムの型が”int“であった。では”CAST“を挟めば良いのか。ということで下記のような感じになった。
select concat(cast(year as varchar), cast(month as varchar), cast(day as varchar)) ...
しかし得られた結果がこれでは微妙であった。”2018316“。”0“パディングしなければならない。”LPAD“の出番である。”LPAD“だから戻ってくるのは”varchar“だよね、と思い下記のように書き換えた。
select concat(cast(year as varchar), lpad(month, 2, '0'), lpad(day, 2, '0')) ...
実行すると下記のようなエラーが…。
Error running query: SYNTAX_ERROR: line 1:215: Unexpected parameters (integer, integer, varchar(1)) for function lpad. Expected: lpad(varchar(x), bigint, varchar(y))
これもエラーログをよく読んでみれば解決した。ここも”CAST“が必要であった。
最終的に下記で思い通りの結果を得られた。
select concat(cast(year as varchar), lpad(cast(month as varchar), 2, '0'), lpad(cast(day as varchar), 2, '0')) ...
以上。