join.py 16.7 KB
Newer Older
C
cpwu 已提交
1 2 3 4 5 6 7
import datetime

from util.log import *
from util.sql import *
from util.cases import *
from util.dnodes import *

C
cpwu 已提交
8
PRIMARY_COL = "ts"
C
cpwu 已提交
9 10 11 12 13 14 15 16 17 18 19 20 21

INT_COL     = "c1"
BINT_COL    = "c2"
SINT_COL    = "c3"
TINT_COL    = "c4"
FLOAT_COL   = "c5"
DOUBLE_COL  = "c6"
BOOL_COL    = "c7"

BINARY_COL  = "c8"
NCHAR_COL   = "c9"
TS_COL      = "c10"

C
cpwu 已提交
22
NUM_COL     = [ INT_COL, BINT_COL, SINT_COL, TINT_COL, FLOAT_COL, DOUBLE_COL, ]
C
cpwu 已提交
23
CHAR_COL    = [ BINARY_COL, NCHAR_COL, ]
C
cpwu 已提交
24 25
BOOLEAN_COL = [ BOOL_COL, ]
TS_TYPE_COL = [ TS_COL, ]
C
cpwu 已提交
26 27 28 29 30

class TDTestCase:

    def init(self, conn, logSql):
        tdLog.debug(f"start to excute {__file__}")
C
cpwu 已提交
31
        tdSql.init(conn.cursor(), False)
C
cpwu 已提交
32

C
cpwu 已提交
33 34
    def __query_condition(self,tbname):
        query_condition = []
C
cpwu 已提交
35
        for char_col in CHAR_COL:
C
cpwu 已提交
36
            query_condition.extend(
C
cpwu 已提交
37
                (
C
cpwu 已提交
38
                    f"{tbname}.{char_col}",
C
cpwu 已提交
39
                    # f"upper( {tbname}.{char_col} )",
C
cpwu 已提交
40 41
                )
            )
C
cpwu 已提交
42 43 44 45
            query_condition.extend( f"cast( {tbname}.{un_char_col} as binary(16) ) " for un_char_col in NUM_COL)
        for num_col in NUM_COL:
            query_condition.extend(
                (
C
cpwu 已提交
46
                    f"sin( {tbname}.{num_col} )",
C
cpwu 已提交
47 48 49 50
                )
            )
            query_condition.extend( f"{tbname}.{num_col} + {tbname}.{num_col_1} " for num_col_1 in NUM_COL )

C
cpwu 已提交
51
        query_condition.append(''' "test1234!@#$%^&*():'><?/.,][}{" ''')
C
cpwu 已提交
52 53 54

        return query_condition

C
cpwu 已提交
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
    def __join_condition(self, tb_list, filter=PRIMARY_COL, INNER=False):
        table_reference = tb_list[0]
        join_condition = table_reference
        join = "inner join" if INNER else "join"
        for i in range(len(tb_list[1:])):
            join_condition += f" {join} {tb_list[i+1]} on {table_reference}.{filter}={tb_list[i+1]}.{filter}"

        return join_condition

    def __where_condition(self, col=None, tbname=None, query_conditon=None):
        if query_conditon and isinstance(query_conditon, str):
            if query_conditon.startswith("count"):
                query_conditon = query_conditon[6:-1]
            elif query_conditon.startswith("max"):
                query_conditon = query_conditon[4:-1]
            elif query_conditon.startswith("sum"):
                query_conditon = query_conditon[4:-1]
            elif query_conditon.startswith("min"):
                query_conditon = query_conditon[4:-1]

        if query_conditon:
            return f" where {query_conditon} is not null"
C
cpwu 已提交
77
        if col in NUM_COL:
C
cpwu 已提交
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
            return f" where abs( {tbname}.{col} ) >= 0"
        if col in CHAR_COL:
            return f" where lower( {tbname}.{col} ) like 'bina%' or lower( {tbname}.{col} ) like '_cha%' "
        if col in BOOLEAN_COL:
            return f" where {tbname}.{col} in (false, true)  "
        if col in TS_TYPE_COL or col in PRIMARY_COL:
            return f" where cast( {tbname}.{col} as binary(16) ) is not null "

        return ""

    def __group_condition(self, col, having = None):
        if isinstance(col, str):
            if col.startswith("count"):
                col = col[6:-1]
            elif col.startswith("max"):
                col = col[4:-1]
            elif col.startswith("sum"):
                col = col[4:-1]
            elif col.startswith("min"):
                col = col[4:-1]
C
cpwu 已提交
98
        return f" group by {col} having {having}" if having else f" group by {col} "
C
cpwu 已提交
99

C
cpwu 已提交
100 101 102 103 104 105 106 107
    def __gen_sql(self, select_clause, from_clause, where_condition="", group_condition=""):
        if isinstance(select_clause, str) and "on" not in from_clause and select_clause.split(".")[0] != from_clause.split(".")[0]:
            return
        return f"select {select_clause} from {from_clause} {where_condition} {group_condition}"

    @property
    def __join_tblist(self):
        return [
C
cpwu 已提交
108
            # ["ct1", "ct2"],
C
cpwu 已提交
109 110
            ["ct1", "ct4"],
            ["ct1", "t1"],
C
cpwu 已提交
111
            # ["ct2", "ct4"],
C
cpwu 已提交
112
            # ["ct2", "t1"],
C
cpwu 已提交
113
            # ["ct4", "t1"],
C
cpwu 已提交
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133
            # ["ct1", "ct2", "ct4"],
            # ["ct1", "ct2", "t1"],
            # ["ct1", "ct4", "t1"],
            # ["ct2", "ct4", "t1"],
            # ["ct1", "ct2", "ct4", "t1"],
        ]

    @property
    def __sqls_list(self):
        sqls = []
        __join_tblist = self.__join_tblist
        for join_tblist in __join_tblist:
            for join_tb in join_tblist:
                select_claus_list = self.__query_condition(join_tb)
                for select_claus in select_claus_list:
                    group_claus = self.__group_condition( col=select_claus)
                    where_claus = self.__where_condition( query_conditon=select_claus )
                    having_claus = self.__group_condition( col=select_claus, having=f"{select_claus} is not null" )
                    sqls.extend(
                        (
C
cpwu 已提交
134
                            # self.__gen_sql(select_claus, self.__join_condition(join_tblist), where_claus, group_claus),
C
cpwu 已提交
135 136
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist), where_claus, having_claus),
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist), where_claus),
C
cpwu 已提交
137
                            # self.__gen_sql(select_claus, self.__join_condition(join_tblist), group_claus),
C
cpwu 已提交
138 139
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist), having_claus),
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist)),
C
cpwu 已提交
140
                            # self.__gen_sql(select_claus, self.__join_condition(join_tblist, INNER=True), where_claus, group_claus),
C
cpwu 已提交
141 142 143
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist, INNER=True), where_claus, having_claus),
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist, INNER=True), where_claus, ),
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist, INNER=True), having_claus ),
C
cpwu 已提交
144 145
                            # self.__gen_sql(select_claus, self.__join_condition(join_tblist, INNER=True), group_claus ),
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist, INNER=True) ),
C
cpwu 已提交
146 147
                        )
                    )
C
cpwu 已提交
148
        return list(filter(None, sqls))
C
cpwu 已提交
149 150

    def __join_check(self,):
C
cpwu 已提交
151
        tdLog.printNoPrefix("==========current sql condition check , must return query ok==========")
C
cpwu 已提交
152 153
        for i in range(len(self.__sqls_list)):
            tdSql.query(self.__sqls_list[i])
C
cpwu 已提交
154 155
            # if i % 10 == 0 :
            #     tdLog.success(f"{i} sql is already executed success !")
C
cpwu 已提交
156 157

    def __join_check_old(self, tblist, checkrows, join_flag=True):
C
cpwu 已提交
158 159 160 161
        query_conditions = self.__query_condition(tblist[0])
        join_condition = self.__join_condition(tb_list=tblist) if join_flag else " "
        for condition in query_conditions:
            where_condition =  self.__where_condition(col=condition, tbname=tblist[0])
C
cpwu 已提交
162 163
            group_having = self.__group_condition(col=condition, having=f"{condition} is not null " )
            group_no_having= self.__group_condition(col=condition )
C
cpwu 已提交
164 165
            groups = ["", group_having, group_no_having]
            for group_condition in groups:
C
cpwu 已提交
166 167 168 169 170
                if where_condition:
                    sql = f" select {condition} from {tblist[0]},{tblist[1]} where {join_condition} and {where_condition} {group_condition} "
                else:
                    sql = f" select {condition} from {tblist[0]},{tblist[1]} where {join_condition}  {group_condition} "

C
cpwu 已提交
171 172
                if not join_flag :
                    tdSql.error(sql=sql)
C
cpwu 已提交
173
                    break
C
cpwu 已提交
174
                if len(tblist) == 2:
C
cpwu 已提交
175 176
                    if "ct1" in tblist or "t1" in tblist:
                        self.__join_current(sql, checkrows)
C
cpwu 已提交
177
                    elif where_condition or "not null" in group_condition:
C
cpwu 已提交
178
                        self.__join_current(sql, checkrows + 2 )
C
cpwu 已提交
179 180
                    elif group_condition:
                        self.__join_current(sql, checkrows + 3 )
C
cpwu 已提交
181 182
                    else:
                        self.__join_current(sql, checkrows + 5 )
C
cpwu 已提交
183
                if len(tblist) > 2 or len(tblist) < 1:
C
cpwu 已提交
184
                    tdSql.error(sql=sql)
C
cpwu 已提交
185

C
cpwu 已提交
186 187
    def __join_current(self, sql, checkrows):
        tdSql.query(sql=sql)
C
cpwu 已提交
188
        # tdSql.checkRows(checkrows)
C
cpwu 已提交
189

C
cpwu 已提交
190
    def __test_error(self):
C
cpwu 已提交
191
        # sourcery skip: extract-duplicate-method, move-assign-in-block
C
cpwu 已提交
192
        tdLog.printNoPrefix("==========err sql condition check , must return error==========")
C
cpwu 已提交
193 194 195 196 197
        err_list_1 = ["ct1","ct2", "ct4"]
        err_list_2 = ["ct1","ct2", "t1"]
        err_list_3 = ["ct1","ct4", "t1"]
        err_list_4 = ["ct2","ct4", "t1"]
        err_list_5 = ["ct1", "ct2","ct4", "t1"]
C
cpwu 已提交
198
        self.__join_check_old(err_list_1, -1)
C
cpwu 已提交
199
        tdLog.printNoPrefix(f"==========err sql condition check in {err_list_1} over==========")
C
cpwu 已提交
200
        self.__join_check_old(err_list_2, -1)
C
cpwu 已提交
201
        tdLog.printNoPrefix(f"==========err sql condition check in {err_list_2} over==========")
C
cpwu 已提交
202
        self.__join_check_old(err_list_3, -1)
C
cpwu 已提交
203
        tdLog.printNoPrefix(f"==========err sql condition check in {err_list_3} over==========")
C
cpwu 已提交
204
        self.__join_check_old(err_list_4, -1)
C
cpwu 已提交
205
        tdLog.printNoPrefix(f"==========err sql condition check in {err_list_4} over==========")
C
cpwu 已提交
206
        self.__join_check_old(err_list_5, -1)
C
cpwu 已提交
207
        tdLog.printNoPrefix(f"==========err sql condition check in {err_list_5} over==========")
C
cpwu 已提交
208
        self.__join_check_old(["ct2", "ct4"], -1, join_flag=False)
C
cpwu 已提交
209 210 211 212 213 214 215 216 217 218
        tdLog.printNoPrefix("==========err sql condition check in has no join condition over==========")

        tdSql.error( f"select c1, c2 from ct2, ct4 where ct2.{PRIMARY_COL}=ct4.{PRIMARY_COL}" )
        tdSql.error( f"select ct2.c1, ct2.c2 from ct2, ct4 where ct2.{INT_COL}=ct4.{INT_COL}" )
        tdSql.error( f"select ct2.c1, ct2.c2 from ct2, ct4 where ct2.{TS_COL}=ct4.{TS_COL}" )
        tdSql.error( f"select ct2.c1, ct2.c2 from ct2, ct4 where ct2.{PRIMARY_COL}=ct4.{TS_COL}" )
        tdSql.error( f"select ct2.c1, ct1.c2 from ct2, ct4 where ct2.{PRIMARY_COL}=ct4.{PRIMARY_COL}" )
        tdSql.error( f"select ct2.c1, ct4.c2 from ct2, ct4 where ct2.{PRIMARY_COL}=ct4.{PRIMARY_COL} and c1 is not null " )
        tdSql.error( f"select ct2.c1, ct4.c2 from ct2, ct4 where ct2.{PRIMARY_COL}=ct4.{PRIMARY_COL} and ct1.c1 is not null " )

C
cpwu 已提交
219

C
cpwu 已提交
220 221
        tbname = ["ct1", "ct2", "ct4", "t1"]

C
cpwu 已提交
222 223 224 225
        # for tb in tbname:
        #     for errsql in self.__join_err_check(tb):
        #         tdSql.error(sql=errsql)
        #     tdLog.printNoPrefix(f"==========err sql condition check in {tb} over==========")
C
cpwu 已提交
226 227 228


    def all_test(self):
C
cpwu 已提交
229
        self.__join_check()
C
cpwu 已提交
230 231 232 233 234 235 236 237 238 239 240
        self.__test_error()


    def __create_tb(self):
        tdSql.prepare()

        tdLog.printNoPrefix("==========step1:create table")
        create_stb_sql  =  f'''create table stb1(
                ts timestamp, {INT_COL} int, {BINT_COL} bigint, {SINT_COL} smallint, {TINT_COL} tinyint,
                 {FLOAT_COL} float, {DOUBLE_COL} double, {BOOL_COL} bool,
                 {BINARY_COL} binary(16), {NCHAR_COL} nchar(32), {TS_COL} timestamp
C
cpwu 已提交
241
            ) tags (tag1 int)
C
cpwu 已提交
242 243 244 245 246 247 248 249 250 251 252 253
            '''
        create_ntb_sql = f'''create table t1(
                ts timestamp, {INT_COL} int, {BINT_COL} bigint, {SINT_COL} smallint, {TINT_COL} tinyint,
                 {FLOAT_COL} float, {DOUBLE_COL} double, {BOOL_COL} bool,
                 {BINARY_COL} binary(16), {NCHAR_COL} nchar(32), {TS_COL} timestamp
            )
            '''
        tdSql.execute(create_stb_sql)
        tdSql.execute(create_ntb_sql)

        for i in range(4):
            tdSql.execute(f'create table ct{i+1} using stb1 tags ( {i+1} )')
C
cpwu 已提交
254
            { i % 32767 }, { i % 127}, { i * 1.11111 }, { i * 1000.1111 }, { i % 2}
C
cpwu 已提交
255 256

    def __insert_data(self, rows):
C
cpwu 已提交
257
        now_time = int(datetime.datetime.timestamp(datetime.datetime.now()) * 1000)
C
cpwu 已提交
258 259
        for i in range(rows):
            tdSql.execute(
C
cpwu 已提交
260
                f"insert into ct1 values ( { now_time - i * 1000 }, {i}, {11111 * i}, {111 * i % 32767 }, {11 * i % 127}, {1.11*i}, {1100.0011*i}, {i%2}, 'binary{i}', 'nchar_测试_{i}', { now_time + 1 * i } )"
C
cpwu 已提交
261 262
            )
            tdSql.execute(
C
cpwu 已提交
263
                f"insert into ct4 values ( { now_time - i * 7776000000 }, {i}, {11111 * i}, {111 * i % 32767 }, {11 * i % 127}, {1.11*i}, {1100.0011*i}, {i%2}, 'binary{i}', 'nchar_测试_{i}', { now_time + 1 * i } )"
C
cpwu 已提交
264 265
            )
            tdSql.execute(
C
cpwu 已提交
266
                f"insert into ct2 values ( { now_time - i * 7776000000 }, {-i},  {-11111 * i}, {-111 * i % 32767 }, {-11 * i % 127}, {-1.11*i}, {-1100.0011*i}, {i%2}, 'binary{i}', 'nchar_测试_{i}', { now_time + 1 * i } )"
C
cpwu 已提交
267 268 269
            )
        tdSql.execute(
            f'''insert into ct1 values
C
cpwu 已提交
270 271
            ( { now_time - rows * 5 }, 0, 0, 0, 0, 0, 0, 0, 'binary0', 'nchar_测试_0', { now_time + 8 } )
            ( { now_time + 10000 }, { rows }, -99999, -999, -99, -9.99, -99.99, 1, 'binary9', 'nchar_测试_9', { now_time + 9 } )
C
cpwu 已提交
272 273 274 275 276 277
            '''
        )

        tdSql.execute(
            f'''insert into ct4 values
            ( { now_time - rows * 7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
278
            ( { now_time - rows * 3888000000 + 10800000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
279 280 281
            ( { now_time +  7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
            (
                { now_time + 5184000000}, {pow(2,31)-pow(2,15)}, {pow(2,63)-pow(2,30)}, 32767, 127,
C
cpwu 已提交
282
                { 3.3 * pow(10,38) }, { 1.3 * pow(10,308) }, { rows % 2 }, "binary_limit-1", "nchar_测试_limit-1", { now_time - 86400000}
C
cpwu 已提交
283 284 285
                )
            (
                { now_time + 2592000000 }, {pow(2,31)-pow(2,16)}, {pow(2,63)-pow(2,31)}, 32766, 126,
C
cpwu 已提交
286
                { 3.2 * pow(10,38) }, { 1.2 * pow(10,308) }, { (rows-1) % 2 }, "binary_limit-2", "nchar_测试_limit-2", { now_time - 172800000}
C
cpwu 已提交
287 288 289 290 291 292 293
                )
            '''
        )

        tdSql.execute(
            f'''insert into ct2 values
            ( { now_time - rows * 7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
294
            ( { now_time - rows * 3888000000 + 10800000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
295
            ( { now_time + 7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
296 297
            (
                { now_time + 5184000000 }, { -1 * pow(2,31) + pow(2,15) }, { -1 * pow(2,63) + pow(2,30) }, -32766, -126,
C
cpwu 已提交
298
                { -1 * 3.2 * pow(10,38) }, { -1.2 * pow(10,308) }, { rows % 2 }, "binary_limit-1", "nchar_测试_limit-1", { now_time - 86400000 }
C
cpwu 已提交
299 300 301
                )
            (
                { now_time + 2592000000 }, { -1 * pow(2,31) + pow(2,16) }, { -1 * pow(2,63) + pow(2,31) }, -32767, -127,
C
cpwu 已提交
302
                { - 3.3 * pow(10,38) }, { -1.3 * pow(10,308) }, { (rows-1) % 2 }, "binary_limit-2", "nchar_测试_limit-2", { now_time - 172800000 }
C
cpwu 已提交
303 304 305 306 307 308
                )
            '''
        )

        for i in range(rows):
            insert_data = f'''insert into t1 values
C
cpwu 已提交
309
                ( { now_time - i * 3600000 }, {i}, {i * 11111}, { i % 32767 }, { i % 127}, { i * 1.11111 }, { i * 1000.1111 }, { i % 2},
C
cpwu 已提交
310
                "binary_{i}", "nchar_测试_{i}", { now_time - 1000 * i } )
C
cpwu 已提交
311 312 313 314 315
                '''
            tdSql.execute(insert_data)
        tdSql.execute(
            f'''insert into t1 values
            ( { now_time + 10800000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
316
            ( { now_time - (( rows // 2 ) * 60 + 30) * 60000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
317 318 319
            ( { now_time - rows * 3600000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
            ( { now_time + 7200000 }, { pow(2,31) - pow(2,15) }, { pow(2,63) - pow(2,30) }, 32767, 127,
                { 3.3 * pow(10,38) }, { 1.3 * pow(10,308) }, { rows % 2 },
C
cpwu 已提交
320
                "binary_limit-1", "nchar_测试_limit-1", { now_time - 86400000 }
C
cpwu 已提交
321 322 323 324
                )
            (
                { now_time + 3600000 } , { pow(2,31) - pow(2,16) }, { pow(2,63) - pow(2,31) }, 32766, 126,
                { 3.2 * pow(10,38) }, { 1.2 * pow(10,308) }, { (rows-1) % 2 },
C
cpwu 已提交
325
                "binary_limit-2", "nchar_测试_limit-2", { now_time - 172800000 }
C
cpwu 已提交
326 327 328 329 330 331 332 333 334 335 336 337
                )
            '''
        )


    def run(self):
        tdSql.prepare()

        tdLog.printNoPrefix("==========step1:create table")
        self.__create_tb()

        tdLog.printNoPrefix("==========step2:insert data")
C
cpwu 已提交
338 339
        self.rows = 10
        self.__insert_data(self.rows)
C
cpwu 已提交
340 341 342 343

        tdLog.printNoPrefix("==========step3:all check")
        self.all_test()

C
cpwu 已提交
344 345
        tdDnodes.stop(1)
        tdDnodes.start(1)
C
cpwu 已提交
346

C
cpwu 已提交
347
        tdSql.execute("use db")
C
cpwu 已提交
348

C
cpwu 已提交
349 350
        tdLog.printNoPrefix("==========step4:after wal, all check again ")
        self.all_test()
C
cpwu 已提交
351 352 353 354 355 356 357

    def stop(self):
        tdSql.close()
        tdLog.success(f"{__file__} successfully executed")

tdCases.addLinux(__file__, TDTestCase())
tdCases.addWindows(__file__, TDTestCase())