AWS Athena:获取最后一个分隔符之后的字符串的部分
创始人
2024-11-14 10:00:18
0

在AWS Athena中,可以使用substring()strpos()函数来获取最后一个分隔符之后的字符串的部分。

下面是一个示例代码,假设我们有一个包含路径的字符串,我们想要获取最后一个分隔符之后的部分:

SELECT
  column_name,
  CASE
    WHEN strpos(column_name, '/') > 0 THEN substring(column_name, strpos_rev(column_name, '/') + 1)
    ELSE column_name
  END AS last_part
FROM
  table_name

在上面的代码中,column_name是包含路径的字符串列名,table_name是表名。

strpos()函数用于查找字符串中第一个出现的指定子字符串的位置。strpos_rev()是一个自定义函数,用于查找字符串中最后一个出现的指定子字符串的位置。

substring()函数用于提取字符串的一部分,第一个参数是要提取的字符串,第二个参数是要提取的起始位置。

在上面的代码中,使用strpos(column_name, '/')来查找最后一个分隔符/的位置,并使用substring(column_name, strpos_rev(column_name, '/') + 1)来提取最后一个分隔符之后的部分。如果字符串中没有分隔符,那么就返回整个字符串。

请注意,上述代码中的strpos_rev()函数是自定义函数,需要根据需要进行创建和注册。以下是一个示例的strpos_rev()函数的定义:

CREATE OR REPLACE FUNCTION strpos_rev(str VARCHAR, sub VARCHAR)
  RETURNS INT
  COMMENT 'Returns the position of the last occurrence of a string within another string.'
  LANGUAGE JAVASCRIPT
  AS
  '
  var result = str.lastIndexOf(sub);
  if (result === -1) {
    return 0;
  } else {
    return result + 1;
  }
  '
;

上述代码中的strpos_rev()函数是一个JavaScript函数,用于返回字符串中最后一个出现指定子字符串的位置。如果找不到指定子字符串,函数返回0。

在使用上述代码时,请将column_nametable_name替换为实际使用的列名和表名。

相关内容

热门资讯

线上(wepoke真的)原来是... 线上(wepoke真的)原来是真的有挂!其实真的有挂(2022已更新)(哔哩哔哩);亲,其实确实真的...
两教程(Wepoke程序)软件... 两教程(Wepoke程序)软件透明挂辅助工具(软件透明挂)透视辅助(2024已更新)(哔哩哔哩);致...
软件(wepoke透明)原来是... 软件(wepoke透明)原来是真的有挂!其实真的有挂(2020已更新)(哔哩哔哩)是一款可以让一直输...
一模拟器(德扑工具)外挂辅助工... 一模拟器(德扑工具)外挂辅助工具(透视)透视辅助(2025已更新)(哔哩哔哩);亲真的是有正版授权,...
系统(aapoker讲解)竟然... 系统(aapoker讲解)竟然真的有挂!其实真的有挂(2021已更新)(哔哩哔哩);aapoker讲...
6系统(aapoker下载)外... 6系统(aapoker下载)外挂辅助工具(辅助挂)透视辅助(2023已更新)(哔哩哔哩)aapoke...
智能(德扑之星刷数据)果真真的... 智能(德扑之星刷数据)果真真的有挂!原来真的有挂(2025已更新)(哔哩哔哩);《WPK辅助透视》‌...
1机器人(德州nzt软件)软件... 1机器人(德州nzt软件)软件透明挂辅助软件(透视)透视辅助(2022已更新)(哔哩哔哩);人气非常...
ai代打(德扑之星决策)确实是... ai代打(德扑之星决策)确实是真的有挂!原来真的有挂(2020已更新)(哔哩哔哩);科技详细教程小薇...
第8透明(wepoke数据)外... 第8透明(wepoke数据)外挂透明挂辅助神器(辅助挂)透视辅助(2023已更新)(哔哩哔哩);原来...