between.py 9.2 KB
Newer Older
C
cpwu 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
import taos
import sys

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



class TDTestCase:

    def init(self, conn, logSql):
        tdLog.debug(f"start to excute {__file__}")
        tdSql.init(conn.cursor())

    def run(self):  # sourcery skip: extract-duplicate-method
        tdSql.prepare()

        tdLog.printNoPrefix("==========step1:create table")
        tdSql.execute(
            '''create table if not exists supt
            (ts timestamp, c1 int, c2 float, c3 bigint, c4 double, c5 smallint, c6 tinyint)
            tags(location binary(64), type int, isused bool , family nchar(64))'''
        )
C
cpwu 已提交
25 26
        tdSql.execute("create table t1 using supt tags('beijing', 1, 1, 'nchar1')")
        tdSql.execute("create table t2 using supt tags('shanghai', 2, 0, 'nchar2')")
C
cpwu 已提交
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47

        tdLog.printNoPrefix("==========step2:insert data")
        for i in range(10):
            tdSql.execute(
                f"insert into t1 values (now()+{i}m, {32767+i}, {20.0+i/10}, {2**31+i}, {3.4*10**38+i/10}, {127+i}, {i})"
            )
            tdSql.execute(
                f"insert into t2 values (now()-{i}m, {-32767-i}, {20.0-i/10}, {-i-2**31}, {-i/10-3.4*10**38}, {-127-i}, {-i})"
            )
        tdSql.execute(
            f"insert into t1 values (now()+11m, {2**31-1}, {pow(10,37)*34}, {pow(2,63)-1}, {1.7*10**308}, 32767, 127)"
        )
        tdSql.execute(
            f"insert into t2 values (now()-11m, {1-2**31}, {-3.4*10**38}, {1-2**63}, {-1.7*10**308}, -32767, -127)"
        )
        tdSql.execute(
            f"insert into t2 values (now()-12m, null , {-3.4*10**38}, null , {-1.7*10**308}, null , null)"
        )

        tdLog.printNoPrefix("==========step3:query timestamp type")

C
cpwu 已提交
48 49 50 51 52 53 54 55 56 57
        tdSql.query("select * from t1 where ts between now()-1m and now()+10m")
        tdSql.checkRows(10)
        tdSql.query("select * from t1 where ts between '2021-01-01 00:00:00.000' and '2121-01-01 00:00:00.000'")
        tdSql.checkRows(11)
        tdSql.query("select * from t1 where ts between '1969-01-01 00:00:00.000' and '1969-12-31 23:59:59.999'")
        tdSql.checkRows(0)
        tdSql.query("select * from t1 where ts between -2793600 and 31507199")
        tdSql.checkRows(0)
        tdSql.query("select * from t1 where ts between 1609430400000 and 4765104000000")
        tdSql.checkRows(11)
C
cpwu 已提交
58 59 60 61 62 63 64 65 66

        tdLog.printNoPrefix("==========step4:query int type")

        tdSql.query("select * from t1 where c1 between 32767 and 32776")
        tdSql.checkRows(10)
        tdSql.query("select * from t1 where c1 between 32766.9 and 32776.1")
        tdSql.checkRows(10)
        tdSql.query("select * from t1 where c1 between 32776 and 32767")
        tdSql.checkRows(0)
C
cpwu 已提交
67 68
        tdSql.query("select * from t1 where c1 between 'a' and 'e'")
        tdSql.checkRows(0)
C
cpwu 已提交
69 70 71 72
        tdSql.query("select * from t1 where c1 between 0x64 and 0x69")
        tdSql.checkRows(6)
        tdSql.query("select * from t1 where c1 not between 100 and 106")
        tdSql.checkRows(11)
C
cpwu 已提交
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
        tdSql.query(f"select * from t1 where c1 between {2**31-2} and {2**31+1}")
        tdSql.checkRows(1)
        tdSql.error(f"select * from t2 where c1 between null and {1-2**31}")
        # tdSql.checkRows(3)
        tdSql.query(f"select * from t2 where c1 between {-2**31} and {1-2**31}")
        tdSql.checkRows(1)

        tdLog.printNoPrefix("==========step5:query float type")

        tdSql.query("select * from t1 where c2 between 20.0 and 21.0")
        tdSql.checkRows(10)
        tdSql.query(f"select * from t1 where c2 between {-3.4*10**38-1} and {3.4*10**38+1}")
        tdSql.checkRows(11)
        tdSql.query("select * from t1 where c2 between 21.0 and 20.0")
        tdSql.checkRows(0)
C
cpwu 已提交
88 89 90
        tdSql.query("select * from t1 where c2 between 'DC3' and 'SYN'")
        tdSql.checkRows(0)
        tdSql.query("select * from t1 where c2 not between 0.1 and 0.2")
C
cpwu 已提交
91
        tdSql.checkRows(11)
C
cpwu 已提交
92
        tdSql.query(f"select * from t1 where c2 between {pow(10,38)*3.4} and {pow(10,38)*3.4+1}")
C
cpwu 已提交
93
        tdSql.checkRows(1)
C
cpwu 已提交
94
        tdSql.query(f"select * from t2 where c2 between {-3.4*10**38-1} and {-3.4*10**38}")
C
cpwu 已提交
95
        tdSql.checkRows(2)
C
cpwu 已提交
96 97 98 99 100 101 102
        tdSql.error(f"select * from t2 where c2 between null and {-3.4*10**38}")
        # tdSql.checkRows(3)

        tdLog.printNoPrefix("==========step6:query bigint type")

        tdSql.query(f"select * from t1 where c3 between {2**31} and {2**31+10}")
        tdSql.checkRows(10)
C
cpwu 已提交
103
        tdSql.query(f"select * from t1 where c3 between {-2**63} and {2**63}")
C
cpwu 已提交
104
        tdSql.checkRows(11)
C
cpwu 已提交
105 106
        tdSql.query(f"select * from t1 where c3 between {2**31+10} and {2**31}")
        tdSql.checkRows(0)
C
cpwu 已提交
107 108 109
        tdSql.query("select * from t1 where c3 between 'a' and 'z'")
        tdSql.checkRows(0)
        tdSql.query("select * from t1 where c3 not between 1 and 2")
C
cpwu 已提交
110
        tdSql.checkRows(0)
C
cpwu 已提交
111 112
        tdSql.query(f"select * from t1 where c3 between {2**63-2} and {2**63-1}")
        tdSql.checkRows(1)
C
cpwu 已提交
113
        tdSql.query(f"select * from t2 where c3 between {-2**63} and {1-2**63}")
C
cpwu 已提交
114
        tdSql.checkRows(3)
C
cpwu 已提交
115 116 117 118 119 120 121 122 123 124 125 126
        tdSql.error(f"select * from t2 where c3 between null and {1-2**63}")
        # tdSql.checkRows(2)

        tdLog.printNoPrefix("==========step7:query double type")

        tdSql.query(f"select * from t1 where c4 between {3.4*10**38} and {3.4*10**38+10}")
        tdSql.checkRows(10)
        tdSql.query(f"select * from t1 where c4 between {1.7*10**308+1} and {1.7*10**308+2}")
        # 因为精度原因,在超出bigint边界后,数值不能进行准确的判断
        # tdSql.checkRows(0)
        tdSql.query(f"select * from t1 where c4 between {3.4*10**38+10} and {3.4*10**38}")
        # tdSql.checkRows(0)
C
cpwu 已提交
127 128 129
        tdSql.query("select * from t1 where c4 between 'a' and 'z'")
        tdSql.checkRows(0)
        tdSql.query("select * from t1 where c4 not between 1 and 2")
C
cpwu 已提交
130
        tdSql.checkRows(0)
C
cpwu 已提交
131
        tdSql.query(f"select * from t1 where c4 between {1.7*10**308} and {1.7*10**308+1}")
C
cpwu 已提交
132
        tdSql.checkRows(1)
C
cpwu 已提交
133
        tdSql.query(f"select * from t2 where c4 between {-1.7*10**308-1} and {-1.7*10**308}")
C
cpwu 已提交
134
        tdSql.checkRows(3)
C
cpwu 已提交
135 136 137 138 139 140 141 142 143 144 145
        tdSql.error(f"select * from t2 where c4 between null and {-1.7*10**308}")
        # tdSql.checkRows(3)

        tdLog.printNoPrefix("==========step8:query smallint type")

        tdSql.query("select * from t1 where c5 between 127 and 136")
        tdSql.checkRows(10)
        tdSql.query("select * from t1 where c5 between 126.9 and 135.9")
        tdSql.checkRows(9)
        tdSql.query("select * from t1 where c5 between 136 and 127")
        tdSql.checkRows(0)
C
cpwu 已提交
146 147 148
        tdSql.query("select * from t1 where c5 between '~' and 'ˆ'")
        tdSql.checkRows(0)
        tdSql.query("select * from t1 where c5 not between 1 and 2")
C
cpwu 已提交
149
        tdSql.checkRows(0)
C
cpwu 已提交
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164
        tdSql.query("select * from t1 where c5 between 32767 and 32768")
        tdSql.checkRows(1)
        tdSql.query("select * from t2 where c5 between -32768 and -32767")
        tdSql.checkRows(1)
        tdSql.error("select * from t2 where c5 between null and -32767")
        # tdSql.checkRows(1)

        tdLog.printNoPrefix("==========step9:query tinyint type")

        tdSql.query("select * from t1 where c6 between 0 and 9")
        tdSql.checkRows(10)
        tdSql.query("select * from t1 where c6 between -1.1 and 8.9")
        tdSql.checkRows(9)
        tdSql.query("select * from t1 where c6 between 9 and 0")
        tdSql.checkRows(0)
C
cpwu 已提交
165 166 167
        tdSql.query("select * from t1 where c6 between 'NUL' and 'HT'")
        tdSql.checkRows(1)
        tdSql.query("select * from t1 where c6 not between 1 and 2")
C
cpwu 已提交
168
        tdSql.checkRows(1)
C
cpwu 已提交
169 170 171 172 173 174 175 176 177
        tdSql.query("select * from t1 where c6 between 127 and 128")
        tdSql.checkRows(1)
        tdSql.query("select * from t2 where c6 between -128 and -127")
        tdSql.checkRows(1)
        tdSql.error("select * from t2 where c6 between null and -127")
        # tdSql.checkRows(3)

        tdLog.printNoPrefix("==========step10:invalid query type")

C
cpwu 已提交
178 179 180 181 182 183 184 185 186 187
        tdSql.query("select * from supt where location between 'beijing' and 'shanghai'")
        tdSql.checkRows(23)
        # 非0值均解析为1,因此"between 负值 and o"解析为"between 1 and 0"
        tdSql.query("select * from supt where isused between 0 and 1")
        tdSql.checkRows(23)
        tdSql.query("select * from supt where isused between -1 and 0")
        tdSql.checkRows(0)
        tdSql.error("select * from supt where isused between false and true")
        tdSql.query("select * from supt where family between '拖拉机' and '自行车'")
        tdSql.checkRows(23)
C
cpwu 已提交
188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205

        tdLog.printNoPrefix("==========step11:query HEX/OCT/BIN type")

        tdSql.error("select * from t1 where c6 between 0x7f and 0x80")      # check filter HEX
        tdSql.error("select * from t1 where c6 between 0b1 and 0b11111")    # check filter BIN
        tdSql.error("select * from t1 where c6 between 0b1 and 0x80")
        tdSql.error("select * from t1 where c6=0b1")
        tdSql.error("select * from t1 where c6=0x1")
        # 八进制数据会按照十进制数据进行判定
        tdSql.query("select * from t1 where c6 between 01 and 0200")        # check filter OCT
        tdSql.checkRows(10)

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

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