实现一个简单的数据库5

编辑测试用例
完整的c语言代码

#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h>

// 输入缓冲区
typedef struct {
   
    char* buffer;
    size_t buffer_length;
    ssize_t input_length;
} InputBuffer;

// 执行结果 lesson4
typedef enum {
    
    EXECUTE_SUCCESS, // 执行成功
    EXECUTE_TABLE_FULL  // 表满
} ExecuteResult;

// 源语句的枚举类型
typedef enum {
   
    META_COMMAND_SUCCESS,
    META_COMMAND_UNRECOGNIZED_COMMAND
} MetaCommandResult;

typedef enum {
   
    PREPARE_SUCCESS,
    PREPARE_NEGATIVE_ID,
    PREPARE_STRING_TOO_LONG,
    PREPARE_SYNTAX_ERROR,
    PREPARE_UNRECOGNIZED_STATEMENT
 } PrepareResult;

typedef enum {
    
    STATEMENT_INSERT, 
    STATEMENT_SELECT 
} StatementType;


#define COLUMN_USERNAME_SIZE 32
#define COLUMN_EMAIL_SIZE 255
typedef struct {
   
    uint32_t id;
    char username[COLUMN_USERNAME_SIZE + 1];
    char email[COLUMN_EMAIL_SIZE + 1];
} Row;

typedef struct {
   
    StatementType type;
    Row row_to_insert; //only used by insert statement
} Statement;

#define size_of_attribute(Struct, Attribute) sizeof(((Struct*)0)->Attribute)

const uint32_t ID_SIZE = size_of_attribute(Row, id);
const uint32_t USERNAME_SIZE = size_of_attribute(Row, username);
const uint32_t EMAIL_SIZE = size_of_attribute(Row, email);
const uint32_t ID_OFFSET = 0;
const uint32_t USERNAME_OFFSET = 4;
const uint32_t EMAIL_OFFSET = 37;
const uint32_t ROW_SIZE = 293;

const uint32_t PAGE_SIZE = 4096;
#define TABLE_MAX_PAGES 100
const uint32_t ROWS_PER_PAGE = 4096 / 293;
const uint32_t TABLE_MAX_ROWS = 4096 / 293 * TABLE_MAX_PAGES;

typedef struct {
   
  uint32_t num_rows;
  void* pages[TABLE_MAX_PAGES];
} Table;

void print_row(Row* row) {
   
  printf("(%d, %s, %s)\n", row->id, row->username, row->email);
}

void serialize_row(Row* source, void* destination) {
   
  memcpy(destination + ID_OFFSET, &(source->id), ID_SIZE);
  memcpy(destination + USERNAME_OFFSET, &(source->username), USERNAME_SIZE);
  memcpy(destination + EMAIL_OFFSET, &(source->email), EMAIL_SIZE);
}

void deserialize_row(void *source, Row* destination) {
   
  memcpy(&(destination->id), source + ID_OFFSET, ID_SIZE);
  memcpy(&(destination
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值