StarRocks version 3.3
- After upgrading StarRocks to v3.3, DO NOT downgrade it directly to v3.2.0, v3.2.1, or v3.2.2, otherwise it will cause metadata loss. You must downgrade the cluster to v3.2.3 or later to prevent the issue.
- After upgrading StarRocks to v3.3.9, you can only downgrade it to v3.2.11 or later.
3.3.19
Release Date: October 14, 2025
Bug Fixes
The following issues have been fixed:
- UserPropertyhad lower priority than Session Variables. #63173
- Materialized view refresh failures that could occur when the Hive base table was dropped and recreated. #63072
- Issues with the aggregation pushdown rewrite rule. #63060
- Inconsistencies between null columns and data columns in Boolean extraction functions for JSON. #63054
- Issues when getting partition columns in Delta Lake format tables. #62953
- Lack of colocation support for materialized views in shared-data clusters. #62941
- Projection mapping errors in view-based materialized view rewrite. #62918
- SQL syntax errors in histogram statistics when Most Common Values (MCV) contained single quotes. #62853
- KILL ANALYZEdid not work. #62842
- CVE-2025-58056 vulnerability. #62801
- Executing SHOW CREATE ROUTINE LOADwithout specifying a database causes wrong results. #62745
- Data loss caused by incorrectly skipping CSV headers in files(). #62719
- Version check failures when Replication and Compaction transactions were committed together. #62663
- Materialized view refresh is skipped because the materialized view version map is not cleared after a failed restore job. #62634
- Issues caused by case-sensitive partition column validation in the materialized view analyzer. #62598
3.3.18
Release Date: August 28, 2025
Bug Fixes
The following issues have been fixed:
- BE crashes when LakePersistentIndexinitialization failed due to cleanup of_memtable. #62279
- A concurrency issue caused by missing locks when retrieving the maximum Tablet version in the replication transaction manager. #62238
- A hang issue in the phased scheduler, which waited indefinitely during synchronous Profile collection (after the fix, the system correctly terminates Profile collection when scheduling errors occur). #62140
- Exception handling issues in low-cardinality optimization under the ALLOW_THROW_EXCEPTIONmode (after the fix, exceptions in expression evaluation are properly caught and returned). #62098
- FThe system failed to compute nested CTE statistics outside of the memo during table pruning when enable_rbo_table_prunewas set tofalse. #62070
- CVE-2025-55163 issue. #62041
- An issue where split_morsel_queuenested insidepartition_morsel_queuefailed to correctly receive the Tablet Schema. #62034
- Incorrect handling of NULLarrays during Parquet writes, which could cause data inconsistency or crashes (after the fix, the system ensures thesplitfunction can correctly handleNULLinput strings). #61999
- Failure when creating materialized views using CASE WHENexpressions due to incompatible return types of VARCHAR (after the fix, the system ensures consistency before and after refresh). #61996
- A concurrency safety issue caused by long operations holding shard-level locks while calculating compression scores. #61899
- An incomplete table pruning issue in CBO caused by pruning logic not considering all relevant predicates. #61881
3.3.17
Release Date: July 30, 2025
Bug Fixes
The following issues have been fixed:
- Upgraded HttpClient5 to 5.4.3. #61298
- Incorrect cpu_core_used_permillelimit in resource groups. #61177
- Conflict between ALTER jobs and partition creation tasks. #61167
- NPE caused by missing globalStateMgrinConnectContext. #60880
- Partition creation failed when partition names matched case-insensitively but had different values. #60909
- Lock competition caused by synchronous access to partition statistics. #61041
- ANALYZE tasks stuck in pendingstate after FE restart. #61113
- Issue with JIT (Just-In-Time) compilation in BE. #61060
- Leader address issue in Starmgr. #61016
- CVE vulnerabilities in Broker. #60908
- Actual number of JDBC connections exceeded jdbc_connection_pool_sizelimit. #61004
- CVE-2022-41404 vulnerability. #59689
- CVEs related to Parquet and HttpClient5. #58750
- Partition not removed from _partition_mapwhen physical partition ID was empty. #60842
- Missing version check in shared-data clusters. #59422
- Transaction log missing when publishing logs in batches in shared-data clusters. #60949
- Concurrent publishing of the same transaction when Batch Publish is enabled in shared-data clusters. #57574
- Statistics overwrite issue caused by lack of semi-synchronous mode. #60897
- Inaccurate maxInstantTimeused for filtering Hudi files when retrieving latest merged file slices. #60927
- TaskRun state incompatible with earlier versions. #60438
- CVE-2025-52999 vulnerability. #60795
- Vulnerability caused by log4j-1.2.17-cloudera6in Broker. #59579
- BE crash when loading OOM partitions. #60778
- Base Compaction tasks blocking other compaction tasks. #60711
- Inefficient handling of error string truncation. #60878
- Materialized view rewrite failed in multi-FE environments. #60841
- INSERT OVERWRITE failed on manually created partitions. #60750
- Issue caused by using random distribution in aggregate keys. #60702
- Crash caused by low cardinality rewrite in multi_distinct_count. #60664
- Issue with Pivot resolving fields. #60748
- Upgraded hudi-commonto 1.0.2. #59501
- BE crash when CLONE and DROP TABLE run concurrently. #61359
3.3.16
Release Date: July 4, 2025
Improvements
- Optimized error logs when creating Hive tables with duplicate names. #60076
- Added the FE parameter slow_lock_print_stackto prevent process stalls in large clusters when printing thread stacks. #59967
- Reduced unnecessary locks during tablet scheduling. #59744
Bug Fixes
Fixed the following issues:
- SplitOR fails to prune scan columns. #60223
- Incorrect query plan for null-aware left anti joins. #60119
- Incorrect query results when rewriting queries with materialized views due to missing NULL partitions. #60087
- Partition pruning errors when tables contain empty partitions. #60162
- Refresh errors on Iceberg external tables when using partition expressions based on str2date. #60089
- Unexpected behavior caused by materialized view schema changes. #60079
- Issues related to low-cardinality global dictionaries in UNION operators. #60075
- Incorrect partition ranges for temporary partitions created using the START END syntax. #60014
- Lock issues with SUBMIT TASK. #60026
- Partial updates fail on Primary Key tables under certain conditions. #60052
- Crashes caused by BE failing to create directories due to a lack of permissions to access storage paths. #60028
- Cache failures due to cache key duplication in concurrent scenarios. #60053
- Hive table metadata background refresh failure in Unified Catalog. #55215
- Query failures caused by incorrect return types of CASE WHEN. #59972
- Query failures when Delta Lake tables UNION themselves. #60030
- Partition creation failure when writing to multiple tables within the same transaction. #59954
- Queries could return empty results instead of errors when tablet versions were updated during execution. #53060
- Queries against modified columns in a table return null after upgrading to v3.4. #59941
- Authentication information is printed in logs. #59907
- Metadata refresh failures for external tables in Hive Catalog. #54596
- CACHE SELECT failures for tables after schema changes. #59812
- Broker Load could not recover after FE Leader shifts. #59732
- Stream Load failures when the target table name contains Chinese characters. #59722
- Incorrect query results in external tables due to search key hash collisions (affecting Iceberg/Delta/Paimon). #59781
3.3.15
Release Date: Jun 20, 2025
Bug Fixes
Fixed the following issues:
- Missing double quotes for string parameters in statistics INSERT statements. #59713
- Downgrade failure caused by Rollup tasks. #59735
- Incorrect function parameters in the result of SHOW CREATE VIEW. #59714
- A security issue where SQL statements with syntax errors exposed sensitive information in the Audit Log. #59442
- Error "Query version not found". #59194
- Failure to change data distribution using the ALTER TABLEstatement. #59360
- An issue where root user processes were still visible when admin protection was enabled. #59435
- Failure of INSERT OVERWRITEinto Hive. #59469
- Missing Tablet ID in the max_tablet_rowset_numlog item. #59467
- An error caused by misconfigured Persistent Index parameters on a Duplicate table. #56040
- TaskRun history being archived on FE Follower nodes. #59393
- External catalog-based materialized view refresh errors. #59369
- Missing minimum version in Tablet information on shared-data clusters. #59373
- Abnormal maximum column unique ID in native tables of shared-data clusters due to version compatibility logic errors. #59190
- Materialized view refresh failure on Iceberg catalogs when the source Iceberg table is dropped and recreated, and manual refresh also fails after the materialized view is set to active. #59287
- Contamination of parameters in materialized view refresh tasks. #59052
- Data loss caused by Persistent Index when loading snapshot fails. #59247
- Issues caused when subcolumns of STRUCT appear in multiple predicates. #59216
- Query failure after renaming columns. #59178
- Loading failure due to multiple Stream Load requests. #59181
- Inability to refresh Hive table-based materialized views at the partition level in Unified Catalog. #59139
- Incorrect UNION plan causing FE out-of-memory (OOM). #59030
- Version loss during data loading. #59006
- Predicate loss when queries are rewritten to synchronous materialized views. #58831
- Issues with BITMAP/HLL/PERCENTILE data types in window functions. #58776
- Metadata changes to the external tables in Hive Catalog cannot be refreshed. #54596
Behavior Changes
- Introduced FE configuration parameter task_runs_max_history_numberto control the number of historical TaskRuns retained in theinformation_schema.task_runsview, reducing memory usage. #59161
3.3.14
Release Date: May 14, 2025
Improvements
- Optimized error messages for regex parsing failures. #57904
- Fixed security vulnerabilities SNYK-JAVA-ORGJSON-5488379 and SNYK-JAVA-ORGJSON-5962464. #58425
Bug Fixes
Fixed the following issues:
- Issues with the JSON data type in first_value/last_value/lead/lagwindow functions. #58697
- Deadlock caused by table-level locks from base tables during materialized view writes (after the bug fix, DB-level locks are used). #58615
- INSERT tasks hang when the target table is deleted. #58603
- Failure to change active/inactive state of materialized views with List partitions. #58575
- Incorrect streaming_load_current_processingmetric. #58565
- Data version update errors caused by continuous loading and replica clone tasks. #58513
- Failed to refresh materialized views on external tables. #58506
- Incorrect if()results on ARM architecture. #58455
- Materialized view rewriting generated incorrect query plans. #58487
- Iceberg table metadata did not refresh automatically. #58490
- Incorrect query plan generated by group_concat. #57908
- Mass Tablet load failures caused by unhandled exceptions during loading. #58393
- Constant folding failed due to type mismatches while pruning List partitions with generated columns (after the bug fix, an implicit cast rule was added). #54543
- Mismatch between aggregate function return type and original column type (after the bug fix, the column type is castto the function output type). #58407
- broadcast_row_limitset to 0 or below failed to prevent BROADCAST JOIN generation. #58307
- Broker Load used BE nodes that had already been blacklisted. #58350
- Asynchronous tasks persist in the background and cannot be dropped after manually cancelling materialized view refresh tasks. #58310
- Failed to create expression partitions with month or year granularity. #58182
- ngram_searchgenerated invalid query plans. #58190
3.3.13
Release Date: April 22, 2025
Improvements
- Added memory consumption metrics for queries in FE in audit logs and the QueryDetail interface. #57731
- Optimized the strategy for concurrent creation of expression partitions. #57899
- Added monitoring metrics for the number of active FE nodes. #57857
- The information_schema.task_runsview supports pushdown of the LIMIT clause. #57404
- Fixed several CVE issues. #57705 #57620
- Primary Key tables support retry during the PUBLISH stage, enhancing system disaster recovery capabilities. #57354
- Reduced memory consumption of Flat JSON. #57357
- The information_schema.routine_load_jobsview adds thetimestamp_progresscolumn, consistent with the SHOW ROUTINE LOAD statement return. #57123
- Disallowed unauthorized behaviors from StarRocks to LDAP. #57131
- Supports returning an error when the schema of an AVRO file does not match the schema of the Hive table. #57296
- Materialized views support the excluded_refresh_tablesproperty. #56428
Bug Fixes
Fixed the following issues:
- Flat JSON does not support the get_json_boolfunction. #58077
- SHOW AUTHENTICATION statement returns the password. #58072
- The percentile_countfunction returns incorrect values. #58038
- Issues caused by spilling strategies. #58022
- After a BE is blacklisted, Stream Load still dispatches tasks to the BE, causing task failures. #57919
- Issues when using the castfunction with semi-structured data types. #57804
- The array_mapfunction returns incorrect values. #57756
- In the scenario of a single tablet, using multiple distinctfunctions on the same column with a single-column GROUP BY clause leads to incorrect query results. #57690
- MIN/MAX values in the profiles of big queries are inaccurate. #57655
- Non-partitioned materialized views based on Delta Lake data cannot rewrite queries. #57686
- A Routine Load deadlock issue. #57430
- Predicate pushdown issues with DATE/DATETIME columns. #57576
- An issue when the percentile_discfunction has an empty input. #57572
- When modifying the bucket distribution of a table with the statement ALTER TABLE {table} PARTITIONS (p1, p1) DISTRIBUTED BY ..., specifying duplicate partition names could result in failure to delete internally generated temporary partitions. #57005
- ALTER TABLE MODIFY COLUMN fails with expression partitioned tables based on str2datefunction. #57487
- CACHE SELECT issue with semi-structured columns. #57448
- Upgrade compatibility issue caused by hadoop-lib. #57436
- Case sensitivity error issues when creating partitions. #54867
- Some columns generate incorrect sort keys during updates. #57375
- Unknown issues caused by nested window functions . #57216
3.3.12
Release date: April 3, 2025
New Features
- Supports the percentile_approx_weightedfunction. #56654
- Supports modifying properties of Hive Catalog and Hudi Catalog. #56212
- Paimon Catalog supports manifest cache. #55788
- Supports SHOW PARTITIONSfor tables in Paimon Catalog. #55785
- Supports statistics collection for Paimon Catalog. #55757
Improvements
- Various improvements and bug fixes related to statistics. #57147 #57238 #57170 #57154 #57124 #57047 #56956 #57031 #56904 #56950 #56671 #55922
- Optimized error messages when table creation fails. #57055
- Enhanced retry mechanism for Broker Load. #56987
- Improved performance of array_generate. #57252
- Aborted ongoing Compaction tasks for deleted partitions. #56943
- Optimized error messages when ALTER TABLEfails. #57054
- Removed unnecessary reverse step from array_agg()to improve performance. #56958
- Added checksum verification for replicas in Primary Key tables. #56519
- Masked sensitive information in the FILESfunction output. #56684
- Reduced noisy logs related to materialized views. #56672
- Upgraded Iceberg version to 1.7.1. #55271
Bug Fixes
- INSERT INTO FILESdid not support CSV delimiter conversion. #57126
- Issues with Iceberg REST Catalog. #55416
- Predicate was lost during rewrite for view-based materialized views. #57153
- Paimon Catalog failed to read tables with schema changes. #56796
- Timezone conversion issue in Paimon Catalog. #56879
- SHOW MATERIALIZED VIEWSdid not display- default_cataloginformation. #56362
- In Trino dialect mode, time strings containing 'T' were not accepted. (Solution: replaced parse_datetimewithstr_to_jodatime.) #56565
- Incorrect result of first_valuefunction. #56467
- Incorrect result of concat_wsfunction. #56384
Behavior Changes
- Added authentication to the FE Profile interface. #56914
- Changed default value of session variable big_query_profile_thresholdfrom0to30. #56520
3.3.11
Release date: March 7, 2025
New Features
- Window functions support max_byandmin_by. #54961
Improvements
- Filessupports exporting JSON type data into Parquet files. #56406
- Optimized Data Cache WarmUp performance for cloud-native tables in shared-data clusters. #56190
- Supports parsing AT TIME ZONEexpressions and thefrom_iso8601_timestampfunction in Trino. #56311 #55573
- Partial Updates for Primary Key tables within shared-data clusters supports Condition Updates. #56132
- Extended support for statistics collection across all types of SQL statements. #56257
- Supports configuring the maximum number of returned rows for SHOW PROC '/transaction'. #55933
- Supports creating asynchronous materialized views on Oracle-type JDBC Catalog tables. #55372
- MemTracker on BE WebUI supports pagination with 25 rows per page. #56206
- Supports pushdown for subfields of complex types in table functions. #55425
- Supports LDAP login for MariaDB clients. #55720
- Upgraded Paimon version to 1.0.1. #54796 #55760
- Eliminates unnecessary unnestcomputations during query execution to reduce overhead. #55431
- Supports enabling Compaction for source clusters that are in the shared-data mode during cross-cluster synchronization. #54787
- Brings high-cost operations like DECIMAL division forward in topN computations to reduce overhead. #55417
- Optimized performance under ARM architecture. #55072 #55510
- For Hive table-based materialized views, StarRocks will perform checks and refreshes on the updated partitions only instead of full table refreshes if the base table was dropped and recreated. #45118
- DELETE operations support partition pruning. #55400
- Optimized priority strategy for collecting internal table statistics to improve efficiency when there are excessive tables. #55446
- When data loading involves multiple partitions, StarRocks merges transaction logs to improve loading performance. #55143
- Optimized error messages for SQL Translation. #55327
- Added a session variable parallel_merge_late_materialization_modeto control parallel merge behavior. #55082
- Optimized error messages for generated columns. #54949
- Optimized performance of SHOW MATERIALIZED VIEWS. #54374
Bug Fixes
Fixed the following issues:
- FE does not support casting constant TIME data types into DATETIME. #55804
- Stream Load transaction interface does not support the starrocks_fe_table_load_rowsandstarrocks_fe_table_load_bytesmetrics. #44991
- Changes to automatic statistics collection do not take effect. #56173
- Materialized views in abnormal states caused issues with SHOW MATERIALIZED VIEWS. #55995
- Text-based materialized view rewrite does not work across different databases. #56001
- Metadata compatibility issues in JDBC Catalogs. #55993
- Issues of handling the JSON data type in JDBC Catalogs. #56008
- Incorrect Sort Key settings during Schema Change. #55902
- Credential information leak issue in Broker Load. #55358
- An error caused by pushing down LIMIT before predicates in CTE. #55768
- An error caused by table schema changes in Stream Load. #55773
- A privilege issue due to the execution plan of DELETE statements containing SELECT. #55695
- An issue caused by not aborting compaction tasks when shutting down CN. #55503
- Follower FE nodes unable to fetch updated loading statistics. #55758
- Incorrect capacity statistics for the spill directory. #55703
- Failed to create materialized views due to lack of sufficient partition checks for base tables with list partitions. #55673
- An issue caused by missing metadata locks in ALTER TABLE. #55605
- An error in SHOW CREATE TABLEcaused by constraints. #55592
- OOM due to large ARRAY in Nestloop Join. #55603
- Lock issue with DROP PARTITION. #55549
- An issue with min/max window functions due to not supporting string types. #55537
- Parser performance degraded. #54830
- Column name case sensitivity issue during partial updates. #55442
- Import failures when Stream Load is scheduled on nodes with an "Alive" state of false. #55371
- Incorrect output column order in materialized views containing ORDER BY. #55355
- BE crashes due to disk failure. #55042
- Incorrect query results caused by Query Cache. #55287
- Parquet Writer fails to convert time zone when writing TIMESTAMP type with time zones. #55194
- Loading tasks hang due to ALTER job timeout. #55207
- An error caused by date_formatfunction when input is in milliseconds. #54854
- Materialized view rewrite failure caused by Partition Key being of DATE type. #54804
Behavior Changes
- Added authentication to the query_detailinterface in FE. #55919
- The UUID type in Iceberg now maps to BINARY. #54978
- Uses changed row count instead of the visible time of partitions to determine if statistics need to be recollected. #55373
3.3.10 (Yanked)
Release date: February 21, 2025
This version has been taken offline due to metadata loss issues in shared-data clusters.
- 
Problem: When there are committed compaction transactions that are not yet been published during a shift of Leader FE node in a shared-data cluster, metadata loss may occur after the shift. 
- 
Impact scope: This problem only affects shared-data clusters. Shared-nothing clusters are unaffected. 
- 
Temporary workaround: When the Publish task is returned with an error, you can execute SHOW PROC 'compactions'to check if there are any partitions that have two compaction transactions with emptyFinishTime. You can executeALTER TABLE DROP PARTITION FORCEto drop the partitions to avoid Publish tasks getting hang.
3.3.9
Release date: January 12, 2025
New Features
- Supports the translation of Trino SQL into StarRocks SQL. #54185
Improvements
- Corrected FE node names starting with bdbje_reset_election_groupto enhance clarity. #54399
- Implemented vectorization for the IFfunction on ARM architectures. #53093
- ALTER SYSTEM CREATE IMAGEsupports creating an image for StarManager. #54370
- Supports deleting cloud-native indexes of Primary Key tables in shared-data clusters. #53971
- Enforced the refresh of materialized views when the FORCEkeyword is specified. #52081
- Supports specifying hints in CACHE SELECT. #54697
- Supports loading compressed CSV files using the FILES()function. Supported compression formats include gzip, bz2, lz4, deflate, and zstd. #54626
- Supports assigning multiple values to the same column in an UPDATEstatement. #54534
Bug Fixes
Fixed the following issues:
- Unexpected errors when refreshing materialized views built on JDBC catalogs. #54487
- Instability in results when a Delta Lake table joins itself. #54473
- Upload retries fail when backing up data to HDFS. #53679
- BFD initialization errors on the aarch64 architecture. #54372
- Sensitive information recorded in BE logs. #54677
- Errors in Compaction-related metrics in profiles. #54678
- BE crashes caused by creating tables with nested TIMEtypes. #54601
- Query plan errors for LIMITqueries with subquery TOP-N. #54507
Downgrade notes
- Clusters can be downgraded from v3.3.9 only to v3.2.11 and later.
3.3.8
Release date: January 3, 2025
Improvements
- Added a cluster idle API to assist in determining cluster status. #53850
- Included node information and histogram metrics in JSON metrics. #53735
- Optimized the MemTable for Primary Key tables in shared-data clusters. #54178
- Optimized memory usage and statistics for Primary Key tables in shared-data clusters. #54358
- Introduced a limit on the number of partitions scanned per node for queries requiring full-table or large-scale partition scans, enhancing system stability by reducing scanning pressure on individual BE or CN nodes. #53747
- Supports collecting statistics of Paimon tables. #52858
- Supports configuration of S3 client request timeout for shared-data clusters. #54211
Bug Fixes
Fixed the following issues:
- BE crashes caused by inconsistencies in the DelVec of Primary Key tables. #53460
- Issues with lock release of Primary Key tables in shared-data clusters. #53878
- Errors of UDFs nested in functions are not returned in query failures. #44297
- Transactions are blocked at the Decommission phase because they depend on the original replicas. #49349
- Queries against Delta Lake tables use relative paths instead of filenames for file retrieval. #53949
- An error is returned when querying Delta Lake Shallow Clone tables. #54044
- Case sensitivity issues when reading Paimon using JNI. #54041
- An error is returned during INSERT OVERWRITEoperations on Hive tables created in Hive. #53792
- SHOW TABLE STATUScommand does not validate view privileges. #53811
- Missing FE metrics. #53058
- Memory leaks in INSERTtasks. #53809
- Concurrency issues caused by missing write locks in replication tasks. #54061
- partition_ttlof tables in the- statisticsdatabase does not take effect. #54398
- Query Cache-related issues:
- Issues with materialized view Union Rewrite. #54293
- Missing padding in string updates for partial updates in Primary Key tables. #54182
- Incorrect execution plans for max(count(distinct))when low-cardinality optimization is enabled. #53403
- Issues with changing the excluded_refresh_tablesparameter of materialized views. #53394
Behavior Changes
- Changed the default value of persistent_index_typefor Primary Key tables in shared-data clusters toCLOUD_NATIVE, that is, enabled Persistent Index by default. #52209
3.3.7
Release date: November 29, 2024
New Features
- Added a new Materialized View parameter, excluded_refresh_tables, exclude tables that need to be refreshed. #50926
Improvements
- Rewrote unnest(bitmap_to_array)asunnest_bitmapto improve performance. #52870
- Reduced the write and delete operations of Txn logs. #42542
Bug Fixes
Fixed the following issues:
- Failure to connect Power BI to external tables. #52977
- Misleading FE Thrift RPC failure messages in logs. #52706
- Routine Load tasks were canceled due to expired transactions (now tasks are canceled only if the database or table no longer exists). #50334
- Stream Load failures when submitted using HTTP 1.0. #53010 #53008
- Integer overflow of partition IDs. #52965
- Hive Text Reader failed to recognize the last empty element. #52990
- Issues caused by array_mapin Join conditions. #52911
- Metadata cache issues under high concurrency scenarios. #52968
- The whole materialized view was refreshed when a partition was dropped from the base table. #52740
3.3.6
Release date: November 18, 2024
Improvements
- Optimized internal repair logic for Primary Key tables. #52707
- Optimized the internal implementation of histograms of statistics. #52400
- Supports adjusting log level via the FE configuration item sys_log_warn_modulesto reduce Hudi Catalog logging. #52709
- Supports constant folding in the yearweekfunction. #52714
- Avoided push-down for Lambda functions. #52655
- Divided the Query Error metric into three: Internal Error Rate, Analysis Error Rate, and Timeout Rate. #52646
- Avoided constant expressions being extracted as common expressions within array_map. #52541
- Optimized the Text-based Rewrite of materialized views. #52498
Bug Fixes
Fixed the following issues:
- The unique_constraintsandforeign_constraintsparameters were incomplete in SHOW CREATE TABLE for cloud-native tables in shared-data clusters. #52804
- Some materialized views were activated even when enable_mv_automatic_active_checkwas set tofalse. #52799
- Memory usage is not reducing after stale memory flush. #52613
- Resource leak caused by Hudi file-system views. #52738
- Concurrent Publish and Update operations on Primary Key tables may cause issues. #52687
- Failures to terminate queries on clients. #52185
- Multi-column List partitions cannot be pushed down. #51036
- Incorrect result due to the lack of hasnullproperty in ORC files. #52555
- An issue caused by using uppercase column names in ORDER BY during table creation. #52513
- An error was returned after running ALTER TABLE PARTITION (*) SET ("storage_cooldown_ttl" = "xxx"). #52482
Behavior Changes
- 
In earlier versions, scale-in operations would fail if there were insufficient replicas for views in the _statistics_database. Starting from v3.3.6, if nodes are scaled in to 3 or more, view replicas are set to 3; if there is only 1 node after the scale-in, view replicas are set to 1, allowing for successful scale-in. #51799Affected views include: - column_statistics
- histogram_statistics
- table_statistic_v1
- external_column_statistics
- external_histogram_statistics
- pipe_file_list
- loads_history
- task_run_history
 
- 
New Primary Key tables no longer allow __opas a column name, even ifallow_system_reserved_namesis set totrue. Existing tables are unaffected. #52621
- 
Expression-partitioned tables cannot have partition names modified. #52557 
- 
Deprecated FE parameters heartbeat_mgr_blocking_queue_sizeandprofile_process_threads_num. #52236
- 
Enabled persistent index on object storage by default for Primary Key tables in shared-data clusters. #52209 
- 
Disallowed manual changes to bucketing methods for tables with the random bucketing method. #52120 
- 
Backup and Restore-related parameter changes: #52111 - make_snapshot_worker_countsupports dynamic configuration.
- release_snapshot_worker_countsupports dynamic configuration.
- upload_worker_countsupports dynamic configuration. Its default value is changed from- 1to the number of CPU cores on the machine where the BE resides.
- download_worker_countsupports dynamic configuration. Its default value is changed from- 1to the number of CPU cores on the machine where the BE resides.
 
- 
The return type of SELECT @@autocommithas changed from BOOLEAN to BIGINT. #51946
- 
Added a new FE configuration item, max_bucket_number_per_partition, to control the maximum number of buckets per partition. #47852
- 
Enabled memory usage checks by default for Primary Key tables. #52393 
- 
Optimized loading strategy to reduce loading speed when Compaction tasks cannot be completed on time. #52269 
3.3.5
Release date: October 23, 2024
New Features
- Supports millisecond and microsecond precision in the DATETIME type.
- Resource groups support CPU hard isolation.
Improvements
- Optimized performance and extraction strategy for Flat JSON. #50696
- Reduced memory usage for the following ARRAY functions:
- Optimized error messages when loading Nullvalues into List partition keys with theNot Nullattribute. #51086
- Optimized error messages for Files() when authentication fails in the Files function. #51697
- Optimized internal statistics for INSERT OVERWRITE. #50417
- Shared-data clusters support garbage collection (GC) for persistent index files. #51684
- Added FE logs to help diagnose FE out-of-memory (OOM) issues. #51528
- Supports recovering metadata from the metadata directory of FE. #51040
Bug Fixes
Fixed the following issues:
- A deadlock issue caused by PIPE exceptions. #50841
- Dynamic partition creation failures block subsequent partition creation. #51440
- An error is returned for UNION ALLqueries withORDER BY. #51647
- CTE in UPDATE statements causes hints to be ignored. #51458
- The load_finish_timefield in the system-defined viewstatistics.loads_historydoes not update as expected after a loading task is completed. #51174
- UDTF mishandles multibyte UTF-8 characters. #51232
Behavior Changes
- Modified the return content of the EXPLAINstatement. After the change, the return content is equivalent toEXPLAIN COST. You can configure the level of details returned byEXPLAINusing the dynamic FE parameterquery_detail_explain_level. The default value isCOSTS, with other valid values beingNORMALandVERBOSE. #51439
3.3.4
Release date: September 30, 2024
New Features
- Supports creating asynchronous materialized views on List Partition tables. #46680 #46808
- List Partition tables now support Nullable partition columns. #47797
- Supports viewing external file schema information using DESC FILES(). #50527
- Supports viewing replication task metrics via SHOW PROC '/replications'. #50483
Improvements
- Optimized data recycling performance for TRUNCATE TABLEin shared-data clusters. #49975
- Supports intermediate result spilling for CTE operators. #47982
- Supports adaptive phased scheduling to alleviate OOM issues caused by complex queries. #47868
- Supports predicate pushdown for STRING-type date or datatime columns in specific scenarios. #50643
- Supports COUNT DISTINCT computation on constant semi-structured data. #48273
- Added a new FE parameter lake_enable_balance_tablets_between_workersto enable tablet balancing for tables in shared-date clusters. #50843
- Enhanced query rewrite capabilities for generated columns. #50398
- Partial Update now supports automatically populating columns with default values of CURRENT_TIMESTAMP. #50287
Bug Fixes
Fixed the following issues:
- The error "version has been compacted" caused by an infinite loop on the FE side during Tablet Clone. #50561
- ISO- formatted DATETIME types cannot be pushed down. #49358
- In concurrent scenarios, data still existed after the tablet was deleted. #50382
- Incorrect results returned by the yearweekfunction. #51065
- An issue with low cardinality dictionaries in ARRAY during CTE queries. #51148
- After FE restarts, partition TTL-related parameters were lost for materialized views. #51028
- Data loss in columns defined with CURRENT_TIMESTAMPafter upgrading. #50911
- A stack overflow caused by the array_distinctfunction. #51017
- Activation failures for materialized views after upgrading due to changes in default field lengths. You can avoid such issues by setting enable_active_materialized_view_schema_strict_checktofalse. #50869
- Resource group property cpu_weightcan be set to a negative value. #51005
- Incorrect statistics for disk capacity information. #50669
- Constant fold in the replacefunction. #50828
Behavior Changes
- Changed the default replica number for external catalog-based materialized views from 1to the value of the FE parameterdefault_replication_num(Default value:3). #50931
3.3.3
Release date: September 5, 2024
New Features
- Supports user-level variables. #48477
- Supports Delta Lake Catalog metadata cache with manual and periodic refresh strategies. #46526 #49069
- Supports loading JSON types from Parquet files. #49385
- JDBC SQL Server Catalog supports queries with LIMIT. #48248
- Shared-data clusters support Partial Updates with INSERT INTO. #49336
Improvements
- Optimized error messages for loading:
- When memory limits are reached during loading, the IP of the corresponding BE node is returned for easier troubleshooting. #49335
- Detailed messages are provided when CSV data is loaded to target table columns that are not long enough. #49713
- Specific node information is provided when Kerberos authentication fails in Broker Load. #46085
 
- Optimized the partitioning mechanism during data loading to reduce memory usage in the initial stage. #47976
- Optimized memory usage for shared-nothing clusters by limiting metadata memory usage to avoid issues when there are too many Tablets or Segment files. #49170
- Optimized the performance of queries using max(partition_column). #49391
- Partition pruning is used to optimize query performance when the partition column is a generated column (a column that is calculated based on a native column in the table), and the query predicate filter condition includes the native column. #48692
- Supports masking authentication information for Files() and PIPE. #47629
- Introduced a new statement show proc '/global_current_queries'to view queries running on all FE nodes.show proc '/current_queries'only shows queries running on the current FE node. #49826
Bug Fixes
Fixed the following issues:
- The source cluster's BE nodes were mistakenly added to the current cluster when exporting data to the destination cluster via StarRocks external tables. #49323
- TINYINT data type returned NULL when StarRocks reads ORC files using select * from filesfrom clusters deployed on aarch64 machines. #49517
- Stream Load fails when loading JSON files containing large Integer types. #49927
- Incorrect schema is returned due to improper handling of invisible characters when users load CSV files with Files(). #49718
- An issue with temporary partition replacement in tables with multiple partition columns. #49764
Behavior Changes
- Introduced a new parameter object_storage_rename_file_request_timeout_msto better accommodate backup scenarios with cloud object storage. This parameter will be used as the backup timeout, with a default value of 30 seconds. #49706
- to_json,- CAST(AS MAP), and- STRUCT AS JSONwill return NULL instead of throwing an error by default when the conversion fails. You can allow errors by setting the system variable- sql_modeto- ALLOW_THROW_EXCEPTION. #50157
3.3.2
Release date: August 8, 2024
New Features
- 
Supports renaming columns within StarRocks internal tables. #47851 
- 
Supports reading Iceberg views. Currently, only Iceberg views created through StarRocks are supported. #46273 
- 
[Experimental] Supports adding and removing fields of STRUCT-type data. #46452 
- 
Supports specifying the compression level for ZSTD compression format during table creation. #46839 
- 
Added the following FE dynamic parameters to limit table boundaries. #47896 Including: - auto_partition_max_creation_number_per_load
- max_partition_number_per_table
- max_bucket_number_per_partition
- max_column_number_per_table
 
- 
Supports runtime optimization of table data distribution, ensuring optimization tasks do not conflict with DML operations on the table. #43747 
- 
Added an observability interface for the global hit rate of Data Cache. #48450 
- 
Added the SQL function array_repeat. #47862 
Improvements
- 
Optimized the error messages for Routine Load failures due to Kafka authentication failures. #46136 #47649 
- 
Stream Load supports using \tand\nas row and column delimiters. Users do not need to convert them to their hexadecimal ASCII codes. #47302
- 
Optimized the asynchronous statistics collection method for write operators, addressing the issue of increased latency when there are many import tasks. #48162 
- 
Added the following BE dynamic parameters to control resource hard limits during loading, reducing the impact on BE stability when writing a large number of tablets. #48495 Including: - load_process_max_memory_hard_limit_ratio
- enable_new_load_on_memory_limit_exceeded
 
- 
Added consistency checks for Column IDs within the same table to prevent Compaction errors. #48498 
- 
Supports persisting PIPE metadata to prevent metadata loss due to FE restarts. #48852 
Bug Fixes
Fixed the following issues:
- The process could not end when creating a dictionary from an FE Follower. #47802
- Inconsistent information returned by the SHOW PARTITIONS command in shared-data clusters and shared-nothing clusters. #48647
- Data errors caused by incorrect type handling when loading data from JSON fields to ARRAY<BOOLEAN>columns. #48387
- The query_idcolumn ininformation_schema.task_runscannot be queried. #48876
- During Backup, multiple requests for the same operation are submitted to different Brokers, causing request errors. #48856
- Downgrading to versions earlier than v3.1.11 or v3.2.4 causes Primary Key table index decompression failures, leading to query errors. #48659
Downgrade Notes
If you have used the renaming column feature, you must rename the columns to their original names before downgrading your cluster to an earlier version. You can check the audit log of your cluster after upgrading to identify any ALTER TABLE RENAME COLUMN operations and the original names of the columns.
3.3.1 (Yanked)
Release date: July 18, 2024
This version has been taken offline due to compatibility issues in Primary Key tables.
- 
Problem: After the cluster is upgraded from versions earlier than v3.1.11 and v3.2.4 to v3.3.1, index decompression failures will lead to failures of queries against Primary Key tables. 
- 
Impact scope: This problem only affects queries against Primary Key tables. 
- 
Temporary workaround: You can downgrade the cluster to v3.3.0 or earlier to avoid this issue. It will be fixed in v3.3.2. 
New Features
- [Preview] Supports temporary tables.
- [Preview] JDBC Catalog supports Oracle and SQL Server.
- [Preview] Unified Catalog supports Kudu.
- INSERT INTO on Primary Key tables supports Partial Updates by specifying the column list.
- User-defined variables support the ARRAY type. #42631
- Stream Load supports converting JSON-type data and loading it into columns of STRUCT/MAP/ARRAY types. #45406
- Supports global dictionary cache.
- Supports deleting partitions in batch. #44744
- Supports managing column-level permissions in Apache Ranger. (Column-level permissions for materialized views and views must be set under the table object.) #47702
- Supports Partial Updates in Column mode For Primary Key tables in shared-data clusters. #46516
- Stream Load supports data compression during transmission, reducing network bandwidth overhead. Users can specify different compression algorithms using parameters compressionandContent-Encoding. Supported compression algorithms including GZIP, BZIP2, LZ4_FRAME, and ZSTD. #43732
Improvements
- Optimized the IdChain hashcode implementation to reduce the FE restart time. #47599
- Improved error messages for the csv.trim_spaceparameter in the FILES() function, checking for illegal characters and providing reasonable prompts. #44740
- Stream Load supports using \tand\nas row and column delimiters. Users do not need to convert them to their hexadecimal ASCII codes. #47302
Bug Fixes
Fixed the following issues:
- Schema Change failures due to file location changes caused by Tablet migration during the Schema Change process. #45517
- Cross-cluster Data Migration Tool fails to create tables in the target cluster due to control characters such as \,\rin the default values of fields. #47861
- Persistent bRPC failures after BE restarts. #40229
- The user_adminrole can change the root password using the ALTER USER command. #47801
- Primary key index write failures cause data write errors. #48045
Behavior Changes
- Intermediate result spilling is enabled by default when sinking data to Hive and Iceberg. #47118
- Changed the default value of the BE configuration item max_cumulative_compaction_num_singleton_deltasto500. #47621
- When users create a partitioned table without specifying the bucket number, if the number of partitions exceeds 5, the rule for setting the bucket count is changed to max(2*BE or CN count, bucket number calculated based on the largest historical partition data volume). The previous rule was to calculate the bucket number based on the largest historical partition data volume). #47949
- Specifying a column list in the INSERT INTO statement on a Primary Key table will perform Partial Updates instead of Full Upsert in earlier versions.
Downgrade notes
To downgrade a cluster from v3.3.1 or later to v3.2, users must clean all temporary tables in the cluster by following these steps:
- 
Disallow users to create new temporary tables: ADMIN SET FRONTEND CONFIG("enable_experimental_temporary_table"="false");
- 
Check if there are any temporary tables in the cluster: SELECT * FROM information_schema.temp_tables;
- 
If there are temporary tables in the system, clean them up using the following command (the SYSTEM-level OPERATE privilege is required): CLEAN TEMPORARY TABLE ON SESSION 'session';
3.3.0
Release date: June 21, 2024
New Features and Improvements
Shared-data Cluster
- 
Optimized the performance of Schema Evolution in shared-data clusters, reducing the time consumption of DDL changes to a sub-second level. For more information, see Schema Evolution. 
- 
To satisfy the requirement for data migration from shared-nothing clusters to shared-data clusters, the community officially released the StarRocks Data Migration Tool. It can also be used for data synchronization and disaster recovery between shared-nothing clusters. 
- 
[Preview] AWS Express One Zone Storage can be used as storage volumes, significantly improving read and write performance. For more information, see CREATE STORAGE VOLUME. 
- 
Optimized the garbage collection (GC) mechanism in shared-data clusters. Supports manual compaction for data in object storage. For more information, see Manual Compaction. 
- 
Optimized the Publish execution of Compaction transactions for Primary Key tables in shared-data clusters, reducing I/O and memory overhead by avoiding reading primary key indexes. 
- 
Supports Internal Parallel Scan within tablets. This optimizes query performance in scenarios where there are very few buckets in the table, which limits query parallelism to the number of tablets. Users can enable the Parallel Scan feature by setting the following system variables: SET GLOBAL enable_lake_tablet_internal_parallel = true;
 SET GLOBAL tablet_internal_parallel_mode = "force_split";
Data Lake Analytics
- Data Cache enhancements
- Added the Data Cache Warmup command CACHE SELECT to fetch hotspot data from data lakes, which speeds up queries and minimizes resource usage. CACHE SELECT can work with SUBMIT TASK to achieve periodic cache warmup. This feature supports both tables in external catalogs and internal tables in shared-data clusters.
- Added metrics and monitoring methods to enhance the observability of Data Cache.
 
- Parquet reader performance enhancements
- Optimized Page Index, significantly reducing the data scan size.
- Reduced the occurrence of reading unnecessary pages when Page Index is used.
- Uses SIMD to accelerate the computation to determine whether data rows are empty.
 
- ORC reader performance enhancements
- Uses column ID for predicate pushdown to read ORC files after Schema Change.
- Optimized the processing logic for ORC tiny stripes.
 
- Iceberg table format enhancements
- Significantly improved the metadata access performance of the Iceberg Catalog by refactoring the parallel Scan logic. Resolved the single-threaded I/O bottleneck in the native Iceberg SDK when handling large volumes of metadata files. As a result, queries with metadata bottlenecks now experience more than a 10-fold performance increase.
- Queries on Parquet-formatted Iceberg v2 tables support equality deletes.
 
- [Experimental] Paimon Catalog enhancements
- Materialized views created based on the Paimon external tables now support automatic query rewriting.
- Optimized Scan Range scheduling for queries against the Paimon Catalog, improving I/O concurrency.
- Support for querying Paimon system tables.
- Paimon external tables now support DELETE Vectors, enhancing query efficiency in update and delete scenarios.
 
- Enhancements in collecting external table statistics
- ANALYZE TABLE can be used to collect histograms of external tables, which helps prevent data skews.
- Supports collecting statistics of STRUCT subfields.
 
- Table sink enhancements
- The performance of the Sink operator is doubled compared to Trino.
- Data can be sunk to Textfile- and ORC-formatted tables in Hive catalogs and storage systems such as HDFS and cloud storage like AWS S3.
 
- [Preview] Supports Alibaba Cloud MaxCompute catalogs, with which you can query data from MaxCompute without ingestion and directly transform and load the data from MaxCompute by using INSERT INTO.
- [Experimental] Supports ClickHouse Catalog.
- [Experimental] Supports Kudu Catalog.
Performance Improvement and Query Optimization
- Optimized performance on ARM.
- Significantly optimized performance for ARM architecture instruction sets. Performance tests under AWS Graviton instances showed that the ARM architecture was 11% faster than the x86 architecture in the SSB 100G test, 39% faster in the Clickbench test, 13% faster in the TPC-H 100G test, and 35% faster in the TPC-DS 100G test.
 
- Spill to Disk is in GA. Optimized the memory usage of complex queries and improved spill scheduling, allowing large queries to run stably without OOM.
- [Preview] Supports spilling intermediate results to object storage.
- Supports more indexes.
- [Preview] Supports full-text inverted index to accelerate full-text searches.
- [Preview] Supports N-Gram bloom filter index to speed up LIKEqueries and the computation speed ofngram_searchandngram_search_case_insensitivefunctions.
 
- Improved the performance and memory usage of Bitmap functions. Added the capability to export Bitmap data to Hive by using Hive Bitmap UDFs.
- [Preview] Supports Flat JSON. This feature automatically detects JSON data during data loading, extracts common fields from the JSON data, and stores these fields in a columnar manner. This improves JSON query performance, comparable to querying STRUCT data.
- [Preview] Optimized global dictionary. Provides a dictionary object to store the mapping of key-value pairs from a dictionary table in the BE memory. A new dictionary_get()function is now used to directly query the dictionary object in the BE memory, accelerating the speed of querying the dictionary table compared to using thedict_mapping()function. Furthermore, the dictionary object can also serve as a dimension table. Dimension values can be obtained by directly querying the dictionary object usingdictionary_get(), resulting in faster query speeds than the original method of performing JOIN operations on the dimension table to obtain dimension values.
- [Preview] Supports Colocate Group Execution. Significantly reduces memory usage for executing Join and Agg operators on the colocate tables, which ensures that large queries can be executed more stably.
- Optimized the performance of CodeGen. JIT is enabled by default, which achieves a 5X performance improvement for complex expression calculations.
- Supports using vectorization technology to implement regular expression matching, which reduces the CPU consumption of the regexp_replacefunction.
- Optimized Broadcast Join so that the Broadcast Join operation can be terminated in advance when the right table is empty.
- Optimized Shuffle Join in scenarios of data skew to prevent OOM.
- When an aggregate query contains Limit, multiple Pipeline threads can share theLimitcondition to prevent compute resource consumption.
Storage Optimization and Cluster Management
- Enhanced flexibility of range partitioning. Three time functions can be used as partitioning columns. These functions convert timestamps or strings in the partitioning columns into date values and then the data can be partitioned based on the converted date values.
- FE memory observability. Provides detailed memory usage metrics for each module within the FE to better manage resources.
- Optimized metadata locks in FE. Provides Lock manager to achieve centralized management for metadata locks in FE. For example, it can refine the granularity of metadata lock from the database level to the table level, which improves load and query concurrency. In a scenario of 100 concurrent load jobs on a small dataset, the load time can be reduced by 35%.
- Supports adding labels on BEs. Supports adding labels on BEs based on information such as the racks and data centers where BEs are located. It ensures even data distribution among racks and data centers, and facilitates disaster recovery in case of power failures in certain racks or faults in data centers.
- Optimized the sort key. Duplicate Key tables, Aggregate tables, and Unique Key tables all support specifying sort keys through the ORDER BYclause.
- [Experimental] Optimized the storage efficiency of non-string scalar data. This type of data supports dictionary encoding, reducing storage space usage by 12%.
- Supports size-tiered compaction for Primary Key tables. Reduces write I/O and memory overhead during compaction. This improvement is supported in both shared-data and shared-nothing clusters. You can use the BE configuration item enable_pk_size_tiered_compaction_strategyto control whether to enable this feature (enabled by default).
- Optimized read I/O for persistent indexes in Primary Key tables. Supports reading persistent indexes by a smaller granularity (page) and improves the persistent index's bloom filter. This improvement is supported in both shared-data and shared-nothing clusters.
- Supports for IPv6. StarRocks now supports deployment on IPv6 networks.
Materialized Views
- Supports view-based query rewrite. With this feature enabled, queries against views can be rewritten to materialized views created upon those views. For more information, see View-based materialized view rewrite.
- Supports text-based query rewrite. With this feature enabled, queries (or their sub-queries) that have the same abstract syntax trees (AST) as the materialized views can be transparently rewritten. For more information, see Text-based materialized view rewrite.
- [Preview] Supports setting transparent rewrite mode for queries directly against the materialized view. When the transparent_mv_rewrite_modeproperty is enabled, StarRocks will automatically rewrite queries to materialized views. It will merge data from refreshed materialized view partitions with the raw data corresponding to the unrefreshed partitions using an automatic UNION operation. This mode is suitable for modeling scenarios where data consistency must be maintained while also aiming to control refresh frequency and reduce refresh costs. For more information, see CREATE MATERIALIZED VIEW.
- Supports aggregation pushdown for materialized view query rewrite: When the enable_materialized_view_agg_pushdown_rewritevariable is enabled, users can use single-table asynchronous materialized views with Aggregation Rollup to accelerate multi-table join scenarios. Aggregate functions will be pushed down to the Scan Operator during query execution and rewritten by the materialized view before the Join Operator is executed, significantly improving query efficiency. For more information, see Aggregation pushdown.
- Supports a new property to control materialized view rewrite. Users can set the enable_query_rewriteproperty tofalseto disable query rewrite based on a specific materialized view, reducing query rewrite overhead. If a materialized view is used only for direct query after modeling and not for query rewrite, users can disable query rewrite for this materialized view. For more information, see CREATE MATERIALIZED VIEW.
- Optimized the cost of materialized view rewrite. Supports specifying the number of candidate materialized views and enhanced the filter algorithms. Introduced materialized view plan cache to reduce the time consumption of the Optimizer at the query rewrite phase. For more information, see cbo_materialized_view_rewrite_related_mvs_limit.
- Optimized materialized views created upon Iceberg catalogs. Materialized views based on Iceberg catalogs now support incremental refresh triggered by partition updates and partition alignment for Iceberg tables using Partition Transforms. For more information, see Data lake query acceleration with materialized views.
- Enhanced the observability of materialized views. Improved the monitoring and management of materialized views for better system insights. For more information, see Metrics for asynchronous materialized views.
- Improved the efficiency of large-scale materialized view refresh. Supports global FIFO scheduling, optimized the cascading refresh strategy for nested materialized views, and fixed some issues that occur in high-frequency refresh scenarios.
- Supports refresh triggered by multiple fact tables. Materialized views created upon multiple fact tables now support partition-level incremental refresh when data in any of the fact tables is updated, increasing data management flexibility. For more information, see Align partitions with multiple base tables.
SQL Functions
- DATETIME fields support microsecond precision. The new time unit is supported in related time functions and during data loading.
- Added the following functions:
- String functions: crc32, url_extract_host, ngram_search
- Array functions: array_contains_seq
- Date and time functions: yearweek
- Math functions: cbrt
 
Ecosystem Support
- [Experimental] Provides ClickHouse SQL Rewriter, a new tool for converting the syntax in ClickHouse to the syntax in StarRocks.
- The Flink connector v1.2.9 provided by StarRocks is integrated with the Flink CDC 3.0 framework, which can build a streaming ELT pipeline from CDC data sources to StarRocks. The pipeline can synchronize the entire database, sharded tables, and schema changes in the sources to StarRocks. For more information, see Synchronize data with Flink CDC 3.0 (with schema change supported).
Behavior and Parameter Changes
Table Creation and Data Distribution
- Users must specify Distribution Key when creating a colocate table using CTAS. #45537
- When users create a non-partitioned table without specifying the bucket number, the minimum bucket number the system sets for the table is 16(instead of2based on the formula2*BE or CN count). If users want to set a smaller bucket number when creating a small table, they must set it explicitly. #47005
Loading and Unloading
- __opis reserved by StarRocks for special purposes and creating columns with names prefixed by- __opis forbidden by default. You can allow this such name format by setting FE configuration- allow_system_reserved_namesto- true. Please note that creating such columns in Primary Key tables may result in undefined behaviors. #46239
- During Routine Load jobs, if the time duration that StarRocks cannot consume data exceeds the threshold specified in the FE configuration routine_load_unstable_threshold_second(Default value is3600, that is one hour), the status of the job will becomeUNSTABLE, but the job will continue. #36222
- The default value of the FE configuration enable_automatic_bucketis changed fromfalsetotrue. When this item is set totrue, the system will automatically setbucket_sizefor newly created tables, thus enabling automatic bucketing, which is the optimized random bucketing feature. However, in v3.2, settingenable_automatic_buckettotruewill take effect. Instead, the system only enables automatic bucketing whenbucket_sizeis specified. This will prevent risks when users downgrade StarRocks from v3.3 to v3.2.
Query and Semi-structured Data
- When a single query is executed within the Pipeline framework, the memory limit is no longer restricted by exec_mem_limitbut is only limited byquery_mem_limit. A value of0forquery_mem_limitindicates no limit. #34120
- NULL values in JSON is treated as SQL NULL values when they are executed by IS NULL and IS NOT NULL operators. For example, parse_json('{"a": null}') -> 'a' IS NULLreturns1, andparse_json('{"a": null}') -> 'a' IS NOT NULLreturns0. #42765 #42909
- A new session variable cbo_decimal_cast_string_strictis added to control how CBO converts data from the DECIMAL type to the STRING type. If this variable is set totrue, the logic built in v2.5.x and later versions prevails and the system implements strict conversion (namely, the system truncates the generated string and fills 0s based on the scale length). If this variable is set tofalse, the logic built in versions earlier than v2.5.x prevails and the system processes all valid digits to generate a string. The default value istrue. #34208
- The default value of cbo_eq_base_typeis changed fromvarchartodecimal, indicating that the system will compare the DECIMAL-type data with strings as numerical values instead of strings. #43443
Others
- JDK 11 or later is required from StarRocks v3.3.0 onwards.
- The default value of the materialized view property partition_refresh_numhas been changed from-1to1. When a partitioned materialized view needs to be refreshed, instead of refreshing all partitions in a single task, the new behavior will incrementally refresh one partition at a time. This change is intended to prevent excessive resource consumption caused by the original behavior. The default behavior can be adjusted using the FE configurationdefault_mv_partition_refresh_number.
- Originally, the database consistency checker was scheduled based on GMT+8 time zone. Database consistency checker is scheduled based on the local time zone now. #45748
- By default, Data Cache is enabled to accelerate data lake queries. Users can manually disable it by executing SET enable_scan_datacache = false.
- If users want to re-use the cached data in Data Cache after downgrading a shared-data cluster from v3.3 to v3.2.8 and earlier, they need to manually rename the Blockfile in the directory starlet_cache by changing the file name format from blockfile_{n}.{version}toblockfile_{n}, that is, to remove the suffix of version information. For more information, refer to the Data Cache Usage Notes. v3.2.9 and later versions are compatible with the file name format in v3.3, so users do not need to perform this operation manually.
- Supports dynamically modifying FE parameter sys_log_level. #45062
- The default value of the Hive Catalog property metastore_cache_refresh_interval_secis changed from7200(two hours) to60(one minute). #46681
Bug Fixes
Fixed the following issues:
- Query results are incorrect when queries are rewritten to materialized views created by using UNION ALL. #42949
- Extra columns are read when queries with predicates are rewritten to materialized views during query execution. #45272
- The results of functions next_dayandprevious_dayare incorrect. #45343
- Schema change fails because of replica migration. #45384
- Restoring a table with full-text inverted index causes BEs to crash. #45010
- Duplicate data rows are returned when an Iceberg catalog is used to query data. #44753
- Low cardinality dictionary optimization does not take effect on ARRAY<VARCHAR>-type columns in Aggregate tables. #44702
- Query results are incorrect when queries are rewritten to materialized views created by using UNION ALL. #42949
- If BEs are compiled with ASAN, BEs crash when the cluster is started and the be.warninglog showsdict_func_expr == nullptr. #44551
- Query results are incorrect when aggregate queries are performed on single-replica tables. #43223
- View Delta Join rewrite fails. #43788
- BEs crash after the column type is modified from VARCHAR to DECIMAL. #44406
- When a table with List partitioning is queried by using a not-equal operator, partitions are incorrectly pruned, resulting in wrong query results. #42907
- Leader FE's heap size increases quickly as many Stream Load jobs using non-transactional interface finishes. #43715
Downgrade notes
To downgrade a cluster from v3.3.0 or later to v3.2, users must follow these steps:
- 
Ensure that all ALTER TABLE SCHEMA CHANGE transactions initiated in the v3.3 cluster are either completed or canceled before downgrading. 
- 
Clear all transaction history by executing the following command: ADMIN SET FRONTEND CONFIG ("history_job_keep_max_second" = "0");
- 
Verify that there are no remaining historical records by running the following command: SHOW PROC '/jobs/<db>/schema_change';
- 
If you want to downgrade the cluster to a patch version earlier than v3.2.8 or v3.1.14, you must drop all asynchronous materialized views you have created using PROPERTIES('compression' = 'lz4').
- 
Execute the following command to create an image file for your metadata: ALTER SYSTEM CREATE IMAGE;
- 
After the new image file is transmitted to the directory meta/image of all FE nodes, you can first downgrade a Follower FE node. If no error is returned, you can then downgrade other nodes in the cluster.