-
Notifications
You must be signed in to change notification settings - Fork 409
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Support all DAG operator types in mock SQL -> DAG parser (#176)
* Enhance dbg invoke and add dag as schemaful function * Add basic sql parse to dag * Column id starts from 1 * Fix value to ref * Add basic dag test * Fix dag bugs and pass 1st mock test * Make dag go normal routine and add mock dag * Add todo * Add comment * Fix gcc compile error * Enhance dag test * Address comments * Enhance mock sql -> dag compiler and add project test * Mock sql dag compiler support more expression types and add filter test * Add topn and limit test * Add agg for sql -> dag parser and agg test * Add dag specific codec * type * Update codec accordingly * Remove cop-test
- Loading branch information
1 parent
b25d1cc
commit 3d38b7b
Showing
13 changed files
with
634 additions
and
385 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
#include <Flash/Coprocessor/DAGCodec.h> | ||
|
||
#include <Storages/Transaction/Codec.h> | ||
#include <Storages/Transaction/TiKVRecordFormat.h> | ||
|
||
namespace DB | ||
{ | ||
|
||
void encodeDAGInt64(Int64 i, std::stringstream & ss) | ||
{ | ||
auto u = RecordKVFormat::encodeInt64(i); | ||
ss.write(reinterpret_cast<const char *>(&u), sizeof(u)); | ||
} | ||
|
||
void encodeDAGUInt64(UInt64 i, std::stringstream & ss) | ||
{ | ||
auto u = RecordKVFormat::encodeUInt64(i); | ||
ss.write(reinterpret_cast<const char *>(&u), sizeof(u)); | ||
} | ||
|
||
void encodeDAGFloat32(Float32 f, std::stringstream & ss) { EncodeFloat64(f, ss); } | ||
|
||
void encodeDAGFloat64(Float64 f, std::stringstream & ss) { EncodeFloat64(f, ss); } | ||
|
||
void encodeDAGString(const String & s, std::stringstream & ss) { ss << s; } | ||
|
||
void encodeDAGBytes(const String & bytes, std::stringstream & ss) { ss << bytes; } | ||
|
||
void encodeDAGDecimal(const Decimal & d, std::stringstream & ss) { EncodeDecimal(d, ss); } | ||
|
||
Int64 decodeDAGInt64(const String & s) | ||
{ | ||
auto u = *(reinterpret_cast<const UInt64 *>(s.data())); | ||
return RecordKVFormat::decodeInt64(u); | ||
} | ||
|
||
UInt64 decodeDAGUInt64(const String & s) | ||
{ | ||
auto u = *(reinterpret_cast<const UInt64 *>(s.data())); | ||
return RecordKVFormat::decodeUInt64(u); | ||
} | ||
|
||
Float32 decodeDAGFloat32(const String & s) | ||
{ | ||
size_t cursor = 0; | ||
return DecodeFloat64(cursor, s); | ||
} | ||
|
||
Float64 decodeDAGFloat64(const String & s) | ||
{ | ||
size_t cursor = 0; | ||
return DecodeFloat64(cursor, s); | ||
} | ||
|
||
String decodeDAGString(const String & s) { return s; } | ||
|
||
String decodeDAGBytes(const String & s) { return s; } | ||
|
||
Decimal decodeDAGDecimal(const String & s) | ||
{ | ||
size_t cursor = 0; | ||
return DecodeDecimal(cursor, s); | ||
} | ||
|
||
} // namespace DB |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
#pragma once | ||
|
||
#include <Common/Decimal.h> | ||
#include <Core/Field.h> | ||
|
||
namespace DB | ||
{ | ||
|
||
void encodeDAGInt64(Int64, std::stringstream &); | ||
void encodeDAGUInt64(UInt64, std::stringstream &); | ||
void encodeDAGFloat32(Float32, std::stringstream &); | ||
void encodeDAGFloat64(Float64, std::stringstream &); | ||
void encodeDAGString(const String &, std::stringstream &); | ||
void encodeDAGBytes(const String &, std::stringstream &); | ||
void encodeDAGDecimal(const Decimal &, std::stringstream &); | ||
|
||
Int64 decodeDAGInt64(const String &); | ||
UInt64 decodeDAGUInt64(const String &); | ||
Float32 decodeDAGFloat32(const String &); | ||
Float64 decodeDAGFloat64(const String &); | ||
String decodeDAGString(const String &); | ||
String decodeDAGBytes(const String &); | ||
Decimal decodeDAGDecimal(const String &); | ||
|
||
} // namespace DB |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1 @@ | ||
include_directories (${CMAKE_CURRENT_BINARY_DIR}) | ||
|
||
add_executable (cop_test cop_test.cpp) | ||
target_link_libraries (cop_test dbms) |
Oops, something went wrong.