2 @message |
assert
Initial state:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
+ ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
3 lowered "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_ASC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_DEC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
+ ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
- ............-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
................-> Bitmap
- ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
+ ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
3 lowered "D" normal
4 UPPERED "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_ASC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
4 UPPERED "D" normal
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_DEC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
4 UPPERED "D" normal
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
3 lowered "L" normal
4 UPPERED "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
+ ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
- ............-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
4 UPPERED "L" normal
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
................-> Bitmap
- ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
4 UPPERED "L" normal
3 lowered "L" normal
After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci_ai:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
+ ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
1 lowered "D" w/accent
2 UPPERED "D" w/accent
3 lowered "D" normal
4 UPPERED "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_ASC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
4 UPPERED "D" normal
1 lowered "D" w/accent
2 UPPERED "D" w/accent
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_DEC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
2 UPPERED "D" w/accent
1 lowered "D" w/accent
4 UPPERED "D" normal
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
1 lowered "L" w/accent
2 UPPERED "L" w/accent
3 lowered "L" normal
4 UPPERED "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
+ ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
- ............-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
4 UPPERED "L" normal
1 lowered "L" w/accent
2 UPPERED "L" w/accent
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
................-> Bitmap
- ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2 UPPERED "L" w/accent
1 lowered "L" w/accent
4 UPPERED "L" normal
3 lowered "L" normal
After alter domain dm_utf8 type varchar(1) character set utf8:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
+ ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
3 lowered "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_ASC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
- ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
+ ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
- ............-> Index "TEST1_DEC" Range Scan (full match)
+ ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
- ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
+ ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
- ............-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
- ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
+ ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
................-> Bitmap
- ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
+ ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
LOG DETAILS:
2025-06-27 06:37:14.771
2025-06-27 06:37:14.771 act = <firebird.qa.plugin.Action object at [hex]>
2025-06-27 06:37:14.771 capsys = <_pytest.capture.CaptureFixture object at [hex]>
2025-06-27 06:37:14.772
2025-06-27 06:37:14.772 @pytest.mark.version('>=6')
2025-06-27 06:37:14.772 def test_1(act: Action, capsys):
2025-06-27 06:37:14.772 qry_map = {
2025-06-27 06:37:14.772 1 : 'select * from v1_chk_nr'
2025-06-27 06:37:14.772 ,2 : 'select * from v1_chk_ir_asc'
2025-06-27 06:37:14.772 ,3 : 'select * from v1_chk_ir_dec'
2025-06-27 06:37:14.772 ,4 : 'select * from v2_chk_nr'
2025-06-27 06:37:14.772 ,5 : 'select * from v2_chk_ir_asc'
2025-06-27 06:37:14.772 ,6 : 'select * from v2_chk_ir_dec'
2025-06-27 06:37:14.772 }
2025-06-27 06:37:14.772
2025-06-27 06:37:14.772 alter_lst = (
2025-06-27 06:37:14.772 ''
2025-06-27 06:37:14.772 ,'alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci'
2025-06-27 06:37:14.772 ,'alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci_ai'
2025-06-27 06:37:14.772 ,'alter domain dm_utf8 type varchar(1) character set utf8'
2025-06-27 06:37:14.773 )
2025-06-27 06:37:14.773
2025-06-27 06:37:14.773 with act.db.connect(charset = 'utf8') as con:
2025-06-27 06:37:14.773 cur = con.cursor()
2025-06-27 06:37:14.773 for alter_i in alter_lst:
2025-06-27 06:37:14.773 if alter_i.strip():
2025-06-27 06:37:14.773 con.execute_immediate(alter_i)
2025-06-27 06:37:14.773 con.commit()
2025-06-27 06:37:14.773 print(f'\nAfter {alter_i}:')
2025-06-27 06:37:14.773 else:
2025-06-27 06:37:14.773 print('Initial state:')
2025-06-27 06:37:14.773
2025-06-27 06:37:14.773 for k, v in qry_map.items():
2025-06-27 06:37:14.773 ps, rs = None, None
2025-06-27 06:37:14.773 try:
2025-06-27 06:37:14.773 ps = cur.prepare(v)
2025-06-27 06:37:14.773
2025-06-27 06:37:14.773 print('Query:', v)
2025-06-27 06:37:14.773 # Print explained plan with padding eash line by dots in order to see indentations:
2025-06-27 06:37:14.773 print( '\n'.join([replace_leading(s) for s in ps.detailed_plan.split('\n')]) )
2025-06-27 06:37:14.774 print('')
2025-06-27 06:37:14.774
2025-06-27 06:37:14.774 # ::: NB ::: 'ps' returns data, i.e. this is SELECTABLE expression.
2025-06-27 06:37:14.774 # We have to store result of cur.execute(<psInstance>) in order to
2025-06-27 06:37:14.774 # close it explicitly.
2025-06-27 06:37:14.774 # Otherwise AV can occur during Python garbage collection and this
2025-06-27 06:37:14.774 # causes pytest to hang on its final point.
2025-06-27 06:37:14.774 # Explained by hvlad, email 26.10.24 17:42
2025-06-27 06:37:14.774 rs = cur.execute(ps)
2025-06-27 06:37:14.774 for r in rs:
2025-06-27 06:37:14.774 print(r[0], r[1])
2025-06-27 06:37:14.774 except DatabaseError as e:
2025-06-27 06:37:14.774 print(e.__str__())
2025-06-27 06:37:14.774 print(e.gds_codes)
2025-06-27 06:37:14.774 finally:
2025-06-27 06:37:14.774 if rs:
2025-06-27 06:37:14.774 rs.close() # <<< EXPLICITLY CLOSING CURSOR RESULTS
2025-06-27 06:37:14.775 if ps:
2025-06-27 06:37:14.775 ps.free()
2025-06-27 06:37:14.775
2025-06-27 06:37:14.775
2025-06-27 06:37:14.775 expected_stdout = """
2025-06-27 06:37:14.775 Initial state:
2025-06-27 06:37:14.775
2025-06-27 06:37:14.775 Query: select * from v1_chk_nr
2025-06-27 06:37:14.775 Select Expression
2025-06-27 06:37:14.775 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.775 ........-> Filter
2025-06-27 06:37:14.775 ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.775 3 lowered "D" normal
2025-06-27 06:37:14.775 Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.775 Select Expression
2025-06-27 06:37:14.775 ....-> Filter
2025-06-27 06:37:14.775 ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.775 ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.775 3 lowered "D" normal
2025-06-27 06:37:14.775 Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.776 Select Expression
2025-06-27 06:37:14.776 ....-> Filter
2025-06-27 06:37:14.776 ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.776 ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.776 3 lowered "D" normal
2025-06-27 06:37:14.776 Query: select * from v2_chk_nr
2025-06-27 06:37:14.776 Select Expression
2025-06-27 06:37:14.776 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.776 ........-> Filter
2025-06-27 06:37:14.776 ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.776 3 lowered "L" normal
2025-06-27 06:37:14.776 Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.776 Select Expression
2025-06-27 06:37:14.776 ....-> Filter
2025-06-27 06:37:14.776 ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.776 ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.776 3 lowered "L" normal
2025-06-27 06:37:14.776 Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.776 Select Expression
2025-06-27 06:37:14.776 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.777 ........-> Filter
2025-06-27 06:37:14.777 ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.777 ................-> Bitmap
2025-06-27 06:37:14.777 ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.777 3 lowered "L" normal
2025-06-27 06:37:14.777
2025-06-27 06:37:14.777
2025-06-27 06:37:14.777 After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci:
2025-06-27 06:37:14.777
2025-06-27 06:37:14.777 Query: select * from v1_chk_nr
2025-06-27 06:37:14.777 Select Expression
2025-06-27 06:37:14.777 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.777 ........-> Filter
2025-06-27 06:37:14.777 ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.777 3 lowered "D" normal
2025-06-27 06:37:14.777 4 UPPERED "D" normal
2025-06-27 06:37:14.777 Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.777 Select Expression
2025-06-27 06:37:14.777 ....-> Filter
2025-06-27 06:37:14.777 ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.777 ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.778 3 lowered "D" normal
2025-06-27 06:37:14.778 4 UPPERED "D" normal
2025-06-27 06:37:14.778 Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.778 Select Expression
2025-06-27 06:37:14.778 ....-> Filter
2025-06-27 06:37:14.778 ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.778 ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.778 4 UPPERED "D" normal
2025-06-27 06:37:14.778 3 lowered "D" normal
2025-06-27 06:37:14.778 Query: select * from v2_chk_nr
2025-06-27 06:37:14.778 Select Expression
2025-06-27 06:37:14.778 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.778 ........-> Filter
2025-06-27 06:37:14.778 ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.778 3 lowered "L" normal
2025-06-27 06:37:14.778 4 UPPERED "L" normal
2025-06-27 06:37:14.778 Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.778 Select Expression
2025-06-27 06:37:14.779 ....-> Filter
2025-06-27 06:37:14.779 ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.779 ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.779 3 lowered "L" normal
2025-06-27 06:37:14.779 4 UPPERED "L" normal
2025-06-27 06:37:14.779 Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.779 Select Expression
2025-06-27 06:37:14.779 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.779 ........-> Filter
2025-06-27 06:37:14.779 ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.779 ................-> Bitmap
2025-06-27 06:37:14.779 ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.779 4 UPPERED "L" normal
2025-06-27 06:37:14.779 3 lowered "L" normal
2025-06-27 06:37:14.779
2025-06-27 06:37:14.779
2025-06-27 06:37:14.779 After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci_ai:
2025-06-27 06:37:14.779
2025-06-27 06:37:14.779 Query: select * from v1_chk_nr
2025-06-27 06:37:14.779 Select Expression
2025-06-27 06:37:14.780 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.780 ........-> Filter
2025-06-27 06:37:14.780 ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.780 1 lowered "D" w/accent
2025-06-27 06:37:14.780 2 UPPERED "D" w/accent
2025-06-27 06:37:14.780 3 lowered "D" normal
2025-06-27 06:37:14.780 4 UPPERED "D" normal
2025-06-27 06:37:14.780 Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.780 Select Expression
2025-06-27 06:37:14.780 ....-> Filter
2025-06-27 06:37:14.780 ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.780 ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.780 3 lowered "D" normal
2025-06-27 06:37:14.780 4 UPPERED "D" normal
2025-06-27 06:37:14.780 1 lowered "D" w/accent
2025-06-27 06:37:14.780 2 UPPERED "D" w/accent
2025-06-27 06:37:14.780 Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.780 Select Expression
2025-06-27 06:37:14.780 ....-> Filter
2025-06-27 06:37:14.780 ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.781 ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.781 2 UPPERED "D" w/accent
2025-06-27 06:37:14.781 1 lowered "D" w/accent
2025-06-27 06:37:14.781 4 UPPERED "D" normal
2025-06-27 06:37:14.781 3 lowered "D" normal
2025-06-27 06:37:14.781 Query: select * from v2_chk_nr
2025-06-27 06:37:14.781 Select Expression
2025-06-27 06:37:14.781 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.781 ........-> Filter
2025-06-27 06:37:14.781 ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.781 1 lowered "L" w/accent
2025-06-27 06:37:14.781 2 UPPERED "L" w/accent
2025-06-27 06:37:14.781 3 lowered "L" normal
2025-06-27 06:37:14.781 4 UPPERED "L" normal
2025-06-27 06:37:14.781 Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.781 Select Expression
2025-06-27 06:37:14.781 ....-> Filter
2025-06-27 06:37:14.781 ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.781 ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.782 3 lowered "L" normal
2025-06-27 06:37:14.782 4 UPPERED "L" normal
2025-06-27 06:37:14.782 1 lowered "L" w/accent
2025-06-27 06:37:14.782 2 UPPERED "L" w/accent
2025-06-27 06:37:14.782 Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.782 Select Expression
2025-06-27 06:37:14.782 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.782 ........-> Filter
2025-06-27 06:37:14.782 ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.782 ................-> Bitmap
2025-06-27 06:37:14.782 ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.782 2 UPPERED "L" w/accent
2025-06-27 06:37:14.782 1 lowered "L" w/accent
2025-06-27 06:37:14.782 4 UPPERED "L" normal
2025-06-27 06:37:14.782 3 lowered "L" normal
2025-06-27 06:37:14.782
2025-06-27 06:37:14.782
2025-06-27 06:37:14.782 After alter domain dm_utf8 type varchar(1) character set utf8:
2025-06-27 06:37:14.782
2025-06-27 06:37:14.782 Query: select * from v1_chk_nr
2025-06-27 06:37:14.783 Select Expression
2025-06-27 06:37:14.783 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.783 ........-> Filter
2025-06-27 06:37:14.783 ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.783 3 lowered "D" normal
2025-06-27 06:37:14.783 Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.783 Select Expression
2025-06-27 06:37:14.783 ....-> Filter
2025-06-27 06:37:14.783 ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.783 ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.783 3 lowered "D" normal
2025-06-27 06:37:14.783 Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.783 Select Expression
2025-06-27 06:37:14.783 ....-> Filter
2025-06-27 06:37:14.783 ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.783 ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.783 3 lowered "D" normal
2025-06-27 06:37:14.783 Query: select * from v2_chk_nr
2025-06-27 06:37:14.783 Select Expression
2025-06-27 06:37:14.783 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.784 ........-> Filter
2025-06-27 06:37:14.784 ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.784 3 lowered "L" normal
2025-06-27 06:37:14.784 Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.784 Select Expression
2025-06-27 06:37:14.784 ....-> Filter
2025-06-27 06:37:14.784 ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.784 ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.784 3 lowered "L" normal
2025-06-27 06:37:14.784 Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.784 Select Expression
2025-06-27 06:37:14.784 ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.784 ........-> Filter
2025-06-27 06:37:14.784 ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.784 ................-> Bitmap
2025-06-27 06:37:14.784 ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.784 3 lowered "L" normal
2025-06-27 06:37:14.784 """
2025-06-27 06:37:14.784
2025-06-27 06:37:14.784 act.expected_stdout = expected_stdout
2025-06-27 06:37:14.785
2025-06-27 06:37:14.785 act.stdout = capsys.readouterr().out
2025-06-27 06:37:14.785 > assert act.clean_stdout == act.clean_expected_stdout
2025-06-27 06:37:14.785 E assert
2025-06-27 06:37:14.785 E Initial state:
2025-06-27 06:37:14.785 E Query: select * from v1_chk_nr
2025-06-27 06:37:14.785 E Select Expression
2025-06-27 06:37:14.785 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.785 E ........-> Filter
2025-06-27 06:37:14.785 E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.785 E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
2025-06-27 06:37:14.785 E 3 lowered "D" normal
2025-06-27 06:37:14.785 E Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.785 E Select Expression
2025-06-27 06:37:14.785 E ....-> Filter
2025-06-27 06:37:14.785 E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.785 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.786 E - ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.786 E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.786 E 3 lowered "D" normal
2025-06-27 06:37:14.786 E Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.786 E Select Expression
2025-06-27 06:37:14.786 E ....-> Filter
2025-06-27 06:37:14.786 E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.786 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.786 E - ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.786 E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.786 E 3 lowered "D" normal
2025-06-27 06:37:14.786 E Query: select * from v2_chk_nr
2025-06-27 06:37:14.786 E Select Expression
2025-06-27 06:37:14.786 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.786 E ........-> Filter
2025-06-27 06:37:14.787 E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.787 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
2025-06-27 06:37:14.787 E 3 lowered "L" normal
2025-06-27 06:37:14.787 E Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.787 E Select Expression
2025-06-27 06:37:14.787 E ....-> Filter
2025-06-27 06:37:14.787 E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.787 E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.787 E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.787 E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.787 E 3 lowered "L" normal
2025-06-27 06:37:14.787 E Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.787 E Select Expression
2025-06-27 06:37:14.787 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.788 E ........-> Filter
2025-06-27 06:37:14.788 E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.788 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.788 E ................-> Bitmap
2025-06-27 06:37:14.788 E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.788 E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.788 E 3 lowered "L" normal
2025-06-27 06:37:14.788 E After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci:
2025-06-27 06:37:14.788 E Query: select * from v1_chk_nr
2025-06-27 06:37:14.788 E Select Expression
2025-06-27 06:37:14.788 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.788 E ........-> Filter
2025-06-27 06:37:14.788 E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.788 E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
2025-06-27 06:37:14.789 E 3 lowered "D" normal
2025-06-27 06:37:14.789 E 4 UPPERED "D" normal
2025-06-27 06:37:14.789 E Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.789 E Select Expression
2025-06-27 06:37:14.789 E ....-> Filter
2025-06-27 06:37:14.789 E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.789 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.789 E - ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.789 E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.789 E 3 lowered "D" normal
2025-06-27 06:37:14.789 E 4 UPPERED "D" normal
2025-06-27 06:37:14.789 E Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.789 E Select Expression
2025-06-27 06:37:14.789 E ....-> Filter
2025-06-27 06:37:14.789 E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.790 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.790 E - ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.790 E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.790 E 4 UPPERED "D" normal
2025-06-27 06:37:14.790 E 3 lowered "D" normal
2025-06-27 06:37:14.790 E Query: select * from v2_chk_nr
2025-06-27 06:37:14.790 E Select Expression
2025-06-27 06:37:14.790 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.790 E ........-> Filter
2025-06-27 06:37:14.790 E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.790 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
2025-06-27 06:37:14.790 E 3 lowered "L" normal
2025-06-27 06:37:14.790 E 4 UPPERED "L" normal
2025-06-27 06:37:14.790 E Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.790 E Select Expression
2025-06-27 06:37:14.791 E ....-> Filter
2025-06-27 06:37:14.791 E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.791 E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.791 E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.791 E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.791 E 3 lowered "L" normal
2025-06-27 06:37:14.791 E 4 UPPERED "L" normal
2025-06-27 06:37:14.791 E Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.791 E Select Expression
2025-06-27 06:37:14.791 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.791 E ........-> Filter
2025-06-27 06:37:14.791 E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.791 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.791 E ................-> Bitmap
2025-06-27 06:37:14.792 E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.792 E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.792 E 4 UPPERED "L" normal
2025-06-27 06:37:14.792 E 3 lowered "L" normal
2025-06-27 06:37:14.792 E After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci_ai:
2025-06-27 06:37:14.792 E Query: select * from v1_chk_nr
2025-06-27 06:37:14.792 E Select Expression
2025-06-27 06:37:14.792 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.792 E ........-> Filter
2025-06-27 06:37:14.792 E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.792 E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
2025-06-27 06:37:14.792 E 1 lowered "D" w/accent
2025-06-27 06:37:14.792 E 2 UPPERED "D" w/accent
2025-06-27 06:37:14.792 E 3 lowered "D" normal
2025-06-27 06:37:14.792 E 4 UPPERED "D" normal
2025-06-27 06:37:14.792 E Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.792 E Select Expression
2025-06-27 06:37:14.793 E ....-> Filter
2025-06-27 06:37:14.793 E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.793 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.793 E - ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.793 E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.793 E 3 lowered "D" normal
2025-06-27 06:37:14.793 E 4 UPPERED "D" normal
2025-06-27 06:37:14.793 E 1 lowered "D" w/accent
2025-06-27 06:37:14.793 E 2 UPPERED "D" w/accent
2025-06-27 06:37:14.793 E Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.793 E Select Expression
2025-06-27 06:37:14.793 E ....-> Filter
2025-06-27 06:37:14.793 E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.793 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.794 E - ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.794 E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.794 E 2 UPPERED "D" w/accent
2025-06-27 06:37:14.794 E 1 lowered "D" w/accent
2025-06-27 06:37:14.794 E 4 UPPERED "D" normal
2025-06-27 06:37:14.794 E 3 lowered "D" normal
2025-06-27 06:37:14.794 E Query: select * from v2_chk_nr
2025-06-27 06:37:14.794 E Select Expression
2025-06-27 06:37:14.794 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.798 E ........-> Filter
2025-06-27 06:37:14.798 E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.798 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
2025-06-27 06:37:14.798 E 1 lowered "L" w/accent
2025-06-27 06:37:14.798 E 2 UPPERED "L" w/accent
2025-06-27 06:37:14.798 E 3 lowered "L" normal
2025-06-27 06:37:14.798 E 4 UPPERED "L" normal
2025-06-27 06:37:14.798 E Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.798 E Select Expression
2025-06-27 06:37:14.798 E ....-> Filter
2025-06-27 06:37:14.798 E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.798 E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.799 E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.799 E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.799 E 3 lowered "L" normal
2025-06-27 06:37:14.799 E 4 UPPERED "L" normal
2025-06-27 06:37:14.799 E 1 lowered "L" w/accent
2025-06-27 06:37:14.799 E 2 UPPERED "L" w/accent
2025-06-27 06:37:14.799 E Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.799 E Select Expression
2025-06-27 06:37:14.799 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.799 E ........-> Filter
2025-06-27 06:37:14.799 E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.799 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.799 E ................-> Bitmap
2025-06-27 06:37:14.799 E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.799 E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.800 E 2 UPPERED "L" w/accent
2025-06-27 06:37:14.800 E 1 lowered "L" w/accent
2025-06-27 06:37:14.800 E 4 UPPERED "L" normal
2025-06-27 06:37:14.800 E 3 lowered "L" normal
2025-06-27 06:37:14.800 E After alter domain dm_utf8 type varchar(1) character set utf8:
2025-06-27 06:37:14.800 E Query: select * from v1_chk_nr
2025-06-27 06:37:14.800 E Select Expression
2025-06-27 06:37:14.800 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.800 E ........-> Filter
2025-06-27 06:37:14.800 E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
2025-06-27 06:37:14.800 E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
2025-06-27 06:37:14.800 E 3 lowered "D" normal
2025-06-27 06:37:14.800 E Query: select * from v1_chk_ir_asc
2025-06-27 06:37:14.800 E Select Expression
2025-06-27 06:37:14.800 E ....-> Filter
2025-06-27 06:37:14.800 E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
2025-06-27 06:37:14.801 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.801 E - ............-> Index "TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.801 E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
2025-06-27 06:37:14.801 E 3 lowered "D" normal
2025-06-27 06:37:14.801 E Query: select * from v1_chk_ir_dec
2025-06-27 06:37:14.801 E Select Expression
2025-06-27 06:37:14.801 E ....-> Filter
2025-06-27 06:37:14.801 E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
2025-06-27 06:37:14.801 E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
2025-06-27 06:37:14.801 E - ............-> Index "TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.801 E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
2025-06-27 06:37:14.801 E 3 lowered "D" normal
2025-06-27 06:37:14.801 E Query: select * from v2_chk_nr
2025-06-27 06:37:14.801 E Select Expression
2025-06-27 06:37:14.801 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.802 E ........-> Filter
2025-06-27 06:37:14.802 E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
2025-06-27 06:37:14.802 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
2025-06-27 06:37:14.802 E 3 lowered "L" normal
2025-06-27 06:37:14.802 E Query: select * from v2_chk_ir_asc
2025-06-27 06:37:14.802 E Select Expression
2025-06-27 06:37:14.802 E ....-> Filter
2025-06-27 06:37:14.802 E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
2025-06-27 06:37:14.802 E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.802 E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.802 E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.802 E 3 lowered "L" normal
2025-06-27 06:37:14.802 E Query: select * from v2_chk_ir_dec
2025-06-27 06:37:14.802 E Select Expression
2025-06-27 06:37:14.803 E ....-> Sort (record length: NN, key length: MM)
2025-06-27 06:37:14.803 E ........-> Filter
2025-06-27 06:37:14.803 E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
2025-06-27 06:37:14.803 E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
2025-06-27 06:37:14.803 E ................-> Bitmap
2025-06-27 06:37:14.803 E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.803 E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
2025-06-27 06:37:14.803 E 3 lowered "L" normal
2025-06-27 06:37:14.803
2025-06-27 06:37:14.803 tests\bugs\gh_8434_test.py:371: AssertionError
2025-06-27 06:37:14.803 ---------------------------- Captured stdout setup ----------------------------
2025-06-27 06:37:14.803 Creating db: localhost:H:\QA\temp\qa2024.tmp\fbqa\test_11757\test.fdb [page_size=None, sql_dialect=None, charset='NONE', user=SYSDBA, password=masterkey]
|
3 #text |
act = <firebird.qa.plugin.Action pytest object at [hex]>
capsys = <_pytest.capture.CaptureFixture pytest object at [hex]>
@pytest.mark.version('>=6')
def test_1(act: Action, capsys):
qry_map = {
1 : 'select * from v1_chk_nr'
,2 : 'select * from v1_chk_ir_asc'
,3 : 'select * from v1_chk_ir_dec'
,4 : 'select * from v2_chk_nr'
,5 : 'select * from v2_chk_ir_asc'
,6 : 'select * from v2_chk_ir_dec'
}
alter_lst = (
''
,'alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci'
,'alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci_ai'
,'alter domain dm_utf8 type varchar(1) character set utf8'
)
with act.db.connect(charset = 'utf8') as con:
cur = con.cursor()
for alter_i in alter_lst:
if alter_i.strip():
con.execute_immediate(alter_i)
con.commit()
print(f'\nAfter {alter_i}:')
else:
print('Initial state:')
for k, v in qry_map.items():
ps, rs = None, None
try:
ps = cur.prepare(v)
print('Query:', v)
# Print explained plan with padding eash line by dots in order to see indentations:
print( '\n'.join([replace_leading(s) for s in ps.detailed_plan.split('\n')]) )
print('')
# ::: NB ::: 'ps' returns data, i.e. this is SELECTABLE expression.
# We have to store result of cur.execute(<psInstance>) in order to
# close it explicitly.
# Otherwise AV can occur during Python garbage collection and this
# causes pytest to hang on its final point.
# Explained by hvlad, email 26.10.24 17:42
rs = cur.execute(ps)
for r in rs:
print(r[0], r[1])
except DatabaseError as e:
print(e.__str__())
print(e.gds_codes)
finally:
if rs:
rs.close() # <<< EXPLICITLY CLOSING CURSOR RESULTS
if ps:
ps.free()
expected_stdout = """
Initial state:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
3 lowered "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
............-> Index "TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
............-> Index "TEST1_DEC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
............-> Index "TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
................-> Bitmap
....................-> Index "TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
3 lowered "D" normal
4 UPPERED "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
............-> Index "TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
4 UPPERED "D" normal
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
............-> Index "TEST1_DEC" Range Scan (full match)
4 UPPERED "D" normal
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
3 lowered "L" normal
4 UPPERED "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
............-> Index "TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
4 UPPERED "L" normal
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
................-> Bitmap
....................-> Index "TEST2_PARTIAL_ASC" Full Scan
4 UPPERED "L" normal
3 lowered "L" normal
After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci_ai:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
1 lowered "D" w/accent
2 UPPERED "D" w/accent
3 lowered "D" normal
4 UPPERED "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
............-> Index "TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
4 UPPERED "D" normal
1 lowered "D" w/accent
2 UPPERED "D" w/accent
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
............-> Index "TEST1_DEC" Range Scan (full match)
2 UPPERED "D" w/accent
1 lowered "D" w/accent
4 UPPERED "D" normal
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
1 lowered "L" w/accent
2 UPPERED "L" w/accent
3 lowered "L" normal
4 UPPERED "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
............-> Index "TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
4 UPPERED "L" normal
1 lowered "L" w/accent
2 UPPERED "L" w/accent
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
................-> Bitmap
....................-> Index "TEST2_PARTIAL_ASC" Full Scan
2 UPPERED "L" w/accent
1 lowered "L" w/accent
4 UPPERED "L" normal
3 lowered "L" normal
After alter domain dm_utf8 type varchar(1) character set utf8:
Query: select * from v1_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
3 lowered "D" normal
Query: select * from v1_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
............-> Index "TEST1_ASC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v1_chk_ir_dec
Select Expression
....-> Filter
........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
............-> Index "TEST1_DEC" Range Scan (full match)
3 lowered "D" normal
Query: select * from v2_chk_nr
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_asc
Select Expression
....-> Filter
........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
............-> Index "TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
Query: select * from v2_chk_ir_dec
Select Expression
....-> Sort (record length: NN, key length: MM)
........-> Filter
............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
................-> Bitmap
....................-> Index "TEST2_PARTIAL_ASC" Full Scan
3 lowered "L" normal
"""
act.expected_stdout = expected_stdout
act.stdout = capsys.readouterr().out
> assert act.clean_stdout == act.clean_expected_stdout
E assert
E Initial state:
E Query: select * from v1_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
E 3 lowered "D" normal
E Query: select * from v1_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_ASC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
E 3 lowered "D" normal
E Query: select * from v1_chk_ir_dec
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_DEC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
E 3 lowered "D" normal
E Query: select * from v2_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
E 3 lowered "L" normal
E Query: select * from v2_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 3 lowered "L" normal
E Query: select * from v2_chk_ir_dec
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
E ................-> Bitmap
E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 3 lowered "L" normal
E After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci:
E Query: select * from v1_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
E 3 lowered "D" normal
E 4 UPPERED "D" normal
E Query: select * from v1_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_ASC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
E 3 lowered "D" normal
E 4 UPPERED "D" normal
E Query: select * from v1_chk_ir_dec
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_DEC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
E 4 UPPERED "D" normal
E 3 lowered "D" normal
E Query: select * from v2_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
E 3 lowered "L" normal
E 4 UPPERED "L" normal
E Query: select * from v2_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 3 lowered "L" normal
E 4 UPPERED "L" normal
E Query: select * from v2_chk_ir_dec
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
E ................-> Bitmap
E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 4 UPPERED "L" normal
E 3 lowered "L" normal
E After alter domain dm_utf8 type varchar(1) character set utf8 collate unicode_ci_ai:
E Query: select * from v1_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
E 1 lowered "D" w/accent
E 2 UPPERED "D" w/accent
E 3 lowered "D" normal
E 4 UPPERED "D" normal
E Query: select * from v1_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_ASC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
E 3 lowered "D" normal
E 4 UPPERED "D" normal
E 1 lowered "D" w/accent
E 2 UPPERED "D" w/accent
E Query: select * from v1_chk_ir_dec
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_DEC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
E 2 UPPERED "D" w/accent
E 1 lowered "D" w/accent
E 4 UPPERED "D" normal
E 3 lowered "D" normal
E Query: select * from v2_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
E 1 lowered "L" w/accent
E 2 UPPERED "L" w/accent
E 3 lowered "L" normal
E 4 UPPERED "L" normal
E Query: select * from v2_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 3 lowered "L" normal
E 4 UPPERED "L" normal
E 1 lowered "L" w/accent
E 2 UPPERED "L" w/accent
E Query: select * from v2_chk_ir_dec
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
E ................-> Bitmap
E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 2 UPPERED "L" w/accent
E 1 lowered "L" w/accent
E 4 UPPERED "L" normal
E 3 lowered "L" normal
E After alter domain dm_utf8 type varchar(1) character set utf8:
E Query: select * from v1_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST1" as "V1_CHK_NR TEST1" Full Scan
E + ............-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_NR" "PUBLIC"."TEST1" Full Scan
E 3 lowered "D" normal
E Query: select * from v1_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_ASC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_ASC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_ASC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_ASC" Range Scan (full match)
E 3 lowered "D" normal
E Query: select * from v1_chk_ir_dec
E Select Expression
E ....-> Filter
E - ........-> Table "TEST1" as "V1_CHK_IR_DEC TEST1" Access By ID
E + ........-> Table "PUBLIC"."TEST1" as "PUBLIC"."V1_CHK_IR_DEC" "PUBLIC"."TEST1" Access By ID
E - ............-> Index "TEST1_DEC" Range Scan (full match)
E + ............-> Index "PUBLIC"."TEST1_DEC" Range Scan (full match)
E 3 lowered "D" normal
E Query: select * from v2_chk_nr
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_NR TEST2" Full Scan
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_NR" "PUBLIC"."TEST2" Full Scan
E 3 lowered "L" normal
E Query: select * from v2_chk_ir_asc
E Select Expression
E ....-> Filter
E - ........-> Table "TEST2" as "V2_CHK_IR_ASC TEST2" Access By ID
E + ........-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_ASC" "PUBLIC"."TEST2" Access By ID
E - ............-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ............-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 3 lowered "L" normal
E Query: select * from v2_chk_ir_dec
E Select Expression
E ....-> Sort (record length: NN, key length: MM)
E ........-> Filter
E - ............-> Table "TEST2" as "V2_CHK_IR_DEC TEST2" Access By ID
E + ............-> Table "PUBLIC"."TEST2" as "PUBLIC"."V2_CHK_IR_DEC" "PUBLIC"."TEST2" Access By ID
E ................-> Bitmap
E - ....................-> Index "TEST2_PARTIAL_ASC" Full Scan
E + ....................-> Index "PUBLIC"."TEST2_PARTIAL_ASC" Full Scan
E 3 lowered "L" normal
tests\bugs\gh_8434_test.py:371: AssertionError
|