一种基于列式sql数据库管理系统的时间序列数据库管理系统的设计方法
技术领域:
:1.该领域主要属于数据库设计,主要包含时间序列这种特殊数据的存储查询。
背景技术:
::2.该数据库是基于列式sql数据库进行开发设计的,包含的
背景技术:
:主要是socket编程,客户端服务器编程等。技术实现要素:3.该数据库管理系统的设计方法将sql请求转变成一个对象,querycontent,再通过传递该对象,实现整个数据查询流程的高效传递,从而实现了数据库管理系统的功能。4.该系统分为客户端和服务器,它们之间使用socket进行通信,服务器这边首先接收到客户端的sql请求,然后它会打开一个文本,从该文本中读取sql请求的内容,然后通过分析该sql请求的内容,生成一个对象,querycontent,然后将该对象作为一个参数,传递下去,直到本次查询终结。5.该系统创建的数据表格包含两种,一种的普通的table,另一种是timetable,其中timetable是专门用于存储时间序列数据的。6.querycontent作为本系统的核心参数传递者,它包含所有的查询有关的信息,一般说来,包含如下信息,string格式的query_type,int格式的query_type_code,string格式的config_home,一个createtable,一个createtimetable,一个inserttable,一个selecttable,一个droptable,一个droptimetable,一个deletetable,一个updatetable,一个createdatabase,一个dropdatabase,一个usedatabase。除去string格式和int格式的,剩下的都是新的类,用于保存sql请求参数的。其中createtable主要包含string格式的table_name,int格式的size,map《string,columntype》的create_list。其中table_name为表格的名称,size为创建表格参数的个数,create_list为参数的具体内容。createtimetable主要包含string格式的table_name,int格式的size,map《string,columntype》的create_list,string格式的time_stamp。其中table_name为表格的名称,size为创建表格参数的个数,create_list为参数的具体内容,time_stamp为时间戳。inserttable主要包含string格式的table_name,int格式的size,map《int,string》的insert_list。selecttable主要包含string格式的table_name,int格式的size,map《int,string》的select_list。droptable主要包含string格式的table_name,int格式的size。droptimetable主要包含string格式的table_name,int格式的size。deletetable主要包含string格式的table_name,int格式的size。updatetable主要包含string格式的table_name,int格式的size。createdatabase主要包含string格式的database_name,dropdatabase主要包含string格式的database_name,usedatabase主要包含string格式的database_name。一次sql请求语句的分析,可以将该querycontent的相关参数填满。并且配置好query_type_code。该query_type_code包含不同的类别,主要包含如下种类:cs_select_table,cs_select_table_all,cs_create_table,cs_create_time_table,cs_insert_table,cs_update_table,cs_drop_table,cs_drop_time_table,cs_delete_table,cs_create_database,cs_drop_database,cs_use_database,cs_show_database,根据不同的类别,服务器执行不同的行为,cs_select_table主要执行selecttable的行为,cs_select_table_all主要执行select*的行为,cs_create_table主要执行createtable的行为,cs_create_time_table主要执行createtimetable的行为,cs_insert_table主要执行insert的行为,cs_update_table主要执行updatetable的行为,cs_drop_table主要执行droptable的行为,cs_drop_time_table主要执行droptimetable的行为,cs_delete_table主要执行deletetable的行为,cs_create_database主要执行docreatedatabase的行为,cs_drop_database主要执行dropdatabase的行为,cs_use_database主要执行usedatabase的行为,cs_show_database主要执行showdatabase的行为。7.该数据加密主要指在存储引擎层面的加密,包含二层数据加密。8.第一层加密是指,将sql请求中的创建数据库和表格的名称进行加密,即将其进行名称到数字的转化,我们使用哈希表来存储该对应关系,举个例子,我们需要创建名称为school的数据库,在该数据库中创建名称为students,driver的表格,我们先建立一个数据库名称的对面关系表格,里面主要是数据库名称的对应关系,比如map[‘school’]=1,将school对应到1,我们将其保存下来,称之为config.dat,同时对于该数据库,我们生成哈希表,用于存储该数据库中表格名称的对应关系,比如,map[‘students’]=1,map[‘driver’]=2,我们将其保存下来,命名为set1.dat。这样,我们形成了表格名称的对应关系,students对应到1,driver对应到2,这样,我们有了第一层的加密,将数据库名称和表格名称转化成数字。我们将对应表格的数据文件保存为数据库序列+表格序列的形式,比如,该例子中school数据库中students表格中的数据信息,保存形式为set1_dat_1_data.dat,其中set1代表school数据库,dat_1代表students表格。对于时间表格,我们支持按一定时间间隔进行存储,比如,按天进行分段存储,我们有一个hashmap,该哈希表存储不同的时间戳及其对应的序列,比如map[‘2021-02-01’]=1,map[‘2021-02-02’]=2,代表这两个时间段的数据分别存在不同的数据中,比如,该例子中school数据库中students表格中2021-02-01时间段的数据信息,保存形式为set1_dat_1_1_data.dat,其中set1代表school数据库,dat_1代表students表格,dat_1_1代表2021-02-01这天的数据。[0009]第二层加密是指,将存储的数据文本进行加密,当我们创建了数据库,生成了表格的数据文件,数据文件分为类型文件和数据文件,我们对这两类文件都进行加密,使之明文不可见。具体的加密算法可以有不同的算法,只要使之明文不可见就行了。举个例子,我们将所有的数据文件进行按字母读取,然后对每个读取的字节加1,这样,然后生成新的数据文件,新的数据文件明文看不懂,旧的数据文件删除,从而达到数据文件保密的目的。[0010]有了加密,也有对应的解密过程,对于第一层的加密,当服务器有需要读取相关数据库的数据或者相关数据表格的数据的读取修改的需求时,服务器先调用相关的哈希表,通过输入相关的数据库的名称和表格的名称,来找到相对应的数字,从而读取到相应的数据文件,比如,服务器要查找school里面所有的表格名称,先从config.dat中读取整个哈希表,输入school的名称,得到1,这样服务器就能知道去set1.dat查找相关的信息,类似的,如果要找students中的相关信息,则先从set1.dat中读取整个哈希表,输入students的名称,得到1,这样,服务器就知道去set1_dat_1_data.dat中读取相关的数据,然后对其进行操作,比如读取,删除等。如果要都时间戳中的数据,从set1_dat_1.dat中读取哈希表,得到相关的时间戳,比如2020-02-01是时间戳为1,服务器就知道去set1_dat_1_1_data.dat中读取相应的数据。[0011]该列式sql数据库主要说明数据存储查询的方法,相对于行式样存储,本系统是列式,比如,行式数据存储为,第一行,“1,tom1,”,第二行,”2,tom2”等。在列式存储中为第一行,”1,2”,第二行,“tom1,tom2”,相对应的,在读取的时候,会根据情况进行变化,列式的在读取完一行之后,根据sql查找信息,找到相关信息,比如第一行的第二个,等等。当前第1页12当前第1页12