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 &

相关推荐
越来越无动于衷27 分钟前
SQL 拼接完全指南
数据库·sql
面向星辰33 分钟前
day07 spark sql
大数据·sql·spark
weixin_46681 小时前
Redis数据库基础
数据库·redis·缓存
清风6666662 小时前
基于单片机的档案库房漏水检测报警labview上位机系统设计
数据库·单片机·毕业设计·课程设计·labview·期末大作业
DarkAthena2 小时前
【GaussDB】在duckdb中查询GaussDB的数据
数据库·gaussdb·duckdb
苏琢玉2 小时前
收藏版:Phinx 数据库迁移完全指南
数据库·mysql·php
七分小魔女2 小时前
MySQL查看服务器/客户端版本
服务器·数据库·mysql
亿坊电商3 小时前
如何检查开源CMS的数据库连接问题?
数据库·开源
指针不指南吗3 小时前
【论文阅读】图数据库 Survey: Graph Databases
数据库·论文阅读
fusugongzi3 小时前
mysql管理语句
数据库·mysql