首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Spark SQL:列值只能是A、T、G、C或N的组合

Spark SQL:列值只能是A、T、G、C或N的组合
EN

Stack Overflow用户
提问于 2016-04-29 20:25:19
回答 2查看 73关注 0票数 0

我正试图查询一个火花表,以查找“ref”列中包含非A、T、G、C或N的字母的所有行。

有效的结果应该只包含这些字母,并且可以包含这些字母的任何长度或组合。

例如:

有效= AA,ATTTGGGGCCCC,C,G,TTG,N等。

无效= P,.,空

以下查询只返回带有单个核苷酸的列:

代码语言:javascript
运行
复制
SELECT ref
from test_set
where ref not in ('*A*', '*T*', '*G*', '*C*', '*N*')

ref
1   T
2   C
3   T
4   C
5   T

下面的查询在impala中工作,但没有spark,而且也很难看:

代码语言:javascript
运行
复制
SELECT regexp_replace(regexp_replace(regexp_replace(regexp_replace(regexp_replace(ref, 'A', ''), 'T', ''), 'G', ''), 'C', ''), 'N', '')
    from spark_df
EN

Stack Overflow用户

回答已采纳

发布于 2016-04-29 20:39:56

好的..。我想出来了:

代码语言:javascript
运行
复制
SELECT regexp_extract(ref, 'ATGCN', 0)
from test_set

代码语言:javascript
运行
复制
SELECT alt 
FROM test_set
WHERE regexp_extract( alt, '([^ACGTN.])', 0 ) IS NULL
票数 1
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36946891

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档