Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
da2d0d26
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 搜索 >>
提交
da2d0d26
编写于
3月 25, 2021
作者:
A
Anton Popov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix build
上级
6a15431b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
0 addition
and
144 deletion
+0
-144
src/DataTypes/DataTypeDateTime.cpp
src/DataTypes/DataTypeDateTime.cpp
+0
-144
未找到文件。
src/DataTypes/DataTypeDateTime.cpp
浏览文件 @
da2d0d26
...
...
@@ -15,29 +15,6 @@
namespace
DB
{
<<<<<<<
HEAD
=======
namespace
{
inline
void
readTextHelper
(
time_t
&
x
,
ReadBuffer
&
istr
,
const
FormatSettings
&
settings
,
const
DateLUTImpl
&
time_zone
,
const
DateLUTImpl
&
utc_time_zone
)
{
switch
(
settings
.
date_time_input_format
)
{
case
FormatSettings
::
DateTimeInputFormat
::
Basic
:
readDateTimeText
(
x
,
istr
,
time_zone
);
return
;
case
FormatSettings
::
DateTimeInputFormat
::
BestEffort
:
parseDateTimeBestEffort
(
x
,
istr
,
time_zone
,
utc_time_zone
);
return
;
}
}
}
>>>>>>>
upstream
/
master
TimezoneMixin
::
TimezoneMixin
(
const
String
&
time_zone_name
)
:
has_explicit_time_zone
(
!
time_zone_name
.
empty
()),
...
...
@@ -66,127 +43,6 @@ String DataTypeDateTime::doGetName() const
return
out
.
str
();
}
<<<<<<<
HEAD
=======
void
DataTypeDateTime
::
serializeText
(
const
IColumn
&
column
,
size_t
row_num
,
WriteBuffer
&
ostr
,
const
FormatSettings
&
settings
)
const
{
auto
value
=
assert_cast
<
const
ColumnType
&>
(
column
).
getData
()[
row_num
];
switch
(
settings
.
date_time_output_format
)
{
case
FormatSettings
::
DateTimeOutputFormat
::
Simple
:
writeDateTimeText
(
value
,
ostr
,
time_zone
);
return
;
case
FormatSettings
::
DateTimeOutputFormat
::
UnixTimestamp
:
writeIntText
(
value
,
ostr
);
return
;
case
FormatSettings
::
DateTimeOutputFormat
::
ISO
:
writeDateTimeTextISO
(
value
,
ostr
,
utc_time_zone
);
return
;
}
}
void
DataTypeDateTime
::
serializeTextEscaped
(
const
IColumn
&
column
,
size_t
row_num
,
WriteBuffer
&
ostr
,
const
FormatSettings
&
settings
)
const
{
serializeText
(
column
,
row_num
,
ostr
,
settings
);
}
void
DataTypeDateTime
::
deserializeWholeText
(
IColumn
&
column
,
ReadBuffer
&
istr
,
const
FormatSettings
&
settings
)
const
{
deserializeTextEscaped
(
column
,
istr
,
settings
);
}
void
DataTypeDateTime
::
deserializeTextEscaped
(
IColumn
&
column
,
ReadBuffer
&
istr
,
const
FormatSettings
&
settings
)
const
{
time_t
x
=
0
;
readTextHelper
(
x
,
istr
,
settings
,
time_zone
,
utc_time_zone
);
if
(
x
<
0
)
x
=
0
;
assert_cast
<
ColumnType
&>
(
column
).
getData
().
push_back
(
x
);
}
void
DataTypeDateTime
::
serializeTextQuoted
(
const
IColumn
&
column
,
size_t
row_num
,
WriteBuffer
&
ostr
,
const
FormatSettings
&
settings
)
const
{
writeChar
(
'\''
,
ostr
);
serializeText
(
column
,
row_num
,
ostr
,
settings
);
writeChar
(
'\''
,
ostr
);
}
void
DataTypeDateTime
::
deserializeTextQuoted
(
IColumn
&
column
,
ReadBuffer
&
istr
,
const
FormatSettings
&
settings
)
const
{
time_t
x
=
0
;
if
(
checkChar
(
'\''
,
istr
))
/// Cases: '2017-08-31 18:36:48' or '1504193808'
{
readTextHelper
(
x
,
istr
,
settings
,
time_zone
,
utc_time_zone
);
assertChar
(
'\''
,
istr
);
}
else
/// Just 1504193808 or 01504193808
{
readIntText
(
x
,
istr
);
}
if
(
x
<
0
)
x
=
0
;
assert_cast
<
ColumnType
&>
(
column
).
getData
().
push_back
(
x
);
/// It's important to do this at the end - for exception safety.
}
void
DataTypeDateTime
::
serializeTextJSON
(
const
IColumn
&
column
,
size_t
row_num
,
WriteBuffer
&
ostr
,
const
FormatSettings
&
settings
)
const
{
writeChar
(
'"'
,
ostr
);
serializeText
(
column
,
row_num
,
ostr
,
settings
);
writeChar
(
'"'
,
ostr
);
}
void
DataTypeDateTime
::
deserializeTextJSON
(
IColumn
&
column
,
ReadBuffer
&
istr
,
const
FormatSettings
&
settings
)
const
{
time_t
x
=
0
;
if
(
checkChar
(
'"'
,
istr
))
{
readTextHelper
(
x
,
istr
,
settings
,
time_zone
,
utc_time_zone
);
assertChar
(
'"'
,
istr
);
}
else
{
readIntText
(
x
,
istr
);
}
if
(
x
<
0
)
x
=
0
;
assert_cast
<
ColumnType
&>
(
column
).
getData
().
push_back
(
x
);
}
void
DataTypeDateTime
::
serializeTextCSV
(
const
IColumn
&
column
,
size_t
row_num
,
WriteBuffer
&
ostr
,
const
FormatSettings
&
settings
)
const
{
writeChar
(
'"'
,
ostr
);
serializeText
(
column
,
row_num
,
ostr
,
settings
);
writeChar
(
'"'
,
ostr
);
}
void
DataTypeDateTime
::
deserializeTextCSV
(
IColumn
&
column
,
ReadBuffer
&
istr
,
const
FormatSettings
&
settings
)
const
{
time_t
x
=
0
;
if
(
istr
.
eof
())
throwReadAfterEOF
();
char
maybe_quote
=
*
istr
.
position
();
if
(
maybe_quote
==
'\''
||
maybe_quote
==
'\"'
)
++
istr
.
position
();
readTextHelper
(
x
,
istr
,
settings
,
time_zone
,
utc_time_zone
);
if
(
maybe_quote
==
'\''
||
maybe_quote
==
'\"'
)
assertChar
(
maybe_quote
,
istr
);
if
(
x
<
0
)
x
=
0
;
assert_cast
<
ColumnType
&>
(
column
).
getData
().
push_back
(
x
);
}
>>>>>>>
upstream
/
master
bool
DataTypeDateTime
::
equals
(
const
IDataType
&
rhs
)
const
{
/// DateTime with different timezones are equal, because:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录