Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Feat](Nereids) support string functions fold constant by fe #40441

Merged
merged 8 commits into from
Sep 11, 2024

Conversation

LiBinfeng-01
Copy link
Collaborator

@LiBinfeng-01 LiBinfeng-01 commented Sep 5, 2024

support string functions fold constant by fe:
Concat, Substring, Length, Lower, Upper, Trim, Ltrim, Rtrim, Replace, Left, Right, Locate,
Instr, Ascii, Bin, ConcatWs, CharacterLength, Initcap, Md5, Md5Sum,
Field, FindInSet, Repeat, Reverse, Space, SplitByChar, SplitByString, SplitPart,
SubstringIndex, Strcmp, StrLeft, StrRight, Overlay, ParseUrl, UrlDecode,
AppendTrailingCharIfAbsent, EndsWith, ExtractUrlParameter, Quote, ReplaceEmpty, Password

@doris-robot
Copy link

Thank you for your contribution to Apache Doris.
Don't know what should be done next? See How to process your PR

Since 2024-03-18, the Document has been moved to doris-website.
See Doris Document.

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

@doris-robot
Copy link

TPC-H: Total hot run time: 38096 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpch-tools
Tpch sf100 test result on commit 0145f57c013df6e8296ec89ca0919744e1056d22, data reload: false

------ Round 1 ----------------------------------
q1	17614	4420	4314	4314
q2	2015	189	184	184
q3	11666	968	1140	968
q4	10515	692	769	692
q5	7772	2816	2782	2782
q6	227	140	134	134
q7	954	605	613	605
q8	9305	2054	2085	2054
q9	7001	6509	6504	6504
q10	7005	2220	2249	2220
q11	452	241	233	233
q12	415	219	227	219
q13	17773	3098	3083	3083
q14	290	247	241	241
q15	542	495	485	485
q16	596	504	518	504
q17	970	697	736	697
q18	7296	6924	6870	6870
q19	1387	1061	1142	1061
q20	667	339	317	317
q21	4009	3067	2928	2928
q22	1116	1023	1001	1001
Total cold run time: 109587 ms
Total hot run time: 38096 ms

----- Round 2, with runtime_filter_mode=off -----
q1	4438	4287	4319	4287
q2	386	267	262	262
q3	2893	2722	2655	2655
q4	1926	1658	1650	1650
q5	5605	5674	5715	5674
q6	232	135	137	135
q7	2241	1822	1882	1822
q8	3316	3463	3452	3452
q9	8785	8823	8762	8762
q10	3560	3391	3343	3343
q11	601	528	513	513
q12	845	694	688	688
q13	12888	3273	3316	3273
q14	317	307	294	294
q15	520	482	513	482
q16	625	587	599	587
q17	1812	1544	1543	1543
q18	8091	8005	7864	7864
q19	1731	1523	1483	1483
q20	2134	1951	1895	1895
q21	5790	5457	5375	5375
q22	1119	1045	1044	1044
Total cold run time: 69855 ms
Total hot run time: 57083 ms

@doris-robot
Copy link

TPC-DS: Total hot run time: 192427 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpcds-tools
TPC-DS sf100 test result on commit 0145f57c013df6e8296ec89ca0919744e1056d22, data reload: false

query1	1263	901	895	895
query2	6347	1883	1848	1848
query3	10626	3903	3723	3723
query4	59537	23791	23314	23314
query5	5335	505	492	492
query6	396	164	187	164
query7	5780	304	290	290
query8	314	229	224	224
query9	9030	2499	2496	2496
query10	472	272	257	257
query11	18097	15138	15368	15138
query12	172	103	107	103
query13	1586	417	416	416
query14	10883	7331	7394	7331
query15	251	172	168	168
query16	7576	484	448	448
query17	1088	565	592	565
query18	2107	305	292	292
query19	298	148	151	148
query20	120	112	107	107
query21	206	105	106	105
query22	4727	4450	4558	4450
query23	34378	33429	33497	33429
query24	5930	2817	2859	2817
query25	524	387	365	365
query26	687	154	150	150
query27	1806	274	274	274
query28	3788	2067	2053	2053
query29	695	401	403	401
query30	232	152	155	152
query31	949	762	768	762
query32	83	50	49	49
query33	429	280	281	280
query34	882	481	471	471
query35	857	728	724	724
query36	1056	927	912	912
query37	153	88	93	88
query38	4002	3957	3869	3869
query39	1450	1392	1412	1392
query40	200	112	113	112
query41	49	46	45	45
query42	111	89	93	89
query43	517	473	459	459
query44	1108	773	738	738
query45	204	166	167	166
query46	1117	713	748	713
query47	1892	1783	1801	1783
query48	382	304	296	296
query49	766	432	444	432
query50	807	404	398	398
query51	6959	6824	6798	6798
query52	98	82	83	82
query53	245	178	182	178
query54	556	470	448	448
query55	78	75	73	73
query56	273	240	254	240
query57	1204	1072	1095	1072
query58	227	227	221	221
query59	3014	2904	2749	2749
query60	290	263	272	263
query61	103	98	102	98
query62	769	657	657	657
query63	217	182	215	182
query64	2861	679	661	661
query65	3228	3152	3159	3152
query66	685	324	339	324
query67	15228	15211	15268	15211
query68	2947	592	596	592
query69	405	268	280	268
query70	1178	1160	1133	1133
query71	343	276	281	276
query72	5262	3987	3934	3934
query73	755	321	326	321
query74	9290	8930	8812	8812
query75	3370	2702	2749	2702
query76	1418	1039	945	945
query77	552	329	326	326
query78	10030	9101	9031	9031
query79	1038	541	527	527
query80	669	498	505	498
query81	539	237	234	234
query82	252	150	143	143
query83	172	148	148	148
query84	256	77	78	77
query85	671	284	275	275
query86	321	286	300	286
query87	4549	4261	4229	4229
query88	2928	2393	2376	2376
query89	370	285	283	283
query90	1921	196	188	188
query91	121	98	100	98
query92	59	48	48	48
query93	1036	530	521	521
query94	706	308	373	308
query95	301	249	244	244
query96	589	270	270	270
query97	3192	3074	3096	3074
query98	212	194	201	194
query99	1549	1264	1266	1264
Total cold run time: 304301 ms
Total hot run time: 192427 ms

@doris-robot
Copy link

ClickBench: Total hot run time: 31.91 s
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/clickbench-tools
ClickBench test result on commit 0145f57c013df6e8296ec89ca0919744e1056d22, data reload: false

query1	0.05	0.05	0.04
query2	0.07	0.03	0.04
query3	0.23	0.05	0.05
query4	1.69	0.09	0.08
query5	0.50	0.49	0.50
query6	1.13	0.73	0.73
query7	0.02	0.02	0.01
query8	0.05	0.04	0.05
query9	0.54	0.51	0.49
query10	0.54	0.55	0.55
query11	0.16	0.12	0.11
query12	0.15	0.13	0.12
query13	0.59	0.60	0.59
query14	2.03	2.06	2.05
query15	0.84	0.82	0.83
query16	0.38	0.37	0.38
query17	1.02	1.05	1.02
query18	0.20	0.19	0.20
query19	1.94	1.76	1.79
query20	0.01	0.01	0.01
query21	15.39	0.66	0.65
query22	4.41	7.47	1.83
query23	18.23	1.41	1.29
query24	2.04	0.23	0.22
query25	0.15	0.08	0.08
query26	0.28	0.18	0.18
query27	0.07	0.07	0.08
query28	13.22	1.01	1.00
query29	12.56	3.38	3.36
query30	0.24	0.05	0.05
query31	2.88	0.40	0.39
query32	3.27	0.49	0.48
query33	3.00	3.03	2.99
query34	17.04	4.34	4.37
query35	4.43	4.46	4.38
query36	0.67	0.48	0.47
query37	0.20	0.16	0.15
query38	0.16	0.14	0.16
query39	0.05	0.04	0.04
query40	0.16	0.13	0.12
query41	0.10	0.05	0.05
query42	0.06	0.04	0.04
query43	0.05	0.04	0.04
Total cold run time: 110.8 s
Total hot run time: 31.91 s

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

@doris-robot
Copy link

TPC-H: Total hot run time: 37836 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpch-tools
Tpch sf100 test result on commit 18f4a35d6de1e227208fa40314e909fb5d9d292c, data reload: false

------ Round 1 ----------------------------------
q1	17641	4390	4284	4284
q2	2023	197	181	181
q3	11983	994	1090	994
q4	10526	760	800	760
q5	7747	2863	2828	2828
q6	227	139	141	139
q7	947	610	595	595
q8	9327	2050	2071	2050
q9	7290	6546	6535	6535
q10	7004	2201	2149	2149
q11	452	241	243	241
q12	388	222	222	222
q13	17772	3111	3081	3081
q14	297	238	242	238
q15	540	501	476	476
q16	518	437	432	432
q17	972	674	636	636
q18	7351	6797	6928	6797
q19	1386	1088	1002	1002
q20	689	350	321	321
q21	3908	3161	2838	2838
q22	1128	1064	1037	1037
Total cold run time: 110116 ms
Total hot run time: 37836 ms

----- Round 2, with runtime_filter_mode=off -----
q1	4368	4290	4302	4290
q2	375	281	275	275
q3	2905	2724	2718	2718
q4	1961	1617	1654	1617
q5	5619	5690	5713	5690
q6	230	139	139	139
q7	2204	1830	1830	1830
q8	3300	3449	3453	3449
q9	8900	8831	8778	8778
q10	3571	3387	3381	3381
q11	604	504	512	504
q12	827	644	702	644
q13	14390	3355	3251	3251
q14	310	293	300	293
q15	531	482	504	482
q16	516	504	484	484
q17	1816	1540	1548	1540
q18	8212	7871	7852	7852
q19	1742	1612	1541	1541
q20	2143	1918	1917	1917
q21	5799	5618	5430	5430
q22	1163	1055	1066	1055
Total cold run time: 71486 ms
Total hot run time: 57160 ms

@doris-robot
Copy link

TPC-DS: Total hot run time: 192562 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpcds-tools
TPC-DS sf100 test result on commit 18f4a35d6de1e227208fa40314e909fb5d9d292c, data reload: false

query1	1253	912	875	875
query2	6324	1924	1874	1874
query3	10736	4152	3904	3904
query4	59518	23948	23247	23247
query5	5382	496	495	495
query6	408	168	173	168
query7	5743	297	287	287
query8	306	221	210	210
query9	8950	2476	2497	2476
query10	504	269	261	261
query11	18353	15024	15423	15024
query12	152	104	99	99
query13	1567	377	370	370
query14	10869	7675	7367	7367
query15	260	183	187	183
query16	7181	488	506	488
query17	1122	593	572	572
query18	1854	296	320	296
query19	291	153	152	152
query20	122	114	112	112
query21	206	102	104	102
query22	4601	4394	4452	4394
query23	34422	34113	33512	33512
query24	5931	2905	2941	2905
query25	519	372	376	372
query26	689	156	154	154
query27	1800	267	272	267
query28	3822	2046	2016	2016
query29	657	405	427	405
query30	240	150	158	150
query31	935	754	764	754
query32	83	52	52	52
query33	412	286	276	276
query34	858	481	481	481
query35	834	705	728	705
query36	1077	908	952	908
query37	148	84	85	84
query38	4103	3902	3867	3867
query39	1445	1432	1395	1395
query40	195	114	112	112
query41	47	46	44	44
query42	118	96	95	95
query43	501	455	487	455
query44	1099	751	742	742
query45	195	162	161	161
query46	1074	749	756	749
query47	1912	1766	1787	1766
query48	363	297	287	287
query49	760	434	443	434
query50	822	408	409	408
query51	6996	6982	6807	6807
query52	104	89	89	89
query53	248	182	186	182
query54	569	459	455	455
query55	78	76	75	75
query56	296	260	272	260
query57	1155	1094	1085	1085
query58	225	240	247	240
query59	3045	2742	2696	2696
query60	293	275	266	266
query61	102	99	102	99
query62	770	667	659	659
query63	216	191	187	187
query64	2842	671	690	671
query65	3269	3176	3236	3176
query66	686	347	361	347
query67	15323	15257	15186	15186
query68	2938	568	584	568
query69	397	282	275	275
query70	1173	1119	1087	1087
query71	348	280	279	279
query72	5473	4005	3976	3976
query73	741	322	326	322
query74	9208	9001	8769	8769
query75	3392	2720	2758	2720
query76	1445	954	951	951
query77	514	330	325	325
query78	9612	9057	9098	9057
query79	1030	541	540	540
query80	694	518	565	518
query81	536	227	231	227
query82	246	150	143	143
query83	173	153	150	150
query84	266	76	76	76
query85	679	284	278	278
query86	305	299	302	299
query87	4449	4372	4242	4242
query88	2950	2409	2291	2291
query89	379	294	281	281
query90	1971	198	190	190
query91	123	97	96	96
query92	58	48	49	48
query93	1032	536	536	536
query94	713	297	290	290
query95	327	250	253	250
query96	588	262	265	262
query97	3263	3087	3042	3042
query98	269	204	206	204
query99	1507	1296	1278	1278
Total cold run time: 303779 ms
Total hot run time: 192562 ms

@doris-robot
Copy link

ClickBench: Total hot run time: 32.23 s
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/clickbench-tools
ClickBench test result on commit 18f4a35d6de1e227208fa40314e909fb5d9d292c, data reload: false

query1	0.05	0.05	0.04
query2	0.09	0.04	0.04
query3	0.24	0.06	0.06
query4	1.66	0.08	0.09
query5	0.51	0.48	0.50
query6	1.13	0.73	0.73
query7	0.02	0.01	0.02
query8	0.05	0.04	0.04
query9	0.55	0.50	0.50
query10	0.55	0.56	0.53
query11	0.15	0.12	0.12
query12	0.15	0.14	0.12
query13	0.59	0.60	0.58
query14	1.41	1.42	1.45
query15	0.86	0.82	0.83
query16	0.37	0.38	0.37
query17	1.05	1.04	1.02
query18	0.21	0.20	0.20
query19	1.93	1.79	1.77
query20	0.01	0.00	0.01
query21	15.40	0.69	0.65
query22	4.14	6.35	2.75
query23	18.24	1.39	1.24
query24	2.15	0.21	0.22
query25	0.15	0.09	0.08
query26	0.27	0.18	0.18
query27	0.08	0.07	0.08
query28	13.26	1.01	1.00
query29	12.63	3.34	3.35
query30	0.24	0.05	0.06
query31	2.86	0.41	0.40
query32	3.25	0.47	0.48
query33	2.94	2.97	2.95
query34	17.25	4.41	4.43
query35	4.52	4.43	4.48
query36	0.66	0.49	0.50
query37	0.18	0.16	0.15
query38	0.15	0.15	0.14
query39	0.05	0.04	0.03
query40	0.15	0.13	0.13
query41	0.10	0.05	0.05
query42	0.06	0.04	0.05
query43	0.05	0.04	0.04
Total cold run time: 110.36 s
Total hot run time: 32.23 s

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

@doris-robot
Copy link

TPC-H: Total hot run time: 38399 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpch-tools
Tpch sf100 test result on commit 297acb4ad4d4198ec22b4f53f656d29d4992436d, data reload: false

------ Round 1 ----------------------------------
q1	17609	4685	4303	4303
q2	2015	193	191	191
q3	11766	1023	1189	1023
q4	10513	771	731	731
q5	7727	2902	2826	2826
q6	233	143	145	143
q7	975	637	620	620
q8	9327	2100	2101	2100
q9	7217	6559	6547	6547
q10	6997	2217	2194	2194
q11	457	246	244	244
q12	407	231	234	231
q13	17874	3083	3055	3055
q14	282	238	247	238
q15	529	495	497	495
q16	507	414	447	414
q17	986	723	723	723
q18	7307	6843	6847	6843
q19	1399	1068	998	998
q20	698	331	331	331
q21	3939	3136	3258	3136
q22	1141	1029	1013	1013
Total cold run time: 109905 ms
Total hot run time: 38399 ms

----- Round 2, with runtime_filter_mode=off -----
q1	4356	4316	4281	4281
q2	380	287	277	277
q3	2865	2671	2674	2671
q4	1967	1721	1662	1662
q5	5665	5694	5705	5694
q6	229	144	141	141
q7	2247	1852	1830	1830
q8	3310	3419	3513	3419
q9	8841	8901	8831	8831
q10	3628	3349	3380	3349
q11	607	509	514	509
q12	841	650	694	650
q13	14933	3214	3291	3214
q14	343	297	288	288
q15	545	491	498	491
q16	567	502	514	502
q17	1846	1543	1523	1523
q18	8111	7896	7932	7896
q19	1721	1579	1489	1489
q20	2165	1894	1904	1894
q21	5686	5623	5620	5620
q22	1126	1044	1023	1023
Total cold run time: 71979 ms
Total hot run time: 57254 ms

@doris-robot
Copy link

TPC-DS: Total hot run time: 192774 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpcds-tools
TPC-DS sf100 test result on commit 297acb4ad4d4198ec22b4f53f656d29d4992436d, data reload: false

query1	1265	876	912	876
query2	6360	1945	1768	1768
query3	10604	3907	3908	3907
query4	60020	26560	23130	23130
query5	5357	505	514	505
query6	423	176	163	163
query7	5778	295	287	287
query8	307	206	216	206
query9	8910	2469	2478	2469
query10	480	276	278	276
query11	18054	15057	15326	15057
query12	155	107	109	107
query13	1567	416	400	400
query14	11189	7007	7082	7007
query15	239	182	186	182
query16	7459	463	509	463
query17	1089	599	600	599
query18	1983	295	298	295
query19	285	150	150	150
query20	125	110	112	110
query21	201	111	105	105
query22	4589	4645	4473	4473
query23	34199	33658	33455	33455
query24	5881	2811	2828	2811
query25	515	388	386	386
query26	668	150	150	150
query27	1762	270	275	270
query28	3781	2045	2016	2016
query29	661	412	451	412
query30	233	151	153	151
query31	953	768	769	768
query32	83	52	52	52
query33	405	282	289	282
query34	854	472	480	472
query35	802	715	726	715
query36	1078	937	976	937
query37	149	88	95	88
query38	4068	3841	3886	3841
query39	1445	1367	1383	1367
query40	206	116	114	114
query41	46	47	45	45
query42	117	98	97	97
query43	493	470	467	467
query44	1079	754	739	739
query45	202	166	166	166
query46	1085	730	722	722
query47	1953	1809	1791	1791
query48	365	290	292	290
query49	784	437	437	437
query50	835	403	403	403
query51	6972	6946	6840	6840
query52	101	90	90	90
query53	261	178	182	178
query54	569	452	460	452
query55	79	75	77	75
query56	298	273	281	273
query57	1218	1092	1096	1092
query58	237	255	240	240
query59	3031	2944	2773	2773
query60	320	274	285	274
query61	120	120	122	120
query62	757	663	661	661
query63	218	191	190	190
query64	2704	759	833	759
query65	3201	3089	3177	3089
query66	684	342	340	340
query67	15419	15210	15084	15084
query68	3313	577	590	577
query69	403	286	288	286
query70	1177	1061	1149	1061
query71	361	278	283	278
query72	6301	3960	3915	3915
query73	762	324	326	324
query74	9081	8828	8824	8824
query75	3378	2719	2696	2696
query76	1423	989	995	989
query77	587	325	326	325
query78	9667	9712	10917	9712
query79	1044	527	533	527
query80	756	503	519	503
query81	545	236	230	230
query82	270	139	140	139
query83	173	153	151	151
query84	270	72	78	72
query85	743	292	276	276
query86	306	273	295	273
query87	4473	4337	4434	4337
query88	3020	2302	2296	2296
query89	379	280	285	280
query90	1992	194	189	189
query91	129	101	109	101
query92	60	47	49	47
query93	1054	579	537	537
query94	750	291	293	291
query95	353	285	251	251
query96	588	261	262	261
query97	3207	3056	3091	3056
query98	230	200	195	195
query99	1674	1266	1289	1266
Total cold run time: 305799 ms
Total hot run time: 192774 ms

@doris-robot
Copy link

ClickBench: Total hot run time: 31.66 s
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/clickbench-tools
ClickBench test result on commit 297acb4ad4d4198ec22b4f53f656d29d4992436d, data reload: false

query1	0.04	0.04	0.04
query2	0.10	0.05	0.04
query3	0.23	0.06	0.06
query4	1.67	0.09	0.09
query5	0.50	0.49	0.49
query6	1.13	0.73	0.72
query7	0.02	0.01	0.01
query8	0.06	0.04	0.05
query9	0.53	0.50	0.49
query10	0.54	0.56	0.56
query11	0.16	0.12	0.12
query12	0.16	0.13	0.12
query13	0.59	0.58	0.58
query14	1.43	1.45	1.47
query15	0.86	0.82	0.82
query16	0.37	0.37	0.36
query17	0.99	0.98	1.06
query18	0.21	0.20	0.19
query19	1.91	1.76	1.74
query20	0.01	0.00	0.01
query21	15.40	0.65	0.65
query22	4.31	6.94	2.23
query23	18.28	1.30	1.26
query24	2.08	0.22	0.22
query25	0.14	0.08	0.08
query26	0.27	0.19	0.17
query27	0.08	0.08	0.07
query28	13.27	1.02	1.00
query29	12.65	3.30	3.31
query30	0.24	0.05	0.06
query31	2.87	0.40	0.39
query32	3.28	0.48	0.47
query33	2.95	2.99	3.03
query34	16.89	4.39	4.40
query35	4.40	4.44	4.49
query36	0.65	0.47	0.47
query37	0.18	0.15	0.16
query38	0.16	0.15	0.15
query39	0.04	0.03	0.04
query40	0.15	0.13	0.13
query41	0.10	0.04	0.05
query42	0.06	0.04	0.04
query43	0.04	0.04	0.04
Total cold run time: 110 s
Total hot run time: 31.66 s

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

@doris-robot
Copy link

TPC-H: Total hot run time: 38006 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpch-tools
Tpch sf100 test result on commit 54275d49f7d10ca215ab7a109cdd22246ffd24af, data reload: false

------ Round 1 ----------------------------------
q1	17625	4472	4309	4309
q2	2024	207	184	184
q3	11844	952	1162	952
q4	10525	763	751	751
q5	7772	2843	2811	2811
q6	225	136	135	135
q7	961	621	605	605
q8	9316	2086	2065	2065
q9	7201	6506	6584	6506
q10	7003	2226	2242	2226
q11	478	234	240	234
q12	392	219	221	219
q13	18715	3083	3052	3052
q14	287	231	248	231
q15	540	492	487	487
q16	531	420	437	420
q17	975	708	681	681
q18	7344	6949	6762	6762
q19	1389	1122	1027	1027
q20	691	331	331	331
q21	3929	3126	3000	3000
q22	1156	1043	1018	1018
Total cold run time: 110923 ms
Total hot run time: 38006 ms

----- Round 2, with runtime_filter_mode=off -----
q1	4346	4331	4258	4258
q2	391	281	267	267
q3	2915	2734	2650	2650
q4	1976	1686	1647	1647
q5	5672	5640	5770	5640
q6	233	140	142	140
q7	2177	1876	1809	1809
q8	3233	3473	3458	3458
q9	8775	8786	8807	8786
q10	3550	3383	3345	3345
q11	597	499	511	499
q12	833	698	653	653
q13	15157	3306	3253	3253
q14	324	293	297	293
q15	517	484	497	484
q16	545	516	486	486
q17	1837	1525	1516	1516
q18	8005	7664	7777	7664
q19	1700	1530	1539	1530
q20	2160	1902	1926	1902
q21	5779	5554	5591	5554
q22	1169	1070	1054	1054
Total cold run time: 71891 ms
Total hot run time: 56888 ms

@LiBinfeng-01
Copy link
Collaborator Author

run feut

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

@doris-robot
Copy link

TPC-H: Total hot run time: 38078 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpch-tools
Tpch sf100 test result on commit 54275d49f7d10ca215ab7a109cdd22246ffd24af, data reload: false

------ Round 1 ----------------------------------
q1	17660	4389	4310	4310
q2	2029	188	198	188
q3	11899	966	1165	966
q4	10506	664	651	651
q5	7766	2869	2801	2801
q6	229	137	136	136
q7	959	618	623	618
q8	10583	2062	2087	2062
q9	7070	6583	6596	6583
q10	6988	2290	2170	2170
q11	490	242	235	235
q12	445	218	221	218
q13	18994	3185	3319	3185
q14	295	241	259	241
q15	555	500	498	498
q16	527	457	466	457
q17	993	694	717	694
q18	9419	7485	6845	6845
q19	1431	1057	1079	1057
q20	699	341	336	336
q21	4696	2969	2819	2819
q22	1145	1027	1008	1008
Total cold run time: 115378 ms
Total hot run time: 38078 ms

----- Round 2, with runtime_filter_mode=off -----
q1	4379	4264	4262	4262
q2	388	286	274	274
q3	2876	2636	2645	2636
q4	1975	1735	1709	1709
q5	5656	5832	5596	5596
q6	219	131	134	131
q7	2192	1754	1757	1754
q8	3308	3471	3462	3462
q9	8814	8767	8843	8767
q10	3588	3347	3307	3307
q11	608	529	507	507
q12	875	626	591	591
q13	16897	3312	3290	3290
q14	321	288	273	273
q15	521	491	512	491
q16	533	523	514	514
q17	1831	1544	1524	1524
q18	8159	7780	7881	7780
q19	1767	1592	1600	1592
q20	2131	1944	1897	1897
q21	5747	5394	5291	5291
q22	1149	1083	1051	1051
Total cold run time: 73934 ms
Total hot run time: 56699 ms

@doris-robot
Copy link

TPC-DS: Total hot run time: 191376 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpcds-tools
TPC-DS sf100 test result on commit 54275d49f7d10ca215ab7a109cdd22246ffd24af, data reload: false

query1	1232	900	869	869
query2	6472	1872	1867	1867
query3	10589	4099	3958	3958
query4	59489	25830	23328	23328
query5	5460	483	484	483
query6	395	158	161	158
query7	5871	292	287	287
query8	313	218	217	217
query9	9043	2481	2472	2472
query10	493	265	272	265
query11	17876	14889	15250	14889
query12	160	106	102	102
query13	1552	392	383	383
query14	11284	7327	7305	7305
query15	254	175	167	167
query16	7548	472	495	472
query17	1139	549	553	549
query18	2010	305	291	291
query19	291	144	142	142
query20	117	107	103	103
query21	207	101	101	101
query22	4797	4331	4683	4331
query23	34165	33272	33295	33272
query24	5898	2765	2846	2765
query25	529	373	381	373
query26	686	147	152	147
query27	1806	262	270	262
query28	3820	2008	2001	2001
query29	686	396	420	396
query30	237	148	150	148
query31	918	758	747	747
query32	81	51	54	51
query33	448	281	269	269
query34	860	460	455	455
query35	842	697	729	697
query36	1072	932	933	932
query37	144	84	79	79
query38	4003	3801	3836	3801
query39	1453	1409	1363	1363
query40	195	110	109	109
query41	45	46	44	44
query42	118	95	93	93
query43	495	483	452	452
query44	1074	752	719	719
query45	197	166	166	166
query46	1088	743	723	723
query47	1900	1778	1839	1778
query48	364	280	283	280
query49	763	460	431	431
query50	837	396	416	396
query51	7121	6806	6882	6806
query52	96	85	85	85
query53	261	178	179	178
query54	541	434	438	434
query55	74	76	74	74
query56	264	257	256	256
query57	1177	1049	1088	1049
query58	220	223	217	217
query59	2955	2879	2784	2784
query60	296	259	260	259
query61	98	101	99	99
query62	746	649	651	649
query63	210	183	182	182
query64	2874	664	651	651
query65	3209	3108	3097	3097
query66	671	335	333	333
query67	15289	15224	15224	15224
query68	2958	574	579	574
query69	397	260	269	260
query70	1127	1109	1074	1074
query71	345	263	267	263
query72	5193	3898	4197	3898
query73	738	314	319	314
query74	9159	8876	8758	8758
query75	3370	2682	2696	2682
query76	1381	978	1004	978
query77	537	319	342	319
query78	9708	9075	8981	8981
query79	1037	547	513	513
query80	695	510	513	510
query81	464	233	239	233
query82	240	142	143	142
query83	177	152	153	152
query84	260	76	78	76
query85	742	341	339	339
query86	320	314	298	298
query87	4328	4192	4317	4192
query88	3265	2273	2286	2273
query89	380	294	287	287
query90	1995	186	188	186
query91	132	110	109	109
query92	63	48	53	48
query93	1046	526	528	526
query94	742	306	297	297
query95	355	264	262	262
query96	583	269	261	261
query97	3187	3048	3049	3048
query98	224	209	203	203
query99	1544	1255	1269	1255
Total cold run time: 304110 ms
Total hot run time: 191376 ms

@doris-robot
Copy link

ClickBench: Total hot run time: 31.75 s
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/clickbench-tools
ClickBench test result on commit 54275d49f7d10ca215ab7a109cdd22246ffd24af, data reload: false

query1	0.05	0.05	0.04
query2	0.08	0.04	0.04
query3	0.23	0.04	0.05
query4	1.68	0.08	0.08
query5	0.51	0.50	0.49
query6	1.12	0.72	0.72
query7	0.02	0.01	0.01
query8	0.05	0.05	0.05
query9	0.53	0.50	0.49
query10	0.54	0.55	0.56
query11	0.16	0.12	0.11
query12	0.15	0.13	0.12
query13	0.59	0.59	0.58
query14	1.38	1.42	1.38
query15	0.84	0.83	0.82
query16	0.38	0.35	0.38
query17	1.04	1.06	1.05
query18	0.21	0.20	0.20
query19	1.88	1.72	1.77
query20	0.01	0.01	0.01
query21	15.38	0.67	0.67
query22	3.78	6.90	2.36
query23	18.29	1.38	1.28
query24	2.19	0.22	0.22
query25	0.15	0.08	0.08
query26	0.27	0.17	0.19
query27	0.08	0.08	0.08
query28	13.19	1.01	0.99
query29	12.58	3.28	3.28
query30	0.26	0.05	0.06
query31	2.88	0.41	0.39
query32	3.24	0.48	0.48
query33	2.95	2.98	3.01
query34	17.01	4.36	4.36
query35	4.41	4.46	4.44
query36	0.66	0.48	0.48
query37	0.19	0.16	0.15
query38	0.15	0.14	0.15
query39	0.06	0.04	0.04
query40	0.16	0.13	0.13
query41	0.09	0.05	0.05
query42	0.06	0.04	0.05
query43	0.05	0.04	0.05
Total cold run time: 109.53 s
Total hot run time: 31.75 s

@LiBinfeng-01
Copy link
Collaborator Author

run buildall

LiBinfeng-01 added a commit to LiBinfeng-01/doris that referenced this pull request Jan 7, 2025
…re cases (apache#45233)

Issue Number: apache#44666
Related PR: apache#40441

Problem Summary:
- select substring_index('哈哈哈AAA','A', 1);
String.split function has second parameter 'limit', which is default
zero. When 'limit' is zero, it means it would remove trailing
empty strings split of '哈哈哈AAA', which would be '哈哈哈' only. But what we
expect is '哈哈哈', '','','' when part function is used by substring index.
So we should change splitpart limit to -1 to enable trailing empty
character in splitpart list
- reorganize fold constant of string functions in fe and add more cases
LiBinfeng-01 added a commit to LiBinfeng-01/doris that referenced this pull request Jan 7, 2025
…re cases (apache#45233)

Issue Number: apache#44666
Related PR: apache#40441

Problem Summary:
- select substring_index('哈哈哈AAA','A', 1);
String.split function has second parameter 'limit', which is default
zero. When 'limit' is zero, it means it would remove trailing
empty strings split of '哈哈哈AAA', which would be '哈哈哈' only. But what we
expect is '哈哈哈', '','','' when part function is used by substring index.
So we should change splitpart limit to -1 to enable trailing empty
character in splitpart list
- reorganize fold constant of string functions in fe and add more cases
morrySnow pushed a commit that referenced this pull request Jan 9, 2025
…re cases (#45233) (#46525)

pick: #45233 

Issue Number: #44666
Related PR: #40441

Problem Summary:
- select substring_index('哈哈哈AAA','A', 1); String.split function has
second parameter 'limit', which is default zero. When 'limit' is zero,
it means it would remove trailing empty strings split of '哈哈哈AAA', which
would be '哈哈哈' only. But what we expect is '哈哈哈', '','','' when part
function is used by substring index. So we should change splitpart limit
to -1 to enable trailing empty character in splitpart list
- reorganize fold constant of string functions in fe and add more cases

---------

Co-authored-by: Mryange <[email protected]>
morrySnow pushed a commit that referenced this pull request Jan 9, 2025
…s and add more cases #45233 (#46523)

pick: #45233
Issue Number: #44666
Related PR: #40441

Problem Summary:
- select substring_index('哈哈哈AAA','A', 1); String.split function has
second parameter 'limit', which is default zero. When 'limit' is zero,
it means it would remove trailing empty strings split of '哈哈哈AAA', which
would be '哈哈哈' only. But what we expect is '哈哈哈', '','','' when part
function is used by substring index. So we should change splitpart limit
to -1 to enable trailing empty character in splitpart list
- reorganize fold constant of string functions in fe and add more cases

---------

Co-authored-by: Mryange <[email protected]>
morrySnow added a commit that referenced this pull request Mar 7, 2025
…#48783)

### What problem does this PR solve?

Related PR: #40441

Problem Summary:

The delimiters in split-related string functions that have special
meanings in regular expressions should be escaped.

.$|()[{^?*+\
github-actions bot pushed a commit that referenced this pull request Mar 7, 2025
…#48783)

### What problem does this PR solve?

Related PR: #40441

Problem Summary:

The delimiters in split-related string functions that have special
meanings in regular expressions should be escaped.

.$|()[{^?*+\
morrySnow added a commit that referenced this pull request Mar 10, 2025
…m by mistake #48783

pick from master #48783

Related PR: #40441

Problem Summary:

The delimiters in split-related string functions that have special
meanings in regular expressions should be escaped.

.$|()[{^?*+\
morrySnow pushed a commit that referenced this pull request Mar 11, 2025
…48895)

### What problem does this PR solve?

Related PR: #40441

Problem Summary:

if source string do not contains delim, split_part should return NULL
github-actions bot pushed a commit that referenced this pull request Mar 11, 2025
…48895)

### What problem does this PR solve?

Related PR: #40441

Problem Summary:

if source string do not contains delim, split_part should return NULL
github-actions bot pushed a commit that referenced this pull request Mar 11, 2025
…48895)

### What problem does this PR solve?

Related PR: #40441

Problem Summary:

if source string do not contains delim, split_part should return NULL
morrySnow pushed a commit that referenced this pull request Mar 21, 2025
…ter by mistake (#49087)

### What problem does this PR solve?

Related PR: #40441

Problem Summary:

wrong calculation of emoji character length in some String function when
do constant folding in FE. For example:

select STRLEFT('😊😉👍', 2);

should return 😊😉, but fe return 😊 only when folding constant

fixed functions:
- left
- strleft
- right
- strright
- locate
- character_length
- split_by_string
- overlay
- replace_empty
LiBinfeng-01 added a commit to LiBinfeng-01/doris that referenced this pull request Mar 21, 2025
…ter by mistake (apache#49087)

Related PR: apache#40441

Problem Summary:

wrong calculation of emoji character length in some String function when
do constant folding in FE. For example:

select STRLEFT('😊😉👍', 2);

should return 😊😉, but fe return 😊 only when folding constant

fixed functions:
- left
- strleft
- right
- strright
- locate
- character_length
- split_by_string
- overlay
- replace_empty
LiBinfeng-01 added a commit to LiBinfeng-01/doris that referenced this pull request Mar 21, 2025
…ter by mistake (apache#49087)

Related PR: apache#40441

Problem Summary:

wrong calculation of emoji character length in some String function when
do constant folding in FE. For example:

select STRLEFT('😊😉👍', 2);

should return 😊😉, but fe return 😊 only when folding constant

fixed functions:
- left
- strleft
- right
- strright
- locate
- character_length
- split_by_string
- overlay
- replace_empty
LiBinfeng-01 added a commit to LiBinfeng-01/doris that referenced this pull request Mar 21, 2025
…ter by mistake (apache#49087)

Related PR: apache#40441

Problem Summary:

wrong calculation of emoji character length in some String function when
do constant folding in FE. For example:

select STRLEFT('😊😉👍', 2);

should return 😊😉, but fe return 😊 only when folding constant

fixed functions:
- left
- strleft
- right
- strright
- locate
- character_length
- split_by_string
- overlay
- replace_empty
LiBinfeng-01 added a commit to LiBinfeng-01/doris that referenced this pull request Mar 21, 2025
…ter by mistake (apache#49087)

Related PR: apache#40441

Problem Summary:

wrong calculation of emoji character length in some String function when
do constant folding in FE. For example:

select STRLEFT('😊😉👍', 2);

should return 😊😉, but fe return 😊 only when folding constant

fixed functions:
- left
- strleft
- right
- strright
- locate
- character_length
- split_by_string
- overlay
- replace_empty
yiguolei pushed a commit that referenced this pull request Mar 21, 2025
…emoji character by mistake #49087 (#49344)

pick: #49087 
Related PR: #40441

Problem Summary:

wrong calculation of emoji character length in some String function when
do constant folding in FE. For example:

select STRLEFT('😊😉👍', 2);

should return 😊😉, but fe return 😊 only when folding constant

fixed functions:
- left
- strleft
- right
- strright
- locate
- character_length
- split_by_string
- overlay
- replace_empty
morrySnow added a commit that referenced this pull request Mar 25, 2025
github-actions bot pushed a commit that referenced this pull request Mar 25, 2025
github-actions bot pushed a commit that referenced this pull request Mar 25, 2025
yiguolei pushed a commit that referenced this pull request Mar 26, 2025
dataroaring pushed a commit that referenced this pull request Mar 27, 2025
…emoji character by mistake #49087 (#49346)

pick: #49087 

Related PR: #40441

Problem Summary:

wrong calculation of emoji character length in some String function when
do constant folding in FE. For example:

select STRLEFT('😊😉👍', 2);

should return 😊😉, but fe return 😊 only when folding constant

fixed functions:
- left
- strleft
- right
- strright
- locate
- character_length
- split_by_string
- overlay
- replace_empty
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by one committer. dev/2.1.7-merged dev/3.0.3-merged reviewed
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants