Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[FLASH-402] Skip unneeded columns when decode row #173

Merged
merged 45 commits into from
Aug 20, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
6abfa1d
skip unneeded column
lidezhu Aug 10, 2019
b83a4b5
small fix
lidezhu Aug 11, 2019
445fc4d
check unknown column id when decode row
lidezhu Aug 12, 2019
fce6f15
add initializer for boolean variable
lidezhu Aug 13, 2019
0231b95
fix the case when tikv value contains just a nill flag
lidezhu Aug 13, 2019
0366142
remove unnecessary copy
lidezhu Aug 13, 2019
f5013e9
small improvement
lidezhu Aug 13, 2019
b0d3e9c
fix comment
lidezhu Aug 14, 2019
93a10a7
don't store column id in field
lidezhu Aug 14, 2019
8a5bb7b
small improvement
lidezhu Aug 15, 2019
dcc4265
remove unnecessary blank line
lidezhu Aug 15, 2019
a92d878
add log for performance debug
lidezhu Aug 15, 2019
1881a5c
adjust time point
lidezhu Aug 15, 2019
eae234b
small fix and adjust log
lidezhu Aug 15, 2019
43472ba
small improvement
lidezhu Aug 15, 2019
1ddb5d2
small improvement
lidezhu Aug 16, 2019
1952272
remove unnecessary construction
lidezhu Aug 16, 2019
d051cbb
small improvement
lidezhu Aug 16, 2019
7aee3e5
fix conflict with master
lidezhu Aug 16, 2019
9191506
uncomment flushregion
lidezhu Aug 16, 2019
8befbd6
Merge branch 'master' into FLASH402
solotzg Aug 19, 2019
a64e2c5
skip uint by calling DecodeVarUInt
lidezhu Aug 19, 2019
68a688d
Merge branch 'FLASH402' of github.com:lidezhu/tics into FLASH402
lidezhu Aug 19, 2019
33b14ef
Merge branch 'master' into FLASH402
lidezhu Aug 19, 2019
171b2f9
avoid insert column id
lidezhu Aug 20, 2019
dfabdb2
Merge branch 'FLASH402' of github.com:lidezhu/tics into FLASH402
lidezhu Aug 20, 2019
a8a25ca
small fix
lidezhu Aug 20, 2019
72beacc
add exception message
lidezhu Aug 20, 2019
237b7f2
comment flushRegion
lidezhu Aug 20, 2019
ad152f8
uncomment flushRegion and other minor fix
lidezhu Aug 20, 2019
c2afabb
modify push_back to emplace_back
lidezhu Aug 20, 2019
f50a6f4
add const
lidezhu Aug 20, 2019
9daf974
fix comment
lidezhu Aug 20, 2019
b6cb23f
fix comment
lidezhu Aug 20, 2019
8b89ea1
optimize by using dense_hash_map&dense_hash_set
solotzg Aug 20, 2019
8970e15
fix
solotzg Aug 20, 2019
1422d0a
fix
solotzg Aug 20, 2019
8b2e256
fix comment
lidezhu Aug 20, 2019
b574f5b
small fix
lidezhu Aug 20, 2019
12db36f
Merge branch 'FLASH402' of github.com:lidezhu/tics into lidezhu-FLASH…
solotzg Aug 20, 2019
96d62ed
Merge branch 'FLASH402' of github.com:lidezhu/tics into lidezhu-FLASH…
solotzg Aug 20, 2019
5119717
remove useless comment
lidezhu Aug 20, 2019
ad9bb51
format
solotzg Aug 20, 2019
e361ea5
Merge pull request #1 from solotzg/FLASH-402-optimize-hash
lidezhu Aug 20, 2019
f886ff3
[FLASH-402] optimize column_map (#2)
solotzg Aug 20, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
77 changes: 75 additions & 2 deletions dbms/src/Storages/Transaction/Codec.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,9 +44,9 @@ Float64 DecodeFloat64(size_t & cursor, const String & raw_value)
return enforce_cast<Float64>(num);
}

String DecodeBytes(size_t & cursor, const String & raw_value)
template <typename StringStream>
void DecodeBytes(size_t & cursor, const String & raw_value, StringStream & ss)
{
std::stringstream ss;
while (true)
{
size_t next_cursor = cursor + 9;
Expand All @@ -62,9 +62,26 @@ String DecodeBytes(size_t & cursor, const String & raw_value)
if (pad_size != 0)
break;
}
}

String DecodeBytes(size_t & cursor, const String & raw_value)
{
std::stringstream ss;
DecodeBytes(cursor, raw_value, ss);
return ss.str();
}

struct NullStringStream
{
void write(const char *, size_t) {}
};

void SkipBytes(size_t & cursor, const String & raw_value)
{
NullStringStream ss;
DecodeBytes(cursor, raw_value, ss);
}

String DecodeCompactBytes(size_t & cursor, const String & raw_value)
{
size_t size = DecodeVarInt(cursor, raw_value);
Expand All @@ -73,13 +90,21 @@ String DecodeCompactBytes(size_t & cursor, const String & raw_value)
return res;
}

void SkipCompactBytes(size_t & cursor, const String & raw_value)
{
size_t size = DecodeVarInt(cursor, raw_value);
cursor += size;
}

Int64 DecodeVarInt(size_t & cursor, const String & raw_value)
{
UInt64 v = DecodeVarUInt(cursor, raw_value);
Int64 vx = v >> 1;
return (v & 1) ? ~vx : vx;
}

void SkipVarInt(size_t & cursor, const String & raw_value) { SkipVarUInt(cursor, raw_value); }

UInt64 DecodeVarUInt(size_t & cursor, const String & raw_value)
{
UInt64 res = 0;
Expand All @@ -99,6 +124,8 @@ UInt64 DecodeVarUInt(size_t & cursor, const String & raw_value)
throw Exception("Wrong format. (DecodeVarUInt)", ErrorCodes::LOGICAL_ERROR);
}

void SkipVarUInt(size_t & cursor, const String & raw_value) { std::ignore = DecodeVarUInt(cursor, raw_value); }

inline Int8 getWords(PrecType prec, ScaleType scale)
{
Int8 scale_word = scale / 9 + (scale % 9 > 0);
Expand Down Expand Up @@ -204,6 +231,15 @@ Decimal DecodeDecimal(size_t & cursor, const String & raw_value)
return Decimal(value, prec, frac);
}

void SkipDecimal(size_t & cursor, const String & raw_value)
{
PrecType prec = raw_value[cursor++];
ScaleType frac = raw_value[cursor++];

int binSize = getBytes(prec, frac);
cursor += binSize;
}

Field DecodeDatum(size_t & cursor, const String & raw_value)
{
switch (raw_value[cursor++])
Expand Down Expand Up @@ -233,6 +269,43 @@ Field DecodeDatum(size_t & cursor, const String & raw_value)
}
}

void SkipDatum(size_t & cursor, const String & raw_value)
{
switch (raw_value[cursor++])
{
case TiDB::CodecFlagNil:
return;
case TiDB::CodecFlagInt:
cursor += sizeof(Int64);
return;
case TiDB::CodecFlagUInt:
cursor += sizeof(UInt64);
return;
case TiDB::CodecFlagBytes:
SkipBytes(cursor, raw_value);
return;
case TiDB::CodecFlagCompactBytes:
SkipCompactBytes(cursor, raw_value);
return;
case TiDB::CodecFlagFloat:
cursor += sizeof(UInt64);
return;
case TiDB::CodecFlagVarUInt:
SkipVarUInt(cursor, raw_value);
return;
case TiDB::CodecFlagVarInt:
SkipVarInt(cursor, raw_value);
return;
case TiDB::CodecFlagDuration:
throw Exception("Not implented yet. DecodeDatum: CodecFlagDuration", ErrorCodes::LOGICAL_ERROR);
case TiDB::CodecFlagDecimal:
SkipDecimal(cursor, raw_value);
return;
default:
throw Exception("Unknown Type:" + std::to_string(raw_value[cursor - 1]), ErrorCodes::LOGICAL_ERROR);
}
}

void EncodeFloat64(Float64 num, std::stringstream & ss)
{
UInt64 u = enforce_cast<UInt64>(num);
Expand Down
12 changes: 12 additions & 0 deletions dbms/src/Storages/Transaction/Codec.h
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,18 @@ Decimal DecodeDecimal(size_t & cursor, const String & raw_value);

Field DecodeDatum(size_t & cursor, const String & raw_value);

void SkipBytes(size_t & cursor, const String & raw_value);

void SkipCompactBytes(size_t & cursor, const String & raw_value);

void SkipVarInt(size_t & cursor, const String & raw_value);

void SkipVarUInt(size_t & cursor, const String & raw_value);

void SkipDecimal(size_t & cursor, const String & raw_value);

void SkipDatum(size_t & cursor, const String & raw_value);

template <typename T>
inline std::enable_if_t<std::is_unsigned_v<T>, void> EncodeUInt(T u, std::stringstream & ss)
{
Expand Down
Loading