Change Log
Next Version (unreleased)
Version 2.1.210 (2022-01-17)
- PR #3381: Add IDENTITY() and SCOPE_IDENTITY() to LEGACY mode
- Issue #3376: Data cannot be read after insert of clob data > MAX_LENGTH_INPLACE_LOB with data change delta table
- PR #3377: Add -webExternalNames setting and fix WebServer.getConnection()
- PR #3367: Use faster checks of dimension systems of geometries
- PR #3369: Added v2 changes in migration docs
- Issue #3361: MemoryEstimator.estimateMemory() can return negative size
- PR #3362: Use BufferedReader instead of BufferedInputStream to avoid Illegal seek exception
- Issue #3353: Wrong rownum() scope for DML with change delta table
- PR #3352: make Javadoc happier
- Issue #3344: Changelog could link to github issue
- Issue #3340: JDBC index type seems wrong
- Issue #3336: FT_INIT error when mode=MySQL
- Issue #3334: Regression with CREATE ALIAS - Parameter "#2" is not set
- Issue #3321: Insert Primary Key after import CSV Data does not work
- PR #3323: Tokenize SQL before parsing and preserve tokens for recompilation
- PR #3320: Add Servlet 5-compatible servlet for H2 Console
- Issue #918: Parser fails recognising set operations in correlated subqueries
- Issue #2050: PostgreSQL with recursive fail with union in the final query
- PR #3316: Update copyright years
- PR #3315: Never put read locks into lockSharedSessions and other minor changes
- Issue #492: H2 does not correctly parse <parenthesized joined table>
- Issue #3311: Parser creates wrong join graph in some cases and uses wrong tables for column mapping
- FORCE_JOIN_ORDER setting is removed
- Issue #1983: Official build script is not compatible with Java 13
- PR #3305: Add UNIQUE(VALUE) and remove some non-standard keywords
- PR #3299: Remove useless StringBuilder.toString() call
- PR #3298: Delete unused sqlTypes array
Version 2.0.206 (2022-01-04)
- Issue #3322: Create linked table fails when the table contains a Geometry with a data type specified
- Issue #3297: Unexpected GROUP BY results with indexed IGNORECASE column
Version 2.0.204 (2021-12-21)
- Issue #3291: Add Legacy and Strict modes
- Issue #3287: SELECT statement works on 1.4.200 but fails on 2.0.202 with "Column XYZ must be in the GROUP BY list"
- PR #3284: Remove unused UNDO_LOG setting
- Issue #3251: Table with GEOMETRY column can't have a TriggerAdapter-based trigger any more
- PR #3281: DateTimeFormatter-based FORMATDATETIME and PARSEDATETIME and other changes
- Issue #3246: Spatial predicates with comparison are broken in MySQL compatibility mode
- Issue #3270: org.h2.jdbc.JdbcSQLFeatureNotSupportedException: Feature not supported: "Unsafe comparison or cast"
- Issue #3268 / PR #3275: Add TO_DATE and TO_TIMESTAMP to PostgreSQL compatibility mode
- PR #3274: Remove some dead code and unused params
- Issue #3266: Oracle compatibility NUMBER without precision and scale should have variable scale
- Issue #3263: Unable to store BigDecimal with negative scale in NUMERIC(19,6) column
- PR #3261: Small optimization for MIN and MAX
- Issue #3258 / PR #3259: Prevent incorrect optimization of COUNT(*) and other changes
- PR #3255: Throw proper exception when type of argument isn't known
- Issue #3249: Multi-column assignment with subquery throws exception when subquery doesn't return any rows
- PR #3248: Remove redundant uniqueness check, correct version in pom
- PR #3247: Avoid AIOBE exception in TestCrashAPI and in Transaction
- Issue #3241: ResultSetMetaData::getColumnTypeName should produce the correct ARRAY type
- Issue #3204: H2 Tools Web Console: Unicode 32
- Issue #3227: Regression when referencing outer joined column from correlated subquery
- Issue #3237: Can no longer cast CHAR(n) to BOOLEAN with n > 1
- Issue #3235: Regression in IN predicate with empty in list
- Issue #3236: NullPointerException in DatabaseMetaData::getIndexInfo when querying the info for views
- Issue #3233: General error when using NULL predicate on _ROWID_ column
- Issue #3223: TRUNC(v, p) with negative precisions no longer works
- Issue #3221: NullPointerException when creating domain
- Issue #3186: ResultSetMetaData.getSchemaName() returns empty string for aliased columns
Version 2.0.202 (2021-11-25)
- Issue #3206: CVE Vulnerability CVE-2018-14335
- Issue #3174: Add keyword AUTOCOMMIT on create linked table to control the commit mode
- Issue #3130: Precision of NUMERIC values isn't verified in the Oracle compatibility mode
- Issue #3122: Documentation: Syntax diagram for RENAME CONSTRAINT incorrect
- PR #3129: remove LOB compression
- PR #3127: Cleanups post PageStore removal
- PR #3126: Change nested classes to static nested classes where possible
- PR #3125: Strongly typed LobStorageMap
- PR #3124: Remove PageStore engine
- Issue #3118: SHUTDOWN COMPACT causes 2PC to corrupt database in a simulated crash
- Issue #3115: Infinite loop then OOM in org.h2.mvstore.tx.Transaction.waitFor() when deadlock occurs
- Issue #3113: Data lost when 2 threads read/write TransactionStore and close it normally even if MVStore autoCommit
disabled
- PR #3110: Fix possible int overflow and minor doc change
- Issue #3036: A database that contains BLOBs might grow without being able to be compacted
- Issue #3097: Possible MVStore compaction issue
- PR #3096: Add separate LOB data layer for values
- Issue #3093: ROWNUM filter doesn't work with more than one table
- PR #3087: Add "CONVERT TO CHARACTER SET" to compatibility modes
- Issue #3080: Complex Query returns different results depending on the number of arguments in the IN clause
- Issue #3066: Very high DB opening/closing times
- PR #3077: Add CREATE UNIQUE INDEX ... INCLUDE
- Issue #3061 / PR #3074: GROUP BY using column index for MySQL/MariaDB/PostgreSQL compatibility modes
- PR #3067: Restrict identity data types and result limitation clauses to compatibility modes
- PR #3065: Remove duplicate method IOUtils.getBufferedReader
- Issue #3055: Phantom table leftover after INSERT .. WITH
- PR #3062: Add ALTER DOMAIN RENAME CONSTRAINT command
- Issue #3059: ALTER TABLE DROP CONSTRAINT doesn't check owner of constraint
- Issue #3054: Add binary set aggregate functions
- Issue #3049: Java value getters of ValueNull should throw exceptions
- Issue #3046: SYSTEM_RANGE can't handle bind variable as step size and produces wrong error message
- Issue #3033: NPE during BLOB read after 2PC rollback
- PR #3034: Don't evaluate ValueTimestampTimeZone at begin and end of each command
- PR #3029: Optimize row storage in MVStore and other changes
- PR #3028: Remove back compatibility
- PR #3025: Switch from Travis CI to GitHub Workflows
- PR #3024: Add initial version of upgrade utility
- Issue #3017: ROUND() does not set correct precision and scale of result
- Issue #3003: CREATE TABLE ... AS SELECT ... FROM creates invalid column definition when aggregate functions are used
- Issue #3008: TestCrashAPI: Exception in Arrays.sort() called by LocalResult.done()
- Issue #3006 / PR #3007: Unlock meta during query execution in CREATE TABLE AS query
- PR #3001: PostgreSQL compatibility: UPDATE with FROM
- PR #2998: Fix off-by-one error with -webAdminPassword in Server
- PR #2995: Add FETCH_SIZE clause to CREATE LINKED TABLE
- Issue #2907 / PR #2994: Prevent "Chunk not found" on LOB operations
- PR #2993: Update copyright years
- Issue #2991: TestCrashAPI: NPE in ScriptCommand.dumpDomains()
- Issue #2950 / PR #2987: Issue commit() right before "non-transactional" DDL command starts
- PR #2980: Assorted minor changes
- PR #2966: H2 2.0.201: Linked Tables freeze the Database and freeze the Server Process
- Issue #2972: Memory leak due to negative Page memory in the MVStore
- PR #2971: create skeleton of migration to V2 document
- Issue #2967: MVStore: averageSize int overflow in the class ObjectDataType
- Issue #2963: Syntax error for large hexadecimal constants with DATABASE_TO_UPPER=false
- Issue #2961: Accept CREATE PRIMARY KEY only in metadata or in quirks mode
- Issue #2960: Reject invalid CREATE { UNIQUE | HASH } SPATIAL INDEX
- Issue #2958: TableLink is broken for Oracle database after pull request #2903
- PR #2955: Prevent incorrect index sorting
- PR #2951: Add documentation for INFORMATION_SCHEMA
- PR #2943: some small prep for next release
- PR #2948: Add support of Infinity, -Infinity, and NaN to DECFLOAT data type
- Issue #2947: Encoding of Unicode and special characters in error messages
- Issue #2891: Fix import of unnamed referential constraints from SQL scripts generated by older versions of H2
- Issue #2812: Unexpected result for query that compares an integer with a string
- Issue #2936: Add data type conversion code from datetime and UUID values to JSON
- Issue #2935: ENUM ARRAY isn't read properly from persisted data
- Issue #2923: Combination of fileName() with fileStore() should throw an exception
- Issue #2928: JSON_ARRAYAGG and all NULL values
- PR #2918: Removal of unnecessary lock
- Issue #2911: org.h2.mvstore.MVStoreException: Transaction was illegally transitioned from ROLLING_BACK to
ROLLED_BACK
- Issue #1022: JdbcDatabaseMetaData.getPseudoColumns() should be implemented
- Issue #2914: (T1.A = T2.B) OR (T1.A = T2.C) should be optimized to T1.A IN(T2.B, T2.C) to allow index conditions
- PR #2903: Assorted changes
- Issue #2901: PgServer returns less rows when fetchSize is set
- Issue #2894: NPE in DROP SCHEMA when unique constraint is removed before linked referential constraint
- Issue #2888: H2 should pass time zone of client to the server
- PR #2890: Fixed possible eternal wait(0)
- Issue #2846: GRANT SELECT, INSERT, UPDATE, DELETE incorrectly gives privileges to drop a table
- Issue #2882: NPE in UPDATE with SELECT UNION
- PR #2881: Store users and roles together and user-defined functions and aggregates together
- Issue #2878: Disallow spatial indexes in PageStore databases
- PR #2874: Use 64-bit row counts in results and other changes
- Issue #2866: New INFORMATION_SCHEMA should not use keywords as column names
- Issue #2867: PageStore + Lazy + INSERT ... SELECT cause infinite loop
- PR #2869: Normalize binary geometry literals and improve EWKB representation of POLYGON EMPTY
- Issue #2860: CHAR columns in PgCatalogTable have incorrect length
- Issue #2848: Add support for standard <listagg overflow clause>
- Issue #2858: Throw 22001 on attempt to use getString() or getBytes() on LOB object longer than 1,048,576
chars/octets
- Issue #2854: Define limits for identifiers, number of columns, etc.
- PR #2853: Small optimization for Page compression / decompression
- Issue #2832: Define length limits for non-LOB data types
- Issue #2842: Querying view that uses LTRIM/RTRIM results in a syntax error
- Issue #2841: Call to STRINGDECODE results in StringIndexOutOfBoundsException
- Issue #2839: Querying a view that uses the POSITION() function results in an unexpected syntax error
- Issue #2838: INSERT() with NULL arguments for the original string and string to be added results in NPE
- Issue #2837: ROUND() function should reject invalid number of digits immediately
- Issue #2835: Calling math functions with a string argument results in a NullPointerException
- Issue #2833: MERGE INTO causes an unexpected syntax error
- Issue #2831: Restore YEAR data type for MySQL compatibility mode
- Issue #2822: Suspicious logic in Database.closeImpl()
- Issue #2829: Incorrect manifest entries in sources jar
- Issue #2828: Parser can't parse NOT in simple when operand
- Issue #2826: Table with a generated column cycle results in a NullPointerException
- Issue #2825: Query with % operator results in a ClassCastException
- Issue #2818: TableFilter.getValue() can read value of delegated column faster
- Issue #2816: Query on view that uses the BETWEEN operator results in an unexpected syntax error
- PR #2815: Remove BINARY_COLLATION and UUID_COLLATION settings
- Issue #2813: Query with CASE operator unexpectedly results in "Column must be in the GROUP BY list" error
- Issue #2811: Update build numbers and data format versions
- Issue #2674: OPTIMIZE_IN_SELECT shouldn't convert value to incompatible data types
- Issue #2803: Disallow comparison operations between incomparable data types
- Issue #2561: Separate normal functions and table value functions
- Issue #2804: NPE in ConditionNot.getNotIfPossible()
- Issue #2801: Instances of TableView objects leaking
- PR #2799: Additional bit functions BITNAND, BITNOR, BITXNOR, BITCOUNT, ULSHIFT, URSHIFT, ROTATELEFT, ROTATERIGHT,
BIT_NAND_AGG, BIT_NOR_AGG, and BIT_XNOR_AGG.
- PR #2798: Complete separation of Function class
- Issue #2795: Sporadic issues with trigger during concurrent insert in 1.4.199/1.4.200
- PR #2796: Assorted refactorings
- Issue #2786: Failure in CREATE TABLE AS leaves inconsistent transaction if some rows were successfully inserted
- Issue #2790: Examples in documentation of CREATE ALIAS should use standard literals only
- Issue #2787: CONCAT and CONCAT_WS functions
- PR #2784: Oracle REGEXP_REPLACE support
- Issue #2780: Remove SCOPE_GENERATED_KEYS setting
- PR #2779: Fix incorrect FK restrictions and other changes
- PR #2778: Assorted changes
- Issue #2776: Referential constraint can create a unique constraint in the wrong schema
- Issue #2771: Add documented DEFAULT ON NULL flag for all types of columns
- Issue #2742 / PR #2768: Better separation of MVStore aimed at smaller h2-mvstore jar
- Issue #2764: Identity columns don't accept large numbers
- IDENTITY() function is removed, SCOPE_IDENTITY() is now available only in MSSQLServer compatibility mode.
- Issue #2757: Intermittent TestFileSystem failures
- Issue #2758: Issues with sequences
- PR #2756: Prevent DROP NOT NULL for identity columns
- Issue #2753: UPDATE statement changes value of GENERATED ALWAYS AS IDENTITY columns
- PR #2751: Add comment explaining seemingly dummy operation
- PR #2750: Use RFC 4122 compliant UUID comparison by default
- PR #2748: PgServer set type text to NULL value
- Issue #2746: Old TCP clients with current server
- PR #2745: PgServer can send bool in binary mode
- PR #2744: Remove jarSmall and jarClient targets
- PR #2743: Add IS_TRIGGER_UPDATABLE and other similar fields to INFORMATION_SCHEMA
- PR #2738: Fix VIEWS.VIEW_DEFINITION and support it for other databases in H2 Console
- PR #2737: Assorted changes
- PR #2734: Update dependencies and fix ResultSetMetaData.isSigned()
- PR #2733: Replace h2.sortNullsHigh with DEFAULT_NULL_ORDERING setting
- PR #2731: Fix spelling errors in German translation
- PR #2728: Add and use DATA_TYPE_SQL() function and remove INFORMATION_SCHEMA.PARAMETERS.REMARKS
- Issue #1015: ENUM and arithmetic operators
- Issue #2711: Store normalized names of data types in metadata
- PR #2722: Implement getRowCount() for some INFORMATION_SCHEMA tables
- PR #2721: Improve LOCKS, SESSIONS, and USERS and optimize COUNT(*) on other isolation levels in some cases
- Issue #2655: TestCrashAPI: AssertionError at MVPrimaryIndex.<init>
- Issue #2716: Fix URL of Maven repository
- Issue #2715: Mention `DB_CLOSE_DELAY=-1` flag in JDBC URL on the "Cheat Sheet" page
- PR #2714: fixed few code smells discovered by PVS-Studio
- Issue #2712: `NOT LIKE` to a sub-query doesn't work
- PR #2710: PgServer: set oid and attnum in RowDescription
- Issue #2254: Add standard DECFLOAT data type
- PR #2708: Add declared data type attributes to the INFORMATION_SCHEMA
- Issue #2706: Empty comments / remarks on objects
- PR #2705: Return standard-compliant DATA_TYPE for strings
- PR #2703: Fix case-insensitive comparison issues with national characters
- Issue #2701: Subquery with FETCH should not accept global conditions
- Issue #2699: Remove FUNCTIONS_IN_SCHEMA setting
- Issue #452: Add possibility to use user-defined aggregate functions with schema
- PR #2695: Refactor handling of parentheses in getSQL() methods
- PR #2693: disallow VARCHAR_IGNORECASE in PostgreSQL mode
- Issue #2407: Implement CHAR whitespace handling correctly
- PR #2685: Check existing data in ALTER DOMAIN ADD CONSTRAINT
- PR #2683: Fix data types in Transfer
- PR #2681: Report user functions in standard ROUTINES and PARAMETERS views
- PR #2680: Reimplement remaining DatabaseMetaData methods and fix precision of binary numeric types
- PR #2679: Reimplement getTables(), getTableTypes(), and getColumns()
- PR #2678: Reimplement getPrimaryKeys(), getBestRowIdentifier(), getIndexInfo() and others
- PR #2675: Reimplement getImportedKeys(), getExportedKeys(), and getCrossReferences()
- PR #2673: Reimplement some metadata methods
- PR #2672: Forward DatabaseMetaData calls to server
- Issue #2329: Content of INFORMATION_SCHEMA should be listed as VIEWS
- PR #2668: Sequence generator data type option and length parameter for JSON data type
- PR #2666: Add ALTER DOMAIN RENAME command
- PR #2663: Add ALTER DOMAIN { SET | DROP } { DEFAULT | ON UPDATE }
- PR #2661: Don't allow construction of incomplete ARRAY and ROW data types
- Issue #2659: NULLIF with row values
- PR #2658: Extract date-time and some other groups of functions into own classes
- PR #2656: add `_int2` and `_int4` for PgServer
- PR #2654: Move out JSON, cardinality, ABS, MOD, FLOOR, and CEIL functions from the Function class
- PR #2653: Use full TypeInfo for conversions between PG and H2 data types
- PR #2652: Add "SHOW ALL"
- PR #2651: add `pg_type.typelem` and `pg_type.typdelim`
- PR #2649: Extract some groups of functions from Function class
- PR #2646: Add some PostgreSQL compatibility features
- PR #2645: Add CURRENT_PATH, CURRENT_ROLE, SESSION_USER, and SYSTEM_USER
- Issue #2643: Send PG_TYPE_TEXTARRAY values to ODBC drivers properly
- PR #2642: Throw proper exceptions from array element reference and TRIM_ARRAY
- PR #2640: German translations
- Issue #2108: Add possible candidates in different case to table not found exception
- Issue #2633: Multi-column UPDATE assignment needs to be reimplemented
- PR #2635: Implement REGEXP_SUBSTR function
- PR #2632: Improve ROW data type
- PR #2630: fix: quoted VALUE in documentation
- Issue #2628: Cached SQL throws JdbcSQLSyntaxErrorException if executed with different parameter values than before
- Issue #2611: Add quantified distinct predicate
- Issue #2620: LOBs in triggers
- PR #2619: ARRAY_MAX_CARDINALITY and TRIM_ARRAY functions
- PR #2617: Add Feature F262: Extended CASE expression
- PR #2615: Add feature T461: Symmetric BETWEEN predicate
- PR #2614: Fix support of multi-dimensional arrays in Java functions
- Issue #2608: Improve concatenation operation for multiple operands
- PR #2605: Assorted minor changes
- Issue #2602: H2 doesn't allow to create trigger from Java source code if there are nested classes
- PR #2601: Add field SLEEP_SINCE to INFORMATION_SCHEMA.SESSIONS table
- Issue #1973: Standard MERGE statement doesn't work with views
- Issue #2552: MERGE statement should process each row only once
- Issue #2548: Wrong update count when MERGE statement visits matched rows more than once
- Issue #2394: H2 does not accept DCL after source merge table
- Issue #2196: Standard MERGE statement doesn't release the source view
- Issue #2567: ARRAY-returning Java functions don't return the proper data type
- Issue #2584: Regression in NULL handling in multiple AND or OR conditions
- PR #2577: PgServer: `array_to_string()` and `set join_collapse_limit`
- PR #2568: Add BIT_XOR_AGG aggregate function
- PR #2565: Assorted minor changes
- PR #2563: defrag is not contributing much, remove from test run
- PR #2562: new exception MVStoreException
- PR #2557: don't throw IllegalStateException in checkOpen
- PR #2554: Reenable mvstore TestCrashAPI
- Issue #2556: TestOutOfMemory: Table "STUFF" not found
- PR #2555: Move current datetime value functions into own class
- PR #2547: split up the ValueLob classes
- PR #2542: Pipelining mvstore chunk creation / save
- Issue #2550: NullPointerException with MERGE containing unknown column in AND condition of WHEN
- Issue #2546: Disallow empty CASE specifications and END CASE
- Issue #2530: Long query with many AND expressions causes StackOverflowError
- PR #2543: Improve case specification support and fix some issues with it
- Issue #2539: Replace non-standard functions with standard code directly in Parser
- Issue #2521: Disallow untyped arrays
- Issue #2532: Duplicate column names in derived table should be acceptable in the presence of a derived column list
that removes ambiguities
- PR #2527: Feature: allow @ meta commands from Console
- PR #2526: Reduce I/O during database presence check and restrict some compatibility settings to their modes
- PR #2525: Restore support of third-party drivers in the Shell tool
- Issue #1710: getHigherType() returns incorrect type for some arguments
- PR #2516: SHUTDOWN IMMEDIATELY should be a normal shut down
- PR #2515: Fix nested comments in ScriptReader
- Issue #2511: Restrict Oracle compatibility functions to Oracle compatibility mode
- PR #2508: Minor refactoring around Tx isolation level
- PR #2505: Assorted changes in DATEADD, DATEDIFF, DATE_TRUNC, and EXTRACT
- Issue #2502: Combination of DML with data change delta table skips subsequent update
- PR #2499: Performance fix for PageStore under concurrent load
- PR #2498: Add some PostgreSQL compatibility features mentioned in issue #2450
- Issue #2496: Error when using empty JSON_OBJECT() or JSON_ARRAY() functions
- PR #2495: Fix JSON_OBJECT grammar in documentation
- Issue #2493 / PR #2494: Replace ColumnNamer with mode-specific generation of column names for views
- PR #2492: Assorted changes in parser, keywords, and ILIKE condition
- PR #2490: Replace pg_catalog.sql with PgCatalogTable and use DATABASE_TO_LOWER in PG Server
- Issue #2488 / PR #2489: Mark version functions as not deterministic
- Issue #2481: Convert TO to keyword
- PR #2476: Add some PostgreSQL compatibility features mentioned in issue #2450
- PR #2479: Recognize absolute path on Windows without drive letter
- Issue #2475: Select order by clause is exported with non-portable SQL
- Issue #2472: Updating column to empty string in Oracle mode with prepared statement does not result in null
- PR #2468: MVStore scalability improvements
- PR #2466: Add partial support for MySQL COLLATE and CHARACTER statements
- Issue #2464: `client_encoding='utf-8'` (single quoted) from `node-postgres` not recognized
- Issue #2461: Support for binary_float and binary_double type aliases
- Issue #2460: Exception when accessing empty arrays
- Issue #2318: Remove incorrect rows from DatabaseMetaData.getTypeInfo() and INFORMATION_SCHEMA.TYPE_INFO
- Issue #2455: `bytea` column incorrectly read by `psycopg2`
- PR #2456: Add standard array value constructor by query
- PR #2451: Add some PostgreSQL compatibility features mentioned in issue #2450
- Issue #2448: Change default data type name from DOUBLE to DOUBLE PRECISION
- PR #2452: Do not use unsafe and unnecessary FROM DUAL internally
- PR #2449: Add support for standard trigraphs
- Issue #2439: StringIndexOutOfBoundsException when using TO_CHAR
- Issue #2444: WHEN NOT MATCHED THEN INSERT should accept only one row
- Issue #2434: Next value expression should return the same value within a processed row
- PR #2437: Assorted changes in MVStore
- Issue #2430: Postgres `bytea` column should be read with and without `forceBinary`
- Issue #2267: BINARY and VARBINARY should be different
- Issue #2266: CHAR and BINARY should have length 1 by default
- PR #2426: Add MD5 and all SHA-1, SHA-2, and SHA-3 digests to the HASH() function
- Issue #2424: 0 should not be accepted as a length of data type
- Issue #2378: JAVA_OBJECT and TableLink
- Issue #2417: Casts between binary strings and non-string data types
- Issue #2416: OTHER and JAVA_OBJECT
- Issue #2379: SQL export can change data type of a constant
- Issue #2411: ArrayIndexOutOfBoundsException when HAVING and duplicate columns in SELECT
- Issue #2194: Add own enumeration of data types to API
- PR #2408: Descending MVMap and TransactionMap cursor
- Issue #2399: Cast to ARRAY with a nested ARRAY does not check the maximum cardinality of the nested ARRAY
- Issue #2402: Remove old ValueLob and DbUpgrade
- Issue #2400: Inconsistent data type conversion between strings and LOBs
- PR #2398: Add expandable flags for SQL generation methods
- PR #2395: Fix for two recent page format bugs
- PR #2386: Chunk occupancy mask
- PR #2385: Memory estimate
- PR #2381: Follow up REPEATABLE_READ-related changes
- PR #2380: use JIRA tracker URLs for JDK bugs
- PR #2376: Fix IN condition with row value expressions in its right side
- Issue #2367 / PR #2370: fix backward compatibility with 1.4.200
- Issue #2371: REPEATABLE READ isolation level does not work in MVStore
- Issue #2363: Soft links in -baseDir and database path cause error 90028
- Issue #2364: TestScript datatypes/timestamp-with-time-zone.sql fails if TZ=Europe/Berlin
- Issue #2359: Complete implementation of generated columns
- PR #2361: Fix unused result
- PR #2353: Push binary search operation from Page to DataType
- Issue #2348: Add USING clause to ALTER COLUMN CHANGE DATA TYPE
- Issue #2350: License Problem in POM
- Issue #2345: Add standard SET TIME ZONE command to set current time zone of the session
- PR #2341: Cleanup file backend sync
- Issue #2343: Domain-based domains: Domain not found after reconnection
- Issue #2338: Domains should not support NULL constraints
- Issue #2334: build target mavenInstallLocal broken since commit 7cbbd55e
- #2335: TestDateTimeUtils fails if system timezone has DST in the future
- Issue #2330: Syntax error with parenthesized expression in GROUP BY clause
- Issue #2256: <interval value expression> with datetime subtraction
- Issue #2325: H2 does not parse nested bracketed comments correctly
- Issue #466: Confusion about INFORMATION_SCHEMA content related to UNIQUE constraints
- PR #2323: Assorted changes
- Issue #2320: Remove SAMPLE_SIZE clause from SELECT
- Issue #2301: Add compatibility setting to accept some keywords as identifiers
- PR #2317: Replace CHECK_COLUMN_USAGE with CONSTRAINT_COLUMN_USAGE and other changes
- Issue #2315: Sequence must remember its original START WITH value
- Issue #2313: DISTINCT does not work in ordered aggregate functions
- PR #2306: Add support for RESTART of sequence without initial value
- Issue #2304: NPE in multiple define commands in one statement after upgrade from H2 4.1.197
- PR #2303: Assorted minor changes
- Issue #2286: Inline check constraints not in INFORMATION_SCHEMA
- PR #2300: Continue generification of MVStore codebase
- PR #2298: add some minimal security documentation
- PR #2292: synchronize fileBase subclasses use of position
- PR #2238: Some MVStore refactoring
- Issue #2288: ConcurrentModificationException during commit
- Issue #2293: Remove TestClearReferences and workarounds for old versions of Apache Tomcat
- Issue #2288: ConcurrentModificationException during commit
- PR #2284: Remove unrelated information from README and add some information about H2
- PR #2282: add PostgreSQL compatible variable STATEMENT_TIMEOUT
- PR #2280: little comment
- Issue #2205: H2 1.4.200 split FS issue
- Issue #2272: UpdatableView and obtaining the Generated Keys
- PR #2276: Split up filesystem classes
- PR #2275: improve detection of JAVA_HOME on Mac OS
- Issue #2268: Numeric division needs better algorithm for scale selection
- Issue #2270: IGNORE_UNKNOWN_SETTINGS is ignored
- PR #2269: Fix existence check of non-persistent databases
- Issue #1910: BinaryOperation should evaluate precision and scale properly
- PR #2264: Clean up redundant parts of file system abstraction
- PR #2262: add setting AUTO_COMPACT_FILL_RATE
- Issue #2255 / PR #2259: Use NIO2 in main sources and build
- PR #2257: Catch java.lang.NoClassDefFoundError
- Issue #2241: Mark H2-specific and compatibility only clauses in documentation
- PR #2246: Update third-party drivers
- Issue #2239 / PR #2236: Add NETWORK_TIMEOUT setting for SO_TIMEOUT
- PR #2235: Don't use RandomAccessFile in FilePathNio
- Issue #2233: "Prepared.getObjectId() was called before" when granting on multiple tables
- PR #2230: Add factory methods for Row
- Issue #2226, PR #2227: Remove support of Apache Ignite
- PR #2224: Update some hyperlinks and use https in them where possible
- PR #2223: Fix data change delta tables in views
- Issue #1943: Deadlock in TestTriggersConstraints
- PR #2219: do not retry failed DDL commands
- PR #2214: Fix TRACE_LEVEL_FILE=4 for in-memory databases
- PR #2216: Add FileChannel.lock in the connection URL summary
- PR #2215: Add white-space: pre to tables with query results
- Issue #2213: NUMERIC scale can be larger than a precision
- PR #2212: Get rid of multi-version CurrentTimestamp and fix negative scale of NUMERIC
- PR #2210: Meta table extras
- PR #2209: Add standard expressions with interval qualifier
- PR #2195: Feature abort_session function
- PR #2201: Add padding to negative years and other changes
- PR #2197: Add some additional methods from JDBC 4.2 and return 4.2 as supported version
- PR #2193: Require Java 8 and remove Java 7 support
- Issue #2191: NPE with H2 v1.4.200 repeatable read select queries
- Issue #1390: Add standard-compliant ARRAY data type syntax
- PR #2186: Refactor Parser.parseColumnWithType() and fix some minor issues with CAST
- Issue #2181: SET EXCLUSIVE quirks
- PR #2173: Move snapshots from Transaction to TransactionMap
- Issue #2175: Regression: NPE in ResultSet#getTime(int)
- Issue #2171: Wrong PostgreSQL compatibility syntax for the creation of indexes
- PR #2169: Clean up some find methods of indexes and fix minor issues with them
Version 1.4.200 (2019-10-14)
- PR #2168: Add non-standard SNAPSHOT isolation level to MVStore databases
- Issue #2165: Problem with secondary index on SERIALIZABLE isolation level
- Issue #2161: Remove undocumented PageStore-only FILE_LOCK=SERIALIZED
- PR #2155: Reduce code duplication
- Issue #1894: Confusing error message when database creation is disallowed
- Issue #2123: Random failures in TestTransactionStore
- Issue #2153: Different behavior in SET LOCK_TIMEOUT after 1.4.197
- Issue #2150: Remove MULTI_THREADED setting and use multi-threaded MVStore and single-threaded PageStore backends
- Issue #216: Support READ UNCOMMITTED isolation level in MVStore mode
- Issue #678: Support REPEATABLE READ isolation level in MVStore mode
- Issue #174: Support SERIALIZABLE isolation level in MVStore mode
- Issue #2144: MVStore: read uncommitted doesn't see committed rows
- Issue #2142: CURRVAL / CURRENT VALUE FOR should return the value for the current session
- Issue #2136: ConstraintCheck concurrency regression
- PR #2137: Don't use SYSTEM_RANGE for SELECT without a FROM
- PR #2134: Assorted fixes and other changes in DateTimeUtils
- PR #2133: Optimize COUNT([ALL] constant) and other changes
- PR #2132: Typo and another bug in MVStore.readStoreHeader()
- Issue #2130: Group-sorted query returns invalid results with duplicate grouped columns in select list
- Issue #2120: Add IF EXISTS clause to column name in ALTER TABLE ALTER COLUMN statement
- Issue #521: Add support for the TIME WITH TIME ZONE data type
- PR #2127: Fix race condition / performance issue during snapshotting
- Issue #2124: MVStore build is broken
- PR #2122: Add support for LMT in time zones and fix large years in datetime values
- Issue #2067: Incorrect chunk space allocation during chunks movement
- PR #2066: Not so happy path - "four alternatives" implementation
- PR #2121: Reduce code duplication for datetime API with custom Calendar instances
- PR #2119: SQL: statement read consistency
- Issue #2116: Empty IN() operator should result in error (MSSQL)
- Issue #2036: CAST from TIME to TIMESTAMP returns incorrect result
- PR #2114: Assorted changes
- PR #2113: Add feature F411: Time zone specification
- PR #2111: CURRENT_CATALOG, SET CATALOG and other changes
- Issue #2109: IW date formatting does not produce proper output
- PR #2104: Fix ordinary grouping set with parentheses and empty grouping set in GROUP BY
- Issue #2103: Add QUOTE_IDENT() function to enquote an identifier in SQL
- Issue #2075: Add EXECUTE IMMEDIATE implementation
- PR #2101: Fix infinite loop in Schema.removeChildrenAndResources()
- Issue #2096: Convert LEFT and RIGHT to keywords and disallow comma before closing parenthesis
- PR #2098: Fix typos
- Issue #1305 / PR #2097: Remove unused and outdated website translation infrastructure
- PR #2093: CURRENT VALUE FOR and other sequence-related changes
- PR #2092: Allow to simulate usage of multiple catalogs by one connection
- PR #2091: Oracle mode now uses DECIMAL with NEXTVAL
- Issue #2088: Division by zero caused by evaluation of global conditions before local conditions
- Issue #2086: TCP_QUICKACK on server socket
- Issue #2073: TableLink should not pass queries to DatabaseMetaData.getColumns()
- Issue #2074: MySQL and MSSQLServer Mode: TRUNCATE TABLE should always RESTART IDENTITY
- Issue #2063: MySQL mode: "drop foreign key if exists" support
- PR #2061: Use VirtualTable as a base class for RangeTable
- PR #2059: Parse IN predicate with multiple subqueries correctly
- PR #2057: Fix TestCrashAPI failure with Statement.enquoteIdentifier()
- PR #2056: Happy path: speed up database opening
- Issue #2051: The website shows outdated information about the storage engine
- PR #2049: bugfix - mvstore data lost issue when partial write occurs
- PR #2047: File maintenance
- PR #2046: Recovery mode
- Issue #2044: setTransactionIsolation always call commit() even if transaction is auto-commit
- Issue #2042: Add possibility to specify generated columns for query in web console
- Issue #2040: INFORMATION_SCHEMA.SETTINGS contains irrelevant settings
- PR #2038: MVMap: lock reduction on updates
- PR #2037: Fix SYS_GUID, RAWTOHEX, and HEXTORAW in Oracle mode
- Issue #2016: ExpressionColumn.mapColumns() performance complexity is quadratic
- Issue #2028: Sporadic inconsistent state after concurrent UPDATE in 1.4.199
- PR #2033: Assorted changes
- Issue #2025: Incorrect query result when (OFFSET + FETCH) > Integer.MAX_VALUE
- PR #2023: traverseDown() code deduplication
- PR #2022: Mvmap minor cleanup
- Issue #2020: Wrong implementation of IN predicate with subquery
- PR #2003: Change dead chunks determination algorithm
- Issue #2013: DECIMAL is casted to double in ROUND function
- PR #2011: ZonedDateTime and (INTERVAL / INTERVAL)
- Issue #1997: TestRandomSQL failure with ClassCastException
- Issue #2007: PostgreSQL compatibility mode: support ON CONFLICT DO NOTHING
- Issue #1927: Do not allow commit() when auto-commit is enabled
- PR #1998: Reduce TxCounter memory footprint
- PR #1999: Make RootReference lock re-entrant
- PR #2001: Test improvements, OOME elimination
- Issue #1995: Obscure condition in MVPrimaryIndex.extractPKFromRow()
- Issue #1975: Add client ip address to information_schema
- PR #1982: Hindi language translation added
- Issue #1985: Add thread number to TCP server thread names
- Do not allow empty password for management DB
- Issue #1978: getGeneratedKeys() can use the same rules as FINAL TABLE
- PR #1977: Change JSON literals and add support for compound character literals
- PR #1974: Use proleptic Gregorian calendar for datetime values
- Issue #1847: Add support for data change delta tables
- PR #1971: Add maximum cardinality parameter to ARRAY data type
- PR #1970: Switch from log map rename to "committed" marker log record
- PR #1969: Add unique predicate
- Issue #1963: Expression.addFilterConditions() with outer joins
- PR #1966: Add standard CURRENT_SCHEMA function
- PR #1964: Add Feature T571: Truth value tests
- PR #1962: Fix data types of optimized conditions
- PR #1961: Failure to open DB after improper shutdown
- Issue #1957: NullPointerException with DISTINCT and ORDER BY CASE
- PR #1956: Fix row value handling in the null predicate
- PR #1955: Add standard UNKNOWN literal
- Issue #1952: Connection.setSchema doesn't work with query cache
- PR #1951: Assorted changes
- PR #1950: Fix NULL handling in ARRAY_AGG
- PR #1949: Extract aggregate and window functions into own pages in documentation
- PR #1948: Add standard LOG() function with two arguments
- Issue #1935: Improve file locking on shared filesystems like SMB
- PR #1946: Reimplement table value constructor on top of Query
- PR #1945: Fix IN (SELECT UNION with OFFSET/FETCH)
- Issue #1942: MySQL Mode: convertInsertNullToZero should be turned off by default?
- Issue #1940: MySQL Mode: Modify column from NOT NULL to NULL syntax
- PR #1941: Extract OFFSET / FETCH handling from Select and SelectUnion to Query
- Issue #1938: Regression with CREATE OR REPLACE VIEW. Causes "Duplicate column name" exception.
- PR #1937: Get rid of FunctionCursorResultSet
- Issue #1932: Incoherence between DbSettings.mvStore and getSettings()
- PR #1931: Fix wildcard expansion for multiple schemas
- PR #1930: Move PageStore table engine into own package
- PR #1929: Initial implementation of type predicate and other changes
- PR #1926: Assorted improvements for BINARY data type
- Issue #1925: Support SQL Server binary literal syntax
- Issue #1918: MySQL: CREATE TABLE with both CHARSET and COMMENT failed
- Issue #1913: MySQL: auto_increment changing SQL not supported
- Issue #1585: The translate function on DB2 mode could have parameters order changed
- PR #1914: Change storage and network format of JSON to byte[]
- Issue #1911: Foreign key constraint does not prevent table being dropped
- PR #1909: Add JSON_OBJECTAGG and JSON_ARRAYAGG aggregate functions
- PR #1908: Cast VARCHAR to JSON properly and require FORMAT JSON in literals
- PR #1906: Add JSON_OBJECT and JSON_ARRAY functions
- Issue #1887: Infinite recursion in ConditionAndOr.java
- Issue #1903: MSSQLServer Mode - Support Update TOP(X)
- Issue #1900: Support SQLServer stored procedure execution syntax
- PR #1898: Add IS JSON predicate
- Issue #1896: MSSQLServer compatibility mode - GETDATE() incorrectly omits time
- PR #1895: Add standard array concatenation operation
- Issue #1892: Window aggregate functions return incorrect result without window ordering and with ROWS unit
- Issue #1890: ArrayIndexOutOfBoundsException in MVSortedTempResult.getKey
- Issue #308: Mode MySQL and LAST_INSERT_ID with argument
- Issue #1883: Suspicious code in Session.getLocks()
- Issue #1878: OPTIMIZE_REUSE_RESULTS causes incorrect result after rollback since 1.4.198
- PR #1880: Collation names like CHARSET_* recognition
- Issue #1844: MySQL Compatibility: create table error when primary key has comment
- PR #1873: Concurrency in database metadata
- Issue #1864: Failing to format NotSerializableException corrupting the database
- PR #1868: add more checking to TestFileLock
- Issue #1819: Trace.db file exceed file size limit (64MB)
- Issue #1861: Use COALESCE in named columns join for some data types
- PR #1860: Additional fix for deadlock on shutdown (exclusively in PageStore mode)
- Issue #1855: Wrong qualified asterisked projections in named column join
- Issue #1854: Wrong asterisked projection and result in named column right outer join
- Issue #1852: Named column joins doesn't work with the VALUES constructor and derived column lists
- Issue #1851: Wrong asterisked projection in named column joins
- PR #1850: Duplicate map identifiers
- PR #1849: Reimplement MVStore.findOldChunks() with PriorityQueue
- PR #1848: Reimplement MVStore.findChunksToMove() with PriorityQueue
- Issue #1843: Named columns join syntax is not supported
- Issue #1841: Deadlock during concurrent shutdown attempts with 1.4.199
- Issue #1834: NUMERIC does not preserve its scale for some values
- PR #1838: Implement conversion from JSON to GEOMETRY
- PR #1837: Implement conversion from GEOMETRY to JSON
- PR #1836: Add LSHIFT and RSHIFT function
- PR #1833: Add BITNOT function
- PR #1832: JSON validation and normalization
- PR #1829: MVStore chunks occupancy rate calculation fixes
- PR #1828: Basis for implementation of SQL/JSON standard
- PR #1827: Add support for Lucene 8.0.0
- Issue #1820: Performance problem on commit
- Issue #1822: Use https:// in h2database.com hyperlinks
- PR #1817: Assorted minor changes in documentation and other places
- PR #1812: An IllegalStateException that wraps EOFException is thrown when partial writes happens
|