clickhouse sql语句

查看a表的创建语句

复制代码
SHOW CREATE TABLE a;

删除表b

复制代码
DROP TABLE b;

例如:

sql 复制代码
CREATE TABLE ark_us.d_stk_info_us_polygon_cik_5_w
(
    `ticker` String,
    `t_date` DateTime64(6),
    `name` Nullable(String),
    `market` Nullable(String),
    `type` Nullable(String),
    `cik` Nullable(String),
    `primary_exchange` Nullable(String),
    `is_alter` Nullable(String),
    `data_issue` Nullable(String),
    `alter_data` Nullable(String)
)
ENGINE = MergeTree
PARTITION BY toYYYYMM(t_date)
ORDER BY (ticker, t_date)
SETTINGS index_granularity = 8192

DROP TABLE ark_us.d_stk_info_us_polygon_cik_5_w

select语句,group by,

正则表达式:

sql 复制代码
SELECT *
                        FROM ark_us.d_stk_info_us_polygon_cik_1_w
                        WHERE (not arrayStringConcat(splitByChar('.', substring(ticker, 1))) != arrayStringConcat(splitByChar('.', replaceRegexpAll(ticker, '[a-z]', ''))))---小写字母
                            and(
                             NOT (ticker LIKE '%.%')-- ticker 不含有点
                            OR
                            -- ticker 含有点且点后只含有一个字符
                            (ticker LIKE '%._%' AND ticker NOT LIKE '%.__%'))
                            and (not ticker like '%.%.%')

对于v1表,选出两种类型,只有CS,只发生CS和NULL转变的两种cik-ticker,得到v2表

sql 复制代码
--插入数据表
insert into ark.d_stk_info_us_polygon_v2 select * from
(
	SELECT ticker, t_date, name, market, if(type IS NULL, 'CS', type)as type, cik, primary_exchange
	FROM (
	select concat(if(cik IS NULL, 'NULL', cik),
	        if(ticker IS NULL, 'NULL', ticker) ) as cik_ticker ,
	        cik,ticker,t_date,type,name,market,primary_exchange
	FROM ark.d_stk_info_us_polygon_v1
	where market = 'stocks'
	) as a_table
	RIGHT JOIN (
	    select *,concat(if(cik IS NULL, 'NULL', cik),
	        if(ticker IS NULL, 'NULL', ticker) ) as cik_ticker from (
	SELECT 
	    cik,
	    ticker,
	    groupArray(DISTINCT if(type IS NULL, 'NULL', type)) AS type_list,
	    arrayStringConcat(type_list) AS type_str
	FROM ark.d_stk_info_us_polygon_v1
	where market = 'stocks'
	GROUP BY cik,ticker
	HAVING length(type_list) >= 1
	) where   type_str in ('CS', 'CSNULL', 'NULLCS')
	) as b_table USING (cik_ticker)
)

distinct ,count(),group by having

sql 复制代码
nohup python3 data.py > output_1733.log &

相关推荐
ccddsdsdfsdf38 分钟前
DBeaver怎么链接mongoDB
数据库·mongodb
丷丩1 小时前
Postgresql基础实践教程(十一)各种Join
数据库·postgresql·join
星夜夏空992 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
TheRouter2 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle
Omics Pro3 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
唐青枫3 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
sql·mysql
JAVA面经实录9174 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫7124 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
Mr.Daozhi5 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_805 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体