test: add case tag index passed ok
This commit is contained in:
parent
4dff7f9763
commit
b4d84f1e5e
|
@ -27,36 +27,36 @@ class TDTestCase:
|
||||||
tdSql.init(conn.cursor())
|
tdSql.init(conn.cursor())
|
||||||
self.setsql = TDSetSql()
|
self.setsql = TDSetSql()
|
||||||
self.column_dict = {
|
self.column_dict = {
|
||||||
'`ts`': 'timestamp',
|
'ts': 'timestamp',
|
||||||
'`col1`': 'tinyint',
|
'col1': 'tinyint',
|
||||||
'`col2`': 'smallint',
|
'col2': 'smallint',
|
||||||
'`col3`': 'int',
|
'col3': 'int',
|
||||||
'`col4`': 'bigint',
|
'col4': 'bigint',
|
||||||
'`col5`': 'tinyint unsigned',
|
'col5': 'tinyint unsigned',
|
||||||
'`col6`': 'smallint unsigned',
|
'col6': 'smallint unsigned',
|
||||||
'`col7`': 'int unsigned',
|
'col7': 'int unsigned',
|
||||||
'`col8`': 'bigint unsigned',
|
'col8': 'bigint unsigned',
|
||||||
'`col9`': 'float',
|
'col9': 'float',
|
||||||
'`col10`': 'double',
|
'col10': 'double',
|
||||||
'`col11`': 'bool',
|
'col11': 'bool',
|
||||||
'`col12`': 'varchar(20)',
|
'col12': 'varchar(20)',
|
||||||
'`col13`': 'nchar(20)'
|
'col13': 'nchar(20)'
|
||||||
}
|
}
|
||||||
self.tag_dict = {
|
self.tag_dict = {
|
||||||
'`t1`': 'tinyint',
|
't1': 'tinyint',
|
||||||
'`t2`': 'smallint',
|
't2': 'smallint',
|
||||||
'`t3`': 'int',
|
't3': 'int',
|
||||||
'`t4`': 'bigint',
|
't4': 'bigint',
|
||||||
'`t5`': 'tinyint unsigned',
|
't5': 'tinyint unsigned',
|
||||||
'`t6`': 'smallint unsigned',
|
't6': 'smallint unsigned',
|
||||||
'`t7`': 'int unsigned',
|
't7': 'int unsigned',
|
||||||
'`t8`': 'bigint unsigned',
|
't8': 'bigint unsigned',
|
||||||
'`t9`': 'float',
|
't9': 'float',
|
||||||
'`t10`': 'double',
|
't10': 'double',
|
||||||
'`t11`': 'bool',
|
't11': 'bool',
|
||||||
'`t12`': 'varchar(20)',
|
't12': 'varchar(20)',
|
||||||
'`t13`': 'nchar(20)',
|
't13': 'nchar(20)',
|
||||||
'`t14`': 'timestamp'
|
't14': 'timestamp'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -85,58 +85,108 @@ class TDTestCase:
|
||||||
tags = f'{ti},{ti},{i},{i},{ti},{ti},{i},{i},{i}.000{i},{i}.000{i},true,"var{i}","nch{i}",now'
|
tags = f'{ti},{ti},{i},{i},{ti},{ti},{i},{i},{i}.000{i},{i}.000{i},true,"var{i}","nch{i}",now'
|
||||||
sql = f'create table {tbname}{i} using {stbname} tags({tags})'
|
sql = f'create table {tbname}{i} using {stbname} tags({tags})'
|
||||||
tdSql.execute(sql)
|
tdSql.execute(sql)
|
||||||
|
|
||||||
|
tdLog.info(f" create {count} child tables ok.")
|
||||||
|
|
||||||
|
|
||||||
# create stable and child tables
|
# create stable and child tables
|
||||||
def create_tagidx(self, stbname):
|
def create_tagidx(self, stbname):
|
||||||
for key in self.tag_dict.keys:
|
cnt = -1
|
||||||
sql = f'create idx_{key} on {stbname} ({key})'
|
for key in self.tag_dict.keys():
|
||||||
|
# first tag have default index, so skip
|
||||||
|
if cnt == -1:
|
||||||
|
cnt = 0
|
||||||
|
continue;
|
||||||
|
sql = f'create index idx_{key} on {stbname} ({key})'
|
||||||
|
tdLog.info(f" sql={sql}")
|
||||||
|
tdSql.execute(sql)
|
||||||
|
cnt += 1
|
||||||
|
tdLog.info(f' create {cnt} tag indexs ok.')
|
||||||
|
|
||||||
|
# insert to child table d1 data
|
||||||
|
def insert_data(self, tbname):
|
||||||
|
# d1 insert 3 rows
|
||||||
|
for i in range(3):
|
||||||
|
sql = f'insert into {tbname}1(ts,col1) values(now,{i});'
|
||||||
|
tdSql.execute(sql)
|
||||||
|
# d20 insert 4
|
||||||
|
for i in range(4):
|
||||||
|
sql = f'insert into {tbname}20(ts,col1) values(now,{i});'
|
||||||
tdSql.execute(sql)
|
tdSql.execute(sql)
|
||||||
|
|
||||||
# check show indexs
|
# check show indexs
|
||||||
def show_tagidx(self, stbname):
|
def show_tagidx(self, stbname):
|
||||||
sql = f'select index_name,column_name from information_schema.ins_indexes where db_name="db"'
|
sql = f'select index_name,column_name from information_schema.ins_indexes where db_name="db"'
|
||||||
tdSql.execute(sql)
|
tdSql.query(sql)
|
||||||
i = 0
|
rows = len(self.tag_dict.keys())-1
|
||||||
for key in self.tag_dict.keys:
|
tdSql.checkRows(rows)
|
||||||
tdSql.checkData(i, 0, f'idx_{key}')
|
|
||||||
tdSql.checkData(i, 1, f'{key}')
|
for i in range(rows):
|
||||||
i += 1
|
col_name = tdSql.getData(i, 1)
|
||||||
|
idx_name = f'idx_{col_name}'
|
||||||
|
tdSql.checkData(i, 0, idx_name)
|
||||||
|
|
||||||
|
tdLog.info(f' show {rows} tag indexs ok.')
|
||||||
|
|
||||||
# query with tag idx
|
# query with tag idx
|
||||||
def query_tagidx(self, stbname):
|
def query_tagidx(self, stbname):
|
||||||
sql = f'select * from meters where t1=10'
|
sql = f'select * from meters where t1=1'
|
||||||
tdSql.execute(sql)
|
tdSql.query(sql)
|
||||||
|
tdSql.checkRows(3)
|
||||||
|
|
||||||
sql = f'select * from meters where t2<10'
|
sql = f'select * from meters where t2<10'
|
||||||
tdSql.execute(sql)
|
tdSql.query(sql)
|
||||||
sql = f'select * from meters where t3>10'
|
tdSql.checkRows(3)
|
||||||
tdSql.execute(sql)
|
|
||||||
|
sql = f'select * from meters where t2>10'
|
||||||
|
tdSql.query(sql)
|
||||||
|
tdSql.checkRows(4)
|
||||||
|
|
||||||
|
sql = f'select * from meters where t3<30'
|
||||||
|
tdSql.query(sql)
|
||||||
|
tdSql.checkRows(7)
|
||||||
|
|
||||||
sql = f'select * from meters where t12="11"'
|
sql = f'select * from meters where t12="11"'
|
||||||
tdSql.execute(sql)
|
tdSql.query(sql)
|
||||||
|
tdSql.checkRows(0)
|
||||||
|
|
||||||
sql = f'select * from meters where (t4 < 10 or t5 = 20) and t6= 30'
|
sql = f'select * from meters where (t4 < 10 or t5 = 20) and t6= 30'
|
||||||
tdSql.execute(sql)
|
tdSql.query(sql)
|
||||||
sql = f'select * from meters where (t7 < 20 and t8 = 20) or t9= 30'
|
tdSql.checkRows(0)
|
||||||
tdSql.execute(sql)
|
|
||||||
|
sql = f'select * from meters where (t7 < 20 and t8 = 20) or t4 = 20'
|
||||||
|
tdSql.query(sql)
|
||||||
|
tdSql.checkRows(4)
|
||||||
|
|
||||||
# drop child table
|
# drop child table
|
||||||
def drop_tables(self, tbname, count):
|
def drop_tables(self, tbname, count):
|
||||||
start = random.randint(1, count/2)
|
# table d1 and d20 have verify data , so can not drop
|
||||||
end = random.random(count/2 + 1, count - 1)
|
start = random.randint(21, count/2)
|
||||||
|
end = random.randint(count/2 + 1, count - 1)
|
||||||
for i in range(start, end):
|
for i in range(start, end):
|
||||||
sql = f'drop table {tbname}{i}'
|
sql = f'drop table {tbname}{i}'
|
||||||
tdSql.execute(sql)
|
tdSql.execute(sql)
|
||||||
|
cnt = end - start + 1
|
||||||
|
tdLog.info(f' drop table from {start} to {end} count={cnt}')
|
||||||
|
|
||||||
# drop tag index
|
# drop tag index
|
||||||
def drop_tagidx(self, stbname):
|
def drop_tagidx(self, stbname):
|
||||||
# drop index
|
# drop index
|
||||||
for key in self.tag_dict.keys:
|
cnt = -1
|
||||||
|
for key in self.tag_dict.keys():
|
||||||
|
# first tag have default index, so skip
|
||||||
|
if cnt == -1:
|
||||||
|
cnt = 0
|
||||||
|
continue;
|
||||||
sql = f'drop index idx_{key}'
|
sql = f'drop index idx_{key}'
|
||||||
tdSql.execute(sql)
|
tdSql.execute(sql)
|
||||||
|
cnt += 1
|
||||||
|
|
||||||
# check idx result is 0
|
# check idx result is 0
|
||||||
sql = f'select index_name,column_name from information_schema.ins_indexes where db_name="db"'
|
sql = f'select index_name,column_name from information_schema.ins_indexes where db_name="db"'
|
||||||
tdSql.execute(sql)
|
tdSql.query(sql)
|
||||||
tdSql.checkRows(0)
|
tdSql.checkRows(0)
|
||||||
|
tdLog.info(f' drop {cnt} tag indexs ok.')
|
||||||
|
|
||||||
# run
|
# run
|
||||||
def run(self):
|
def run(self):
|
||||||
|
@ -145,6 +195,7 @@ class TDTestCase:
|
||||||
count = 1000
|
count = 1000
|
||||||
self.create_table(stable, tbname, count)
|
self.create_table(stable, tbname, count)
|
||||||
self.create_tagidx(stable)
|
self.create_tagidx(stable)
|
||||||
|
self.insert_data(tbname)
|
||||||
self.show_tagidx(stable)
|
self.show_tagidx(stable)
|
||||||
self.query_tagidx(stable)
|
self.query_tagidx(stable)
|
||||||
self.drop_tables(tbname, count)
|
self.drop_tables(tbname, count)
|
||||||
|
|
Loading…
Reference in New Issue