Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
2a4a6b22
C
ClickHouse
项目概览
2dot5
/
ClickHouse
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
ClickHouse
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
2a4a6b22
编写于
12月 16, 2020
作者:
A
alesapin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix remove TTL for column
上级
37363ae8
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
38 addition
and
1 deletion
+38
-1
src/Storages/AlterCommands.cpp
src/Storages/AlterCommands.cpp
+3
-1
tests/queries/0_stateless/01603_remove_column_ttl.reference
tests/queries/0_stateless/01603_remove_column_ttl.reference
+6
-0
tests/queries/0_stateless/01603_remove_column_ttl.sql
tests/queries/0_stateless/01603_remove_column_ttl.sql
+29
-0
未找到文件。
src/Storages/AlterCommands.cpp
浏览文件 @
2a4a6b22
...
...
@@ -793,6 +793,7 @@ void AlterCommands::apply(StorageInMemoryMetadata & metadata, const Context & co
throw
DB
::
Exception
(
"Alter commands is not prepared. Cannot apply. It's a bug"
,
ErrorCodes
::
LOGICAL_ERROR
);
auto
metadata_copy
=
metadata
;
for
(
const
AlterCommand
&
command
:
*
this
)
if
(
!
command
.
ignore
)
command
.
apply
(
metadata_copy
,
context
);
...
...
@@ -823,6 +824,7 @@ void AlterCommands::apply(StorageInMemoryMetadata & metadata, const Context & co
/// Changes in columns may lead to changes in TTL expressions.
auto
column_ttl_asts
=
metadata_copy
.
columns
.
getColumnTTLs
();
metadata_copy
.
column_ttls_by_name
.
clear
();
for
(
const
auto
&
[
name
,
ast
]
:
column_ttl_asts
)
{
auto
new_ttl_entry
=
TTLDescription
::
getTTLFromAST
(
ast
,
metadata_copy
.
columns
,
context
,
metadata_copy
.
primary_key
);
...
...
@@ -830,7 +832,7 @@ void AlterCommands::apply(StorageInMemoryMetadata & metadata, const Context & co
}
if
(
metadata_copy
.
table_ttl
.
definition_ast
!=
nullptr
)
metadata
.
table_ttl
=
TTLTableDescription
::
getTTLForTableFromAST
(
metadata
_copy
.
table_ttl
=
TTLTableDescription
::
getTTLForTableFromAST
(
metadata_copy
.
table_ttl
.
definition_ast
,
metadata_copy
.
columns
,
context
,
metadata_copy
.
primary_key
);
metadata
=
std
::
move
(
metadata_copy
);
...
...
tests/queries/0_stateless/01603_remove_column_ttl.reference
0 → 100644
浏览文件 @
2a4a6b22
1 32
2 0
CREATE TABLE default.table_with_column_ttl\n(\n `EventTime` DateTime,\n `UserID` UInt64,\n `Age` UInt8\n)\nENGINE = MergeTree\nORDER BY tuple()\nSETTINGS index_granularity = 8192
1 32
2 0
3 27
tests/queries/0_stateless/01603_remove_column_ttl.sql
0 → 100644
浏览文件 @
2a4a6b22
DROP
TABLE
IF
EXISTS
table_with_column_ttl
;
CREATE
TABLE
table_with_column_ttl
(
EventTime
DateTime
,
UserID
UInt64
,
Age
UInt8
TTL
EventTime
+
INTERVAL
3
MONTH
)
ENGINE
MergeTree
()
ORDER
BY
tuple
();
INSERT
INTO
table_with_column_ttl
VALUES
(
now
(),
1
,
32
);
INSERT
INTO
table_with_column_ttl
VALUES
(
now
()
-
INTERVAL
4
MONTH
,
2
,
45
);
OPTIMIZE
TABLE
table_with_column_ttl
FINAL
;
SELECT
UserID
,
Age
FROM
table_with_column_ttl
ORDER
BY
UserID
;
ALTER
TABLE
table_with_column_ttl
MODIFY
COLUMN
Age
REMOVE
TTL
;
SHOW
CREATE
TABLE
table_with_column_ttl
;
INSERT
INTO
table_with_column_ttl
VALUES
(
now
()
-
INTERVAL
10
MONTH
,
3
,
27
);
OPTIMIZE
TABLE
table_with_column_ttl
FINAL
;
SELECT
UserID
,
Age
FROM
table_with_column_ttl
ORDER
BY
UserID
;
DROP
TABLE
table_with_column_ttl
;
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录