147 lines
4.6 KiB
C++
147 lines
4.6 KiB
C++
/**
|
|
* Copyright (c) 2021 OceanBase
|
|
* OceanBase CE is licensed under Mulan PubL v2.
|
|
* You can use this software according to the terms and conditions of the Mulan PubL v2.
|
|
* You may obtain a copy of Mulan PubL v2 at:
|
|
* http://license.coscl.org.cn/MulanPubL-2.0
|
|
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
|
|
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
|
|
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
|
|
* See the Mulan PubL v2 for more details.
|
|
*/
|
|
|
|
#ifndef OB_MACRO_META_GENERATE_H_
|
|
#define OB_MACRO_META_GENERATE_H_
|
|
|
|
#include "lib/number/ob_number_v2.h"
|
|
#include "storage/blocksstable/ob_block_sstable_struct.h"
|
|
|
|
namespace oceanbase {
|
|
using namespace common;
|
|
namespace blocksstable {
|
|
class ObMacroMetaGenerator {
|
|
public:
|
|
ObMacroMetaGenerator()
|
|
{}
|
|
virtual ~ObMacroMetaGenerator()
|
|
{}
|
|
static int gen_meta(ObMacroBlockMeta& meta, ObIAllocator& allocator);
|
|
};
|
|
|
|
int ObMacroMetaGenerator::gen_meta(ObMacroBlockMeta& meta, ObIAllocator& allocator)
|
|
{
|
|
int ret = OB_SUCCESS;
|
|
int16_t column_num = 7;
|
|
char* buf = NULL;
|
|
|
|
meta.attr_ = ObMacroBlockCommonHeader::SSTableData;
|
|
meta.data_version_ = 1;
|
|
meta.column_number_ = column_num;
|
|
meta.rowkey_column_number_ = column_num;
|
|
meta.column_index_scale_ = 1;
|
|
meta.row_store_type_ = 0;
|
|
meta.row_count_ = 10;
|
|
meta.occupy_size_ = 123;
|
|
meta.data_checksum_ = 111;
|
|
meta.micro_block_count_ = 1;
|
|
meta.micro_block_data_offset_ = 0;
|
|
meta.micro_block_index_offset_ = 222;
|
|
meta.micro_block_endkey_offset_ = 333;
|
|
|
|
meta.compressor_ = (char*)allocator.alloc(5);
|
|
strncpy(meta.compressor_, "none", 5);
|
|
|
|
if (OB_SUCC(ret)) {
|
|
if (NULL == (buf = (char*)allocator.alloc(sizeof(ObObj) * column_num))) {
|
|
ret = OB_ALLOCATE_MEMORY_FAILED;
|
|
} else {
|
|
meta.endkey_ = new (buf) ObObj[column_num];
|
|
}
|
|
}
|
|
|
|
if (OB_SUCC(ret)) {
|
|
if (NULL == (buf = (char*)allocator.alloc(sizeof(ObObjMeta) * column_num))) {
|
|
ret = OB_ALLOCATE_MEMORY_FAILED;
|
|
} else {
|
|
meta.column_type_array_ = new (buf) ObObjMeta[column_num];
|
|
}
|
|
}
|
|
|
|
if (OB_SUCC(ret)) {
|
|
if (NULL == (buf = (char*)allocator.alloc(sizeof(uint16_t) * column_num))) {
|
|
ret = OB_ALLOCATE_MEMORY_FAILED;
|
|
} else {
|
|
meta.column_id_array_ = new (buf) uint16_t[column_num];
|
|
}
|
|
}
|
|
|
|
if (OB_SUCC(ret)) {
|
|
if (NULL == (buf = (char*)allocator.alloc(sizeof(ObOrderType) * column_num))) {
|
|
ret = OB_ALLOCATE_MEMORY_FAILED;
|
|
} else {
|
|
meta.column_order_array_ = new (buf) ObOrderType[column_num];
|
|
}
|
|
}
|
|
|
|
if (OB_SUCC(ret)) {
|
|
if (NULL == (buf = (char*)allocator.alloc(sizeof(int64_t) * column_num))) {
|
|
ret = OB_ALLOCATE_MEMORY_FAILED;
|
|
} else {
|
|
meta.column_checksum_ = new (buf) int64_t[column_num];
|
|
}
|
|
}
|
|
|
|
if (OB_SUCC(ret)) {
|
|
// init endkey
|
|
// ObTinyIntType type
|
|
meta.endkey_[0].set_tinyint(static_cast<int8_t>(0));
|
|
meta.column_type_array_[0].set_type(common::ObTinyIntType);
|
|
// ObUTinyIntType type
|
|
meta.endkey_[1].set_utinyint(1);
|
|
meta.column_type_array_[1].set_type(common::ObUTinyIntType);
|
|
// ObDoubleType type
|
|
meta.endkey_[2].set_double(static_cast<double>(2));
|
|
meta.column_type_array_[2].set_type(common::ObDoubleType);
|
|
// ObNumber type
|
|
common::number::ObNumber number;
|
|
buf = reinterpret_cast<char*>(allocator.alloc(1024));
|
|
int64_t tmp = 3;
|
|
ret = number.from(tmp, allocator);
|
|
meta.endkey_[3].set_number(number);
|
|
meta.column_type_array_[3].set_type(common::ObNumberType);
|
|
// ObYearType type
|
|
meta.endkey_[4].set_year(static_cast<uint8_t>(4));
|
|
meta.column_type_array_[4].set_type(common::ObYearType);
|
|
// ObVarcharType
|
|
sprintf(buf, "%d", 5);
|
|
ObString str;
|
|
str.assign_ptr(buf, static_cast<int32_t>(strlen(buf)));
|
|
meta.endkey_[5].set_varchar(str);
|
|
meta.endkey_[5].set_collation_type(CS_TYPE_UTF8MB4_GENERAL_CI);
|
|
meta.column_type_array_[5].set_type(common::ObVarcharType);
|
|
meta.column_type_array_[5].set_collation_type(CS_TYPE_UTF8MB4_GENERAL_CI);
|
|
// ObHexStringType
|
|
sprintf(buf, "%d", 5);
|
|
str.assign_ptr(buf, static_cast<int32_t>(strlen(buf)));
|
|
meta.endkey_[6].set_hex_string(str);
|
|
meta.column_type_array_[6].set_type(common::ObHexStringType);
|
|
|
|
for (int64_t i = 0; i < column_num; ++i) {
|
|
meta.column_id_array_[i] = static_cast<uint16_t>(i);
|
|
meta.column_checksum_[i] = i + 0x1220;
|
|
if (i % 2 == 0) {
|
|
meta.column_order_array_[i] = ObOrderType::ASC;
|
|
} else {
|
|
meta.column_order_array_[i] = ObOrderType::DESC;
|
|
}
|
|
}
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
} // namespace blocksstable
|
|
} // namespace oceanbase
|
|
|
|
#endif /* OB_MACRO_META_GENERATE_H_ */
|