join.py 16.8 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__}")
31
        tdSql.init(conn.cursor(), True)
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 46 47 48 49 50 51
            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(
                (
                    f"{tbname}.{num_col}",
                    f"sin( {tbname}.{num_col} )"
                )
            )
            query_condition.extend( f"{tbname}.{num_col} + {tbname}.{num_col_1} " for num_col_1 in NUM_COL )

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

        return query_condition

C
cpwu 已提交
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
    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 已提交
78
        if col in NUM_COL:
C
cpwu 已提交
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
            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 已提交
99
        return f" group by {col} having {having}" if having else f" group by {col} "
C
cpwu 已提交
100

C
cpwu 已提交
101 102 103 104 105 106 107 108
    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 已提交
109
            # ["ct1", "ct2"],
C
cpwu 已提交
110 111 112
            ["ct1", "ct4"],
            ["ct1", "t1"],
            ["ct2", "ct4"],
C
cpwu 已提交
113
            # ["ct2", "t1"],
C
cpwu 已提交
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
            ["ct4", "t1"],
            # ["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 已提交
135
                            # self.__gen_sql(select_claus, self.__join_condition(join_tblist), where_claus, group_claus),
C
cpwu 已提交
136 137
                            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 已提交
138
                            # self.__gen_sql(select_claus, self.__join_condition(join_tblist), group_claus),
C
cpwu 已提交
139 140
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist), having_claus),
                            self.__gen_sql(select_claus, self.__join_condition(join_tblist)),
C
cpwu 已提交
141
                            # self.__gen_sql(select_claus, self.__join_condition(join_tblist, INNER=True), where_claus, group_claus),
C
cpwu 已提交
142 143 144
                            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 已提交
145 146
                            # 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 已提交
147 148
                        )
                    )
C
cpwu 已提交
149
        return list(filter(None, sqls))
C
cpwu 已提交
150 151

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

    def __join_check_old(self, tblist, checkrows, join_flag=True):
C
cpwu 已提交
159 160 161 162
        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 已提交
163 164
            group_having = self.__group_condition(col=condition, having=f"{condition} is not null " )
            group_no_having= self.__group_condition(col=condition )
C
cpwu 已提交
165 166
            groups = ["", group_having, group_no_having]
            for group_condition in groups:
C
cpwu 已提交
167 168 169 170 171
                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 已提交
172 173
                if not join_flag :
                    tdSql.error(sql=sql)
C
cpwu 已提交
174
                    break
C
cpwu 已提交
175
                if len(tblist) == 2:
C
cpwu 已提交
176 177
                    if "ct1" in tblist or "t1" in tblist:
                        self.__join_current(sql, checkrows)
C
cpwu 已提交
178
                    elif where_condition or "not null" in group_condition:
C
cpwu 已提交
179
                        self.__join_current(sql, checkrows + 2 )
C
cpwu 已提交
180 181
                    elif group_condition:
                        self.__join_current(sql, checkrows + 3 )
C
cpwu 已提交
182 183
                    else:
                        self.__join_current(sql, checkrows + 5 )
C
cpwu 已提交
184
                if len(tblist) > 2 or len(tblist) < 1:
C
cpwu 已提交
185
                    tdSql.error(sql=sql)
C
cpwu 已提交
186

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

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

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

C
cpwu 已提交
223 224 225 226
        # 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 已提交
227 228 229


    def all_test(self):
C
cpwu 已提交
230
        self.__join_check()
C
cpwu 已提交
231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254
        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
            ) tags (t1 int)
            '''
        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 已提交
255
            { i % 32767 }, { i % 127}, { i * 1.11111 }, { i * 1000.1111 }, { i % 2}
C
cpwu 已提交
256 257

    def __insert_data(self, rows):
C
cpwu 已提交
258
        now_time = int(datetime.datetime.timestamp(datetime.datetime.now()) * 1000)
C
cpwu 已提交
259 260
        for i in range(rows):
            tdSql.execute(
C
cpwu 已提交
261
                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 已提交
262 263
            )
            tdSql.execute(
C
cpwu 已提交
264
                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 已提交
265 266
            )
            tdSql.execute(
C
cpwu 已提交
267
                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 已提交
268 269 270
            )
        tdSql.execute(
            f'''insert into ct1 values
C
cpwu 已提交
271 272
            ( { 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 已提交
273 274 275 276 277 278
            '''
        )

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

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

        for i in range(rows):
            insert_data = f'''insert into t1 values
C
cpwu 已提交
310
                ( { now_time - i * 3600000 }, {i}, {i * 11111}, { i % 32767 }, { i % 127}, { i * 1.11111 }, { i * 1000.1111 }, { i % 2},
C
cpwu 已提交
311
                "binary_{i}", "nchar_测试_{i}", { now_time - 1000 * i } )
C
cpwu 已提交
312 313 314 315 316
                '''
            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 已提交
317
            ( { now_time - (( rows // 2 ) * 60 + 30) * 60000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
318 319 320
            ( { 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 已提交
321
                "binary_limit-1", "nchar_测试_limit-1", { now_time - 86400000 }
C
cpwu 已提交
322 323 324 325
                )
            (
                { 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 已提交
326
                "binary_limit-2", "nchar_测试_limit-2", { now_time - 172800000 }
C
cpwu 已提交
327 328 329 330 331 332 333 334 335 336 337 338
                )
            '''
        )


    def run(self):
        tdSql.prepare()

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

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

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

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

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

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

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

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