Jump to content

Comparison of relational database management systems

From Wikipedia, the free encyclopedia

The following tables compare general and technical information for a number of relational database management systems. Please see the individual products' articles for further information. Unless otherwise specified in footnotes, comparisons are based on the stable versions without any add-ons, extensions or external programs.

General information

[edit]
Maintainer First public release date Latest stable version Latest release date License Public issues list
4D (4th Dimension)4D S.A.S. 1984 v16.0 2017-01-10[1]ProprietaryNo
ADABASSoftware AG1970 8.1 2013-06 ProprietaryNo
Adaptive Server EnterpriseSAP AG1987 16.0 SP03 PL07 2019-06-10 ProprietaryNo
Advantage Database Server (ADS)SAP AG1992 12.0 2015 ProprietaryNo
AltibaseAltibase Corp. 2000 7.1.0.1.2 2018-03-02 ProprietaryNo
Apache DerbyApache2004 10.17.1.0[2]2023-11-14 Apache LicenseYes[3]
ClustrixDB MariaDB Corporation2010 v7.0 2015-08-19 ProprietaryNo
CockroachDBCockroach Labs 2015 v24.1.0 2024-05-20 BSL,CCL,MIT,BSD Yes[4]
CUBRIDCUBRID 2008-11 11.2.3 2023-01-31 Apache License 2.0, BSD license for APIs and GUI tools Yes[5]
DatacomCA, Inc.Early 70s[6]14[7]2012[8]ProprietaryNo
IBM Db2IBM1983 12.1[9] Edit this on Wikidata2024-11-14; 5 months ago ProprietaryNo
Empress Embedded DatabaseEmpress Software Inc 1979 10.20 2010-03 ProprietaryNo
ExasolEXASOL AG2004 7.1.1 2021-09-15; 3 years ago ProprietaryNo
FileMakerFileMaker, Inc., an Apple subsidiary 1985-04 19 2020-05-20 ProprietaryNo
FirebirdFirebird project 2000-07-25 5.0.2[10] Edit this on Wikidata2025-02-12; 2 months ago IPL[11] and IDPL[12]Yes[13]
GPUdbGIS Federal2014 3.2.5 2015-01-14 ProprietaryNo
HSQLDBHSQL Development Group 2001 2.6.1 2021-10-21 BSDYes[14]
H2H2 Software 2005 2.3.232 2024-08-12 EPL and modified MPLYes[15]
Informix Dynamic ServerIBM / HCL Technologies1981????1980 15.0.0.0 2024-11-20 ProprietaryNo
IngresActian1974 11.2[16]2022-05-06 GPL and ProprietaryNo
InterBaseEmbarcadero Technologies1984 XE7 v12.0.4.357 2015-08-12 ProprietaryNo
Linter SQL RDBMSRELEX Group 1990 6.0.17.53 2018-02-15 ProprietaryYes[17]
LucidDBThe Eigenbase Project 2007-01 0.9.4 2012-01-05 GPL v2 No
MariaDBMariaDB Community2010-02-01 11.7.2[18] Edit this on Wikidata2025-02-13; 2 months ago GPL v2, LGPL (for client-libraries)[19]Yes[20]
MaxDBSAP AG2003-05 7.9.0.8 2014 ProprietaryYes[21]
SingleStore (formerly MemSQL)SingleStore2012-06 7.1.11 2020-10-12 ProprietaryNo
Microsoft Access (JET) Microsoft1992 16 (2016) 2015-09-22 ProprietaryNo
Microsoft Visual FoxproMicrosoft1984 9 (2005) 2007-10-11 ProprietaryNo
Microsoft SQL ServerMicrosoft1989 2022[22] Edit this on Wikidata2022-11-16; 2 years ago ProprietaryNo
Microsoft SQL Server Compact (Embedded Database)Microsoft2000 2011 (v4.0) ProprietaryNo
Mimer SQLMimer Information Technology 1978 11.0.8E 2024-10-22 ProprietaryNo
MonetDBMonetDB Foundation [23]2004 Aug2024 [24]2024-08-26 Mozilla Public License, version 2.0[25]Yes[26]
mSQLHughes Technologies 1994 4.1[27]2017-06-30 ProprietaryNo
MySQLOracle Corporation1995-11 8.0.38[28] Edit this on Wikidata2025-04-15; 7 days ago GPL v2 or ProprietaryYes[29]
NexusDBNexusDB Pty Ltd 2003 4.00.14 2015-06-25 ProprietaryNo
HPE NonStop SQLHewlett Packard Enterprise1987 SQL/MX 3.4 ProprietaryNo
NuoDBNuoDB2013 4.1 2020-08 ProprietaryNo
Omnis StudioTigerLogic Inc 1982-07 6.1.3 Release 1no 2015-12 ProprietaryNo
OpenEdgeProgress Software Corporation1984 12.8 2024-1 ProprietaryNo
OpenLink VirtuosoOpenLink Software 1998 7.2.5.1 2018-08-15 GPL v2 or ProprietaryYes[30]
Oracle DBOracle Corporation1979-11 23ai[31] Edit this on Wikidata2023-09-19; 19 months ago ProprietaryNo
Oracle RdbOracle Corporation1984 7.4.1.1[32]2021-04-21[±]ProprietaryNo
ParadoxCorel Corporation 1985 11 2009-09-07 ProprietaryNo
Percona Server for MySQL Percona2006 8.0.37-29 2024-08-06[±]GPL v2 Yes
Actian Zen (PSQL)Actian1982 v15 2021 ProprietaryNo
Polyhedra DBMSENEA AB1993 9.0 2015-06-24 Proprietary, with Polyhedra Lite available as Freeware[33]No
PostgreSQLPostgreSQL Global Development Group 1989-06 17.4 2025-02-21[34]Postgres License[35]No[36]
R:BaseR:BASE Technologies 1982 10.0 2016-05-26 ProprietaryNo
SAP HANASAP AG2010 2.0 SPS04 2019-08-08 ProprietaryNo
solidDBUNICOM Global1992 7.0.0.10 2014-04-29 ProprietaryNo
SQL AnywhereSAP AG1992 17.0.0.48 2019-07-26 ProprietaryNo
SQLBaseUnify Corp. 1982 11.5 2008-11 ProprietaryNo
SQLiteD. Richard Hipp2000-09-12 3.49.1[37] Edit this on Wikidata2025-02-18; 2 months ago Public domainYes[38]
SQream DBSQream Technologies 2014 2.1[39]2018-01-15 ProprietaryNo
SuperbaseSuperbase1984 Classic 2003 ProprietaryNo
Superbase NGSuperbase NG2002 Superbase NG 2.10 2017 ProprietaryYes[40]
TeradataTeradata1984 15 2014-04 ProprietaryNo
TiDBPingCAP Inc. 2016 8.5.1[41] Edit this on Wikidata2025-01-17; 3 months ago Apache LicenseYes[42]
UniDataRocket Software 1988 8.2.1 2017-07 ProprietaryNo
YugabyteDBYugabyte, Inc. 2018 2.20.1.3[43]2024-01-25[±]Apache LicenseYes[44]
Maintainer First public release date Latest stable version Latest release date License Public issues list

Operating system support

[edit]

The operating systems that the RDBMSes can run on.

WindowsmacOSLinuxBSDUNIXAmigaOSz/OSOpenVMSiOSAndroid
4th DimensionYes Yes No No No No No No No No
ADABASYes No Yes No Yes No Yes No No No
Adaptive Server EnterpriseYes No Yes Yes Yes No No No No No
Advantage Database ServerYes No Yes No No No No No No No
AltibaseYes No Yes No Yes No No No No No
Apache DerbyYes Yes Yes Yes Yes No Yes No ? No
ClustrixDB No No Yes No Yes No No No No No
CockroachDBYes Yes Yes No No No No No No No
CUBRIDYes Partial Yes No No No No No No No
IBM Db2Yes Yes Yes No Yes No Yes No Yes No
Empress Embedded DatabaseYes Yes Yes Yes Yes No No No No Yes
EXASolutionNo No Yes No No No No No No No
FileMakerYes Yes Yes No No No No No Yes No
FirebirdYes Yes Yes Yes Yes No Maybe No Yes[45]Yes
HSQLDBYes Yes Yes Yes Yes No Yes No ? ?
H2Yes Yes Yes Yes Yes No Yes No ? Yes
Informix Dynamic ServerYes No Yes No Yes (AIX) No No No No No
IngresYes Yes Yes Yes Yes No Partial Yes[46]No No
InterBaseYes Yes Yes No Yes (Solaris) No No No Yes Yes
Linter SQL RDBMSYes Yes Yes Yes Yes No Under Linux on IBM ZYes Yes Yes
LucidDBYes Yes Yes No No No No No No No
MariaDBYes Yes[47]Yes Yes Yes No No No ? Yes[48]
MaxDBYes No Yes No Yes No Maybe No No No
Microsoft Access (JET) Yes No No No No No No No No No
Microsoft Visual FoxproYes No No No No No No No No No
Microsoft SQL ServerYes No Yes[49]No No No No No No No
Microsoft SQL Server Compact (Embedded Database)Yes No No No No No No No No No
Mimer SQLYes Yes Yes No Yes No No Yes[50]No Yes
MonetDBYes Yes Yes Yes Yes No No No No No
MySQLYes Yes Yes Yes Yes Yes Yes No ? Yes[51]
Omnis StudioYes Yes Yes No No No No No No No
OpenEdgeYes No Yes No Yes No No No No No
OpenLink VirtuosoYes Yes Yes Yes Yes No No No No No
OracleYes Yes Yes No Yes No Yes Yes No No
Oracle RdbNo No No No No No No Yes No No
Actian Zen (PSQL)Yes Yes (OEM only) Yes No No No No No Yes Yes
PolyhedraYes No Yes No Yes No No No No No
PostgreSQLYes Yes Yes Yes Yes Yes (MorphOS)[52]Under Linux on IBM Z[53]No No Yes
R:BaseYes No No No No No No No No No
SAP HANAYes No Yes No No No No No No No
solidDBYes No Yes No Yes No Under Linux on IBM ZNo No No
SQL AnywhereYes Yes Yes No Yes No No No No Yes
SQLBaseYes No Yes No No No No No No No
SQLiteYes Yes Yes Yes Yes Yes Maybe No Yes Yes
SQream DBNo No Yes No No No No No No No
SuperbaseYes No No No No Yes No No No No
Superbase NGYes No Yes No No No No No No No
TeradataYes No Yes No Yes No No No No No
TiDBYes Yes Yes Partial No No No No No No
UniDataYes No Yes No Yes No No No No No
UniVerseYes No Yes No Yes No No No No No
YugabyteDBYes Yes Yes No No No No No No No
WindowsmacOSLinuxBSDUNIXAmigaOSz/OSOpenVMSiOSAndroid

Fundamental features

[edit]

Information about what fundamental RDBMS features are implemented natively.

Database Name ACIDReferential integrityTransactionsFine-grained lockingMultiversion concurrency controlUnicodeInterface Type inference
4th DimensionYes Yes Yes ? ? Yes GUI & SQLYes
ADABASYes No Yes ? ? Yes proprietary direct call & SQL (via 3rd party) Yes
Adaptive Server EnterpriseYes Yes Yes Yes (Row-level locking) Yes Yes API & GUI & SQLYes
Advantage Database ServerYes Yes Yes Yes (Row-level locking) ? Yes4API & SQLYes
AltibaseYes Yes Yes Yes (Row-level locking) ? Yes API & GUI & SQLYes
Apache DerbyYes Yes Yes Yes (Row-level locking) [54]? Yes SQLYes
ClustrixDB Yes Yes Yes Yes Yes Yes SQLYes
CockroachDBYes Yes Yes Yes (Row-level locking) Yes Yes SQLNo
CUBRIDYes Yes Yes Yes (Row-level locking) Yes Yes GUI & SQLYes
IBM Db2Yes Yes Yes Yes (Row-level locking)[55]? Yes GUI & SQLYes
Empress Embedded DatabaseYes Yes Yes ? ? Yes API & SQLYes
EXASolutionYes Yes Yes ? ? Yes API & GUI & SQLYes
FirebirdYes Yes Yes ? Yes Yes API & SQLYes
HSQLDBYes Yes Yes ? Yes Yes SQLYes
H2Yes Yes Yes ? Yes[56]Yes SQLYes
Informix Dynamic ServerYes Yes Yes Yes (Row-level locking) Yes Yes SQL, REST, MQ, and JSONYes
IngresYes Yes Yes Yes (Row-level locking) Yes Yes SQL & QUELYes
InterBaseYes Yes Yes ? ? Yes SQLYes
Linter SQL RDBMSYes Yes Yes (Except for DDL) Yes (Row-level locking) ? Yes API & GUI & SQLYes
LucidDBYes No No ? ? Yes SQLYes
MariaDBYes2Yes Yes2 except for DDL[57][58]Yes (Row-level locking) Yes Yes SQLYes
MaxDBYes Yes Yes ? ? Yes SQLYes
Microsoft Access (JET) Yes Yes Yes ? ? Yes GUI & SQLYes
Microsoft Visual FoxProYes Yes Yes Yes (Row-level locking SMB2) Yes No GUI & SQLYes
Microsoft SQL ServerYes Yes Yes Yes (Row-level locking)[59]Yes Yes GUI & SQLYes
Microsoft SQL Server Compact (Embedded Database)Yes Yes Yes ? ? Yes GUI & SQLYes
Mimer SQLYes Yes Yes Yes (Optimistic locking) Yes Yes API & GUI & SQLYes
MonetDBYes Yes Yes ? ? Yes API & SQL & MAL Yes
MySQLYes2Yes3Yes2 except for DDL[57]Yes (Row-level locking)[60]Yes Yes GUI5 & SQLYes
OpenEdgeYes Yes6Yes Yes (Row-level locking) ? Yes GUI & SQLYes
OpenLink VirtuosoYes Yes Yes ? ? Yes API & GUI & SQLYes
OracleYes Yes Yes except for DDL[57]Yes (Row-level locking)[61]Yes Yes API & GUI & SQLYes
Oracle RdbYes Yes Yes ? ? Yes SQLYes
Actian Zen (PSQL)Yes Yes Yes ? ? Yes API & GUI & SQLYes
Polyhedra DBMSYes Yes Yes Yes (optimistic and pessimistic cell-level locking)[62]? Yes API & SQLYes
PostgreSQLYes Yes Yes Yes (Row-level locking)[63]Yes Yes API & GUI & SQLNo[64]
SAP HANAYes Yes Yes Yes (Row-level locking) Yes Yes API & GUI & SQLYes
solidDBYes Yes Yes Yes (Row-level locking) ? Yes API & SQLYes
SQL AnywhereYes Yes Yes Yes (Row-level locking)[65]Yes[66]Yes API & GUI & HTTP(S) (REST & SOAP)[67] & SQLYes
SQLBaseYes Yes Yes ? ? Yes API & GUI & SQLYes
SQLiteYes Yes Yes No (Database-level locking)[68]No Optional[69]API & SQLYes
Superbase NG? ? ? Yes (Record-level locking) ? Yes GUI & Proprietary & ODBCYes
TeradataYes Yes Yes Yes (Hash and Partition) ? Yes SQLYes
TiDBYes Yes Yes except for DDL[57]Yes (Row-level locking)[70]Yes Yes GUI5 & SQLYes
UniDataYes No Yes ? ? Yes Multiple Yes
UniVerseYes No Yes ? ? Yes Multiple Yes
Database Name ACIDReferential integrityTransactionsFine-grained lockingMultiversion concurrency controlUnicodeInterface Type inference
  • Note (1): Currently only supports read uncommitted transaction isolation. Version 1.9 adds serializable isolation and version 2.0 will be fully ACID compliant.
  • Note (2): MariaDB and MySQL provide ACID compliance through the default InnoDB storage engine.[71][72]
  • Note (3): "For other than InnoDB storage engines, MySQL Server parses and ignores the FOREIGN KEY and REFERENCES syntax in CREATE TABLE statements. The CHECK clause is parsed but ignored by all storage engines."[73]
  • Note (4): Support for Unicode is new in version 10.0.
  • Note (5): MySQL provides GUI interface through MySQL Workbench.
  • Note (6): OpenEdge SQL database engine uses Referential Integrity, OpenEdge ABL Database engine does not and is handled via database triggers.

Limits

[edit]

Information about data size limits.

Max DB size Max table size Max row size Max columns per row Max Blob/Clob size Max CHAR size Max NUMBER size Min DATE value Max DATE value Max column name size
4th DimensionLimited ? ? 65,135 200 GB (2 GiBUnicode) 200 GB (2 GiBUnicode) 64 bits ? ? ?
Advantage Database ServerUnlimited 16 EiB65,530 B65,135 / (10+ AvgFieldNameLength) 4 GiB? 64 bits ? ? 128
Apache DerbyUnlimited Unlimited Unlimited 1,012 (5,000 in views) 2,147,483,647 chars 254 (VARCHAR: 32,672) 64 bits 0001-01-01 9999-12-31 128
ClustrixDB Unlimited Unlimited 64 MB on Appliance, 4 MB on AWS ? 64 MB 64 MB 64 MB 0001-01-01 9999-12-31 254
CUBRID2 EB 2 EB Unlimited Unlimited Unlimited 1 GB 64 bits 0001-01-01 9999-12-31 254
IBM DB2Unlimited 2 ZB1,048,319 B1,012 2 GB32 KiB64 bits 0001-01-01 9999-12-31 128
Empress Embedded DatabaseUnlimited 263−1 bytes 2 GB 32,767 2 GB 2 GB 64 bits 0000-01-01 9999-12-31 32
EXASolutionUnlimited Unlimited Unlimited 10,000 2 MB 128 bits 0001-01-01 9999-12-31 256
FileMaker8 TB 8 TB 8 TB 256,000,000 4 GB 10,000,000 1 billion characters, 10−400 to 10400, ± 0001-01-01 4000-12-31 100
FirebirdUnlimited1≈32 TB 65,536 B Depends on data types used 32 GB 32,767 B 128 bits 100 32768 63
HSQLDB64 TB Unlimited8Unlimited8Unlimited864 TB7Unlimited8Unlimited80001-01-01 9999-12-31 128
H264 TB Unlimited8Unlimited8Unlimited864 TB7Unlimited864 bits -99999999 99999999 Unlimited8
Max DB size Max table size Max row size Max columns per row Max Blob/Clob size Max CHAR size Max NUMBER size Min DATE value Max DATE value Max column name size
Informix Dynamic Server≈0.5 YB12≈0,5YB1232,765 bytes (exclusive of large objects) 32,765 4 TB 32,76514101251301/01/00011012/31/9999 128 bytes
IngresUnlimited Unlimited 256 KB 1,024 2 GB 32 000 B 64 bits 0001 9999 256
InterBaseUnlimited1≈32 TB 65,536 B Depends on data types used 2 GB 32,767 B 64 bits 100 32768 31
Linter SQL RDBMSUnlimited 230 rows 64 KB (w/o BLOBs),
2GB (each BLOB value)
250 2 GB 4000 B 64 bits 0001-01-01 9999-12-31 66
MariaDBUnlimited MyISAM storage limits: 256 TB;
Innodb storage limits: 64 TB;
Aria storage limits: ???
64 KB34,09644 GB (longtext, longblob) 64 KB (text) 64 bits 1000 9999 64[74]
Microsoft Access (JET) 2 GB 2 GB 16 MB 255 64 KB (memo field),
1 GB ("OLE Object" field)
255 B (text field) 32 bits 0100 9999 64
Microsoft Visual FoxproUnlimited 2 GB 65,500 B 255 2 GB 16 MB 32 bits 0001 9999 10
Microsoft SQL Server524,272 TB (32 767 files × 16 TB max file size)

16ZB per instance

524,272 TB 8,060 bytes / 2 TB61,024 / 30,000(with sparse columns) 2 GB / Unlimited (using RBS/FILESTREAM object) 2 GB6126 bits20001 9999 128
Microsoft SQL Server Compact (Embedded Database)4 GB 4 GB 8,060 bytes 1024 2 GB 4000 154 bits 0001 9999 128
Mimer SQLUnlimited Unlimited 16000 (+lob data) 252 Unlimited 15000 45 digits 0001-01-01 9999-12-31 128
MonetDBUnlimited Unlimited Unlimited Unlimited 2 GB 2 GB 128 bits -4712-01-01 9999-12-31 1024
MySQLUnlimited MyISAM storage limits: 256 TB; Innodb storage limits: 64 TB 64 KB34,09644 GB (longtext, longblob) 64 KB (text) 64 bits 1000 9999 64
OpenLink Virtuoso32 TB per instance
(Unlimited via elastic cluster)
DB size (or 32 TB) 4 KB 200 2 GB 2 GB 2310 9999 100
Oracle2 PB (with standard 8k block)
8 PB (with max 32k block)
8 EB (with max 32k block and BIGFILE option)
4 GB × block size
(with BIGFILE tablespace)
8 KB 1,000 128 TB 32,767 B11126 bits −4712 9999 128
Max DB size Max table size Max row size Max columns per row Max Blob/Clob size Max CHAR size Max NUMBER size Min DATE value Max DATE value Max column name size
Actian Zen (PSQL)4 billion objects 256 GB 2 GB 1,536 2 GB 8,000 bytes 64 bits 01-01-0001 12-31-9999 128 bytes
PolyhedraLimited by available RAM, address space 232 rows Unlimited 65,536 4 GB (subject to RAM) 4 GB (subject to RAM) 64 bits 0001-01-01 8000-12-31 255
PostgreSQL[75]Unlimited 32 TB 1.6 TB 250–1600 depending on type 1 GB (text, bytea) stored inline or 4 TB using pg_largeobject

[76]

1 GB Unlimited −4,713

[77]

5,874,897 63
SAP HANA? ? ? ? ? ? ? ? ? ?
solidDB256 TB 256 TB 32 KB + BLOB data Limited by row size 4 GB 4 GB 64 bits -32768-01-01 32767-12-31 254
SQL Anywhere[78]104 TB (13 files, each file up to 8 TB (32 KB pages)) Limited by file size Limited by file size 45,000 2 GB 2 GB 64 bits 0001-01-01 9999-12-31 128 bytes
SQLite128 TB (231 pages × 64 KB max page size) Limited by file size Limited by file size 32,767 2 GB 2 GB 64 bits No DATE type9No DATE type9Unlimited
TeradataUnlimited Unlimited 64000 wo/lobs
(64 GB w/lobs)
2,048 2 GB 64,000 38 digits 0001-01-01 9999-12-31 128
UniVerseUnlimited Unlimited Unlimited Unlimited Unlimited Unlimited Unlimited Unlimited Unlimited Unlimited
Max DB size Max table size Max row size Max columns per row Max Blob/Clob size Max CHAR size Max NUMBER size Min DATE value Max DATE value Max column name size
  • Note (1): Firebird 2.x maximum database size is effectively unlimited with the largest known database size >980 GB.[79] Firebird 1.5.x maximum database size: 32 TB.
  • Note (2): Limit is 1038 using DECIMAL datatype.[80]
  • Note (3): InnoDB is limited to 8,000 bytes (excluding VARBINARY, VARCHAR, BLOB, or TEXT columns).[81]
  • Note (4): InnoDB is limited to 1,017 columns.[81]
  • Note (6): Using VARCHAR (MAX) in SQL 2005 and later.[82]
  • Note (7): When using a page size of 32 KB, and when BLOB/CLOB data is stored in the database file.
  • Note (8): Java array size limit of 2,147,483,648 (231) objects per array applies. This limit applies to number of characters in names, rows per table, columns per table, and characters per CHAR/VARCHAR.
  • Note (9): Despite the lack of a date datatype, SQLite does include date and time functions,[83] which work for timestamps between 24 November 4714 B.C. and 1 November 5352.
  • Note (10): Informix DATETIME type has adjustable range from YEAR only through 1/10000th second. DATETIME date range is 0001-01-01 00:00:00.00000 through 9999-12-31 23:59:59.99999.
  • Note (11): Since version 12c. Earlier versions support up to 4000 B.
  • Note (12): The 0.5 YB limit refers to the storage limit of a single Informix server instance beginning with v15.0. Informix v12.10 and later versions support using sharding techniques to distribute a table across multiple server instances. A distributed Informix database has no upper limit on table or database size.
  • Note (13): Informix DECIMAL type supports up to 32 decimal digits of precision with a range of 10−130 to 10125. Fixed and variable precision are supported.
  • Note (14): The LONGLVARCHAR type supports strings up to 4TB.

Tables and views

[edit]

Information about what tables and views (other than basic ones) are supported natively.

Temporary table Materialized view
4th DimensionYes No
ADABAS? ?
Adaptive Server EnterpriseYes1Yes – see precomputed result sets
Advantage Database ServerYes No (only common views)
AltibaseYes No (only common views)
Apache DerbyYes No
ClustrixDB Yes No
CUBRIDYes (only CTE) No (only common views)
IBM Db2Yes Yes
Empress Embedded DatabaseYes Yes
EXASolutionYes No
FirebirdYes No (only common views)
HSQLDBYes No
H2Yes No (only common views)
Informix Dynamic ServerYes No2
IngresYes No
InterBaseYes No
Linter SQL RDBMSYes Yes
LucidDBNo No
MariaDBYes No4
MaxDBYes No
Microsoft Access (JET) No No
Microsoft Visual FoxproYes Yes
Microsoft SQL ServerYes Yes
Microsoft SQL Server Compact (Embedded Database)Yes No
Mimer SQLNo No
MonetDBYes No (only common views)
MySQLYes No4
OracleYes Yes
Oracle RdbYes Yes
OpenLink VirtuosoYes Yes
Actian Zen (PSQL)Yes No
Polyhedra DBMSNo No (only common views)
PostgreSQLYes Yes
SAP HANAYes ?
solidDBYes No (only common views)
SQL AnywhereYes Yes
SQLiteYes No
SuperbaseYes Yes
TeradataYes Yes
UniDataYes No
UniVerseYes No
Temporary table Materialized view
  • Note (1): Server provides tempdb, which can be used for public and private (for the session) temp tables.[84]
  • Note (2): Materialized views are not supported in Informix; the term is used in IBM's documentation to refer to a temporary table created to run the view's query when it is too complex, but one cannot for example define the way it is refreshed or build an index on it. The term is defined in the Informix Performance Guide.[85]
  • Note (4): Materialized views can be emulated using stored procedures and triggers.[86]

Indexes

[edit]

Information about what indexes (other than basic B-/B+ tree indexes) are supported natively.

R-/R+ treeHashExpressionPartialReverseBitmapGiSTGINFull-textSpatialForest of Trees Index Duplicate index prevention
4th Dimension? Cluster ? ? ? ? ? ? Yes ? ? No
ADABAS? ? ? ? ? ? ? ? ? ? ? No
Adaptive Server EnterpriseNo No Yes No Yes No No No Yes ? ? No
Advantage Database ServerNo No Yes No Yes Yes No No Yes ? ? No
Apache DerbyNo No No No No No No No No[87]? ? No
ClustrixDB No Yes No No No No No No No No ? No
CUBRIDNo No Yes[88]Yes[88]Yes No No No No No No No
IBM Db2Yes Yes Yes No Yes Yes No No Yes[89]? ? No
Empress Embedded DatabaseYes No No Yes No Yes No No No ? ? No
EXASolutionNo Yes No No No No No No No ? ? No
FirebirdNo No Yes Yes Yes No No No No[90]? ? No
HSQLDBNo No No No No No No No No ? ? No
H2No Yes No No No No No No Yes[91]Yes[92]? No
Informix Dynamic ServerYes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes[93]Yes
IngresYes Yes Ingres v10 No No Ingres v10 No No No ? ? No
InterBaseNo No No No No No No No No ? ? No
Linter SQL RDBMS10No Yes temporary indexes for equality joins Yes for some scalar functions like LOWER and UPPER No No No No No Yes[94]No No Yes
LucidDBNo No No No No Yes No No No ? ? No
MariaDBAria and MyISAM tables and, since v10.2.2, InnoDB tables only[95]MEMORY,[96] InnoDB,5 tables only PERSISTENT virtual columns only[97]No No No No No Yes[98]Aria and MyISAM tables and, since v10.2.2, InnoDB tables only[95]? No
MaxDBNo No No No No No No No No ? ? No
Microsoft Access (JET) No No No No No No No No No[99]? ? No
Microsoft Visual FoxproNo No Yes Yes Yes2Yes No No No ? ? No
Microsoft SQL ServerSpatial Indexes Yes4Yes3Yes on Computed columns3Bitmap filter index for Star Join Query No No Yes[100]Yes[101]? No
Microsoft SQL Server Compact (Embedded Database)No No No No No No No No No[102]? ? No
Mimer SQLNo No No No Yes No No No Yes Yes No No
MonetDBNo Yes No No No No No No No No No No
MySQLSpatial Indexes[103]MEMORY, Cluster (NDB), InnoDB,5 tables only No[104]No No No No No MyISAM tables[105] and, since v5.6.4, InnoDB tables[106]MyISAM tables[107] and, since v5.7.5, InnoDB tables[108]? No
OpenLink VirtuosoYes Cluster Yes Yes No Yes No No Yes Yes (Commercial only) No No
OracleYes 11Cluster Tables Yes Yes 6Yes Yes No No Yes[109]Yes[110]? Yes[111]
Oracle RdbNo Yes ? No No ? No No ? ? ? No
Actian Zen (PSQL)No No No No No No No No No No No No
Polyhedra DBMSNo Yes No No No No No No No No ? No
PostgreSQLYes Yes Yes Yes Yes7Yes Yes[112]Yes Yes[113]PostGIS[114]No No
SAP HANA? ? ? ? ? ? ? ? ? ? ? No
solidDBNo No No No Yes No No No No No No No
SQL AnywhereNo No Yes No No No No No Yes Yes ? Yes
SQLiteYes[115]No Yes[116]Yes No No No No Yes[117]SpatiaLite[118]? No
SQream DB? ? ? ? Yes ? ? ? ? ? ? No
TeradataNo Yes Yes Yes No Yes No No ?[119]? ? No
UniVerseYes Yes Yes3Yes3Yes3No No No ? Yes[120]? No
R-/R+ treeHashExpressionPartialReverseBitmapGiSTGINFull-textSpatialForest of Trees Index Duplicate index prevention
  • Note (1): The users need to use a function from freeAdhocUDF library or similar.[121]
  • Note (2): Can be implemented for most data types using expression-based indexes.
  • Note (3): Can be emulated by indexing a computed column[122] (doesn't easily update) or by using an "Indexed View"[123] (proper name not just any view works[124]).
  • Note (4): Used for InMemory ColumnStore index, temporary hash index for hash join, Non/Cluster & fill factor.
  • Note (5): InnoDB automatically generates adaptive hash index[125] entries as needed.
  • Note (6): Can be implemented using Function-based Indexes in Oracle 8i and higher, but the function needs to be used in the sql for the index to be used.
  • Note (7): A PostgreSQL functional index can be used to reverse the order of a field.
  • Note (10): B+ tree and full-text only for now.
  • Note (11): R-Tree indexing available in base edition with Locator but some functionality requires Personal Edition or Enterprise Edition with Spatial option.
  • Note (12): FOT or Forest of Trees indexes is a type of B-tree index consisting of multiple B-trees which reduces contention in multi-user environments.[126]

Database capabilities

[edit]
UnionIntersectExceptInner joinsOuter joinsInner selects Merge joinsBlobs and clobsCommon table expressionsWindowing functionsParallel query System-versioned tables
4th DimensionYes Yes Yes Yes Yes No No Yes ? ? ? ?
ADABASYes ? ? ? ? ? ? ? ? ? ? ?
Adaptive Server EnterpriseYes ? ? Yes Yes Yes Yes Yes ? ? Yes ?
Advantage Database ServerYes No No Yes Yes Yes Yes Yes ? No ? ?
AltibaseYes Yes Yes, via MINUS Yes Yes Yes Yes Yes No No No ?
Apache DerbyYes Yes Yes Yes Yes Yes ? Yes No No ? ?
ClustrixDB Yes No No Yes Yes Yes No Yes Yes Yes Yes ?
CUBRIDYes Yes Yes Yes Yes Yes Yes Yes Yes Yes[88]? ?
IBM Db2Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes[127]Yes[128]
Empress Embedded DatabaseYes Yes Yes Yes Yes Yes Yes Yes ? ? ? ?
EXASolutionYes Yes Yes Yes Yes Yes Yes No Yes Yes Yes ?
FirebirdYes No No Yes Yes Yes Yes Yes Yes Yes ? ?
HSQLDBYes Yes Yes Yes Yes Yes Yes[129]Yes Yes No Yes[129]?
H2Yes Yes Yes Yes Yes Yes No Yes experimental[130]Yes[131]? ?
Informix Dynamic ServerYes Yes Yes, via MINUS Yes Yes Yes Yes Yes Yes Yes Yes[132]?
IngresYes No No Yes Yes Yes Yes Yes Yes[133]Yes[134]Yes[135]?
InterBaseYes ? ? Yes Yes ? ? Yes ? ? ? ?
Linter SQL RDBMSYes Yes Yes Yes Yes Yes Yes Yes Yes Yes No No
LucidDBYes Yes Yes Yes Yes Yes Yes No ? ? ? ?
MariaDBYes 10.3+[136]10.3+[137]Yes Yes Yes No Yes Yes[138]Yes[139]No[140]Yes[128]
MaxDBYes ? ? Yes Yes Yes No Yes ? ? ? ?
Microsoft Access (JET) Yes No No Yes Yes Yes No Yes No No ? ?
Microsoft Visual FoxproYes ? ? Yes Yes Yes ? Yes ? ? ? ?
Microsoft SQL ServerYes Yes Yes Yes Yes Yes Yes Yes Yes Yes[141]Yes[142]Yes[128]
Microsoft SQL Server Compact (Embedded Database)Yes No No Yes Yes ? No Yes No No ? ?
Mimer SQLYes Yes Yes Yes Yes Yes ? Yes Yes No No ?
MonetDBYes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes No
MySQLYes 8+[143]8+[144]Yes Yes Yes No Yes 8+[145]8+[146]No[140]No[128]
OpenLink VirtuosoYes Yes Yes Yes Yes Yes ? Yes ? ? Yes ?
OracleYes Yes Yes, via MINUS Yes Yes Yes Yes Yes Yes 1Yes Yes[147]Yes[148]
Oracle RdbYes Yes Yes Yes Yes Yes Yes Yes ? ? ? ?
Actian Zen (PSQL)Yes No No Yes Yes ? ? Yes No No No ?
Polyhedra DBMSYes Yes Yes Yes Yes No No Yes No No No ?
PostgreSQLYes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes[149]No[128]
SAP HANA? ? ? ? ? ? ? ? ? ? ? ?
solidDBYes Yes Yes Yes Yes Yes Yes Yes Yes No No ?
SQL AnywhereYes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes ?
SQLiteYes Yes Yes Yes 3.43.0+[150]Yes No Yes 3.8.3+[151]3.25+[152]No No[128]
SQream DBALL only No No Yes Yes Yes Yes No Yes Yes No ?
TeradataYes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes ?
UniVerseYes Yes Yes Yes Yes Yes Yes No No No ? ?
UnionIntersectExceptInner joinsOuter joinsInner selects Merge joinsBlobs and clobsCommon table expressionsWindowing functionsParallel query System-versioned tables
  • Note (1): Recursive CTEs introduced in 11gR2 supersedes similar construct called CONNECT BY.

Data types

[edit]
Type systemIntegerFloating pointDecimal StringBinaryDate/Time BooleanOther
4th DimensionStatic UUID (16-bit), SMALLINT (16-bit), INT (32-bit), BIGINT (64-bit), NUMERIC (64-bit) REAL, FLOATREAL, FLOATCLOB, TEXT, VARCHARBIT, BITVARYING, BLOBDURATION, INTERVAL, TIMESTAMPBOOLEANPICTURE
Altibase[153]Static SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) REAL (32-bit), DOUBLE (64-bit) DECIMAL, NUMERIC, NUMBER, FLOATCHAR, VARCHAR, NCHAR, NVARCHAR, CLOBBLOB, BYTE, NIBBLE, BIT, VARBITDATEGEOMETRY
ClustrixDB[154]Static TINYINT (8-bit), SMALLINT (16-bit), MEDIUMINT (24-bit), INT (32-bit), BIGINT (64-bit) FLOAT (32-bit), DOUBLEDECIMALCHAR, BINARY, VARCHAR, VARBINARY, TEXT, TINYTEXT, MEDIUMTEXT, LONGTEXTTINYBLOB, BLOB, MEDIUMBLOB, LONGBLOBDATETIME, DATE, TIMESTAMP, YEARBIT(1), BOOLEANENUM, SET,
CUBRID[155]Static SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) FLOAT, REAL(32-bit), DOUBLE(64-bit) DECIMAL, NUMERICCHAR, VARCHAR, NCHAR, NVARCHAR, CLOBBLOBDATE, DATETIME, TIME, TIMESTAMPBITMONETARY, BITVARYING, SET, MULTISET, SEQUENCE, ENUM
IBM Db2? SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) DECFLOAT, REAL, DOUBLEDECIMALCLOB, CHAR, VARCHARBINARY, VARBINARY, BLOBDATE, TIME, TIMESTAMPWITHTIMEZONE, TIMESTAMPWITHOUTTIMEZONEBOOLEANXML, GRAPHIC, VARGRAPHIC, DBCLOB, ROWID
Empress Embedded DatabaseStatic TINYINT, SQL_TINYINT, or INTEGER8; SMALLINT, SQL_SMALLINT, or INTEGER16; INTEGER, INT, SQL_INTEGER, or INTEGER32; BIGINT, SQL_BIGINT, or INTEGER64REAL, SQL_REAL, or FLOAT32; DOUBLEPRECISION, SQL_DOUBLE, or FLOAT64; FLOAT, or SQL_FLOAT; EFLOATDECIMAL, DEC, NUMERIC, SQL_DECIMAL, or SQL_NUMERIC; DOLLARCHARACTER, ECHARACTER, CHARACTERVARYING, NATIONALCHARACTER, NATIONALCHARACTERVARYING, NLSCHARACTER, CHARACTERLARGEOBJECT, TEXT, NATIONALCHARACTERLARGEOBJECT, NLSTEXTBINARYLARGEOBJECT or BLOB; BULKDATE, EDATE, TIME, ETIME, EPOCH_TIME, TIMESTAMP, MICROTIMESTAMPBOOLEANSEQUENCE 32, SEQUENCE
EXASolutionStatic TINYINT, SMALLINT, INTEGER, BIGINT, REAL, FLOAT, DOUBLEDECIMAL, DEC, NUMERIC, NUMBERCHAR, NCHAR, VARCHAR, VARCHAR2, NVARCHAR, NVARCHAR2, CLOB, NCLOBN/A DATE, TIMESTAMP, INTERVALBOOLEAN, BOOLGEOMETRY
FileMaker[156]Static Not Supported Not Supported NUMBERTEXTCONTAINERTIMESTAMPNot Supported
Firebird[157]? INT128, INT64, INTEGER, SMALLINTDOUBLE, FLOATDECIMAL, NUMERIC, DECIMAL(38, 4), DECIMAL(10, 4) BLOB, CHAR, CHAR(x)CHARACTERSETUNICODE_FSS, VARCHAR(x)CHARACTERSETUNICODE_FSS, VARCHARBLOBSUB_TYPETEXT, BLOBDATE, TIME, TIMESTAMP (without time zone and with time zone) BOOLEANTIMESTAMP, TIMESTAMP WITH TIME ZONE, CHAR(38), User defined types (Domains)
Type systemIntegerFloating pointDecimal StringBinaryDate/Time BooleanOther
HSQLDB[158]Static TINYINT (8-bit), SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) DOUBLE (64-bit) DECIMAL, NUMERICCHAR, VARCHAR, LONGVARCHAR, CLOBBINARY, VARBINARY, LONGVARBINARY, BLOBDATE, TIME, TIMESTAMP, INTERVALBOOLEANOTHER (object), BIT, BITVARYING, ARRAY
Informix Dynamic Server[159]Static + UDTSMALLINT (16-bit), INT (32-bit), INT8 (64-bit proprietary), BIGINT (64-bit) SMALLFLOAT (32-bit), FLOAT (64-bit) DECIMAL (32 decimal digits float/fixed, range 10130 to +10125), MONEYCHAR, VARCHAR, NCHAR, NVARCHAR, LVARCHAR, CLOB, TEXT, LONGLVARCHARTEXT, BYTE, BLOB, CLOBDATE, DATETIME, INTERVALBOOLEANSET, LIST, MULTISET, ROW, TIMESERIES, SPATIAL, GEODETIC, NODE, JSON, BSON, USERDEFINEDTYPES
Ingres[160]Static TINYINT (8-bit), SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) FLOAT4 (32-bit), FLOAT (64-bit) DECIMALC, CHAR, VARCHAR, LONGVARCHAR, NCHAR, NVARCHAR, LONGNVARCHAR, TEXTBYTE, VARBYTE, LONGVARBYTE (BLOB) DATE, ANSIDATE, INGRESDATE, TIME, TIMESTAMP, INTERVALN/A MONEY, OBJECT_KEY, TABLE_KEY, USER-DEFINEDDATATYPES (via OME)
Linter SQL RDBMSStatic + Dynamic (in stored procedures) SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) REAL(32-bit), DOUBLE(64-bit) DECIMAL, NUMERICCHAR, VARCHAR, NCHAR, NVARCHAR, BLOBBYTE, VARBYTE, BLOBDATEBOOLEANGEOMETRY, EXTFILE
MariaDB[161]Static TINYINT (8-bit), SMALLINT (16-bit), MEDIUMINT (24-bit), INT (32-bit), BIGINT (64-bit) FLOAT (32-bit), DOUBLE (aka REAL) (64-bit) DECIMALCHAR, BINARY, VARCHAR, VARBINARY, TEXT, TINYTEXT, MEDIUMTEXT, LONGTEXTTINYBLOB, BLOB, MEDIUMBLOB, LONGBLOBDATETIME, DATE, TIMESTAMP, YEARBIT(1), BOOLEAN (aka BOOL) = synonym for TINYINTENUM, SET, GIS data types (Geometry, Point, Curve, LineString, Surface, Polygon, GeometryCollection, MultiPoint, MultiCurve, MultiLineString, MultiSurface, MultiPolygon)
Microsoft SQL Server[162]Static TINYINT, SMALLINT, INT, BIGINTFLOAT, REALNUMERIC, DECIMAL, SMALLMONEY, MONEYCHAR, VARCHAR, TEXT, NCHAR, NVARCHAR, NTEXTBINARY, VARBINARY, IMAGE, FILESTREAM, FILETABLEDATE, DATETIMEOFFSET, DATETIME2, SMALLDATETIME, DATETIME, TIMEBITCURSOR, TIMESTAMP, HIERARCHYID, UNIQUEIDENTIFIER, SQL_VARIANT, XML, TABLE, Geometry, Geography, Custom .NET datatypes
Microsoft SQL Server Compact (Embedded Database)[163]Static TINYINT, SMALLINT, INT, BIGINTFLOAT, REALNUMERIC, DECIMAL, MONEYNCHAR, NVARCHAR, NTEXTBINARY, VARBINARY, IMAGEDATETIMEBITTIMESTAMP, ROWVERSION, UNIQUEIDENTIFIER, IDENTITY, ROWGUIDCOL
Mimer SQLStatic SMALLINT, INT, BIGINT, INTEGER(n)FLOAT, REAL, DOUBLE, FLOAT(n)NUMERIC, DECIMALCHAR, VARCHAR, NCHAR, NVARCHAR, CLOB, NCLOBBINARY, VARBINARY, BLOBDATE, TIME, TIMESTAMP, INTERVALBOOLEANDOMAINS, USER-DEFINED TYPES (including the pre-defined spatial data types location, latitude, longitude and coordinate, and UUID)
MonetDBStatic, extensible TINYINT, SMALLINT, INT, INTEGER, BIGINT, HUGEINT, SERIAL, BIGSERIALFLOAT, FLOAT(n), REAL, DOUBLE, DOUBLEPRECISIONDECIMAL, NUMERICCHAR, CHAR(n), VARCHAR(n), CLOB, CLOB(n), TEXT, STRINGBLOB, BLOB(n)DATE, TIME, TIMEWITHTIMEZONE, TIMESTAMP, TIMESTAMPWITHTIMEZONE, INTERVALMONTH, INTERVALDAY, INTERVALSECONDBOOLEANJSON, JSON(n), URL, URL(n), INET, UUID, GIS data types (Geometry, Point, Curve, LineString, Surface, Polygon, GeometryCollection, MultiPoint, MultiCurve, MultiLineString, MultiSurface, MultiPolygon), User Defined Types
MySQL[154]Static TINYINT (8-bit), SMALLINT (16-bit), MEDIUMINT (24-bit), INT (32-bit), BIGINT (64-bit) FLOAT (32-bit), DOUBLE (aka REAL) (64-bit) DECIMALCHAR, BINARY, VARCHAR, VARBINARY, TEXT, TINYTEXT, MEDIUMTEXT, LONGTEXTTINYBLOB, BLOB, MEDIUMBLOB, LONGBLOBDATETIME, DATE, TIMESTAMP, YEARBIT(1), BOOLEAN (aka BOOL) = synonym for TINYINTENUM, SET, GIS data types (Geometry, Point, Curve, LineString, Surface, Polygon, GeometryCollection, MultiPoint, MultiCurve, MultiLineString, MultiSurface, MultiPolygon)
OpenLink Virtuoso[164]Static + Dynamic INT, INTEGER, SMALLINTREAL, DOUBLEPRECISION, FLOAT, FLOAT(n)DECIMAL, DECIMAL(n), DECIMAL(m, n), NUMERIC, NUMERIC(n), NUMERIC(m, n)CHARACTER, CHAR(n), VARCHAR, VARCHAR(n), NVARCHAR, NVARCHAR(n)BLOBTIMESTAMP, DATETIME, TIME, DATEN/A ANY, REFERENCE (IRI, URI), UDT (User Defined Type), GEOMETRY (BOX, BOX2D, BOX3D, BOXM, BOXZ, BOXZM, CIRCULARSTRING, COMPOUNDCURVE, CURVEPOLYGON, EMPTY, GEOMETRYCOLLECTION, GEOMETRYCOLLECTIONM, GEOMETRYCOLLECTIONZ, GEOMETRYCOLLECTIONZM, LINESTRING, LINESTRINGM, LINESTRINGZ, LINESTRINGZM, MULTICURVE, MULTILINESTRING, MULTILINESTRINGM, MULTILINESTRINGZ, MULTILINESTRINGZM, MULTIPOINT, MULTIPOINTM, MULTIPOINTZ, MULTIPOINTZM, MULTIPOLYGON, MULTIPOLYGONM, MULTIPOLYGONZ, MULTIPOLYGONZM, POINT, POINTM, POINTZ, POINTZM, POLYGON, POLYGONM, POLYGONZ, POLYGONZM, POLYLINE, POLYLINEZ, RING, RINGM, RINGZ, RINGZM)
Type systemIntegerFloating pointDecimal StringBinaryDate/Time BooleanOther
Oracle[165]Static + Dynamic (through ANYDATA) NUMBERBINARY_FLOAT, BINARY_DOUBLENUMBERCHAR, VARCHAR2, CLOB, NCLOB, NVARCHAR2, NCHAR, LONG (deprecated) BLOB, RAW, LONGRAW (deprecated), BFILEDATE, TIMESTAMP (with/without TIMEZONE), INTERVALN/A SPATIAL, IMAGE, AUDIO, VIDEO, DICOM, XMLType, UDT, JSON
Actian Zen (PSQL)[166]Static BIGINT, INTEGER, SMALLINT, TINYINT, UBIGINT, UINTEGER, USMALLINT, UTINYINTBFLOAT4, BFLOAT8, DOUBLE, FLOATDECIMAL, NUMERIC, NUMERICSA, NUMERICSLB, NUMERICSLS, NUMERICSTB, NUMERICSTSCHAR, LONGVARCHAR, VARCHARBINARY, LONGVARBINARY, VARBINARYDATE, DATETIME, TIMEBITCURRENCY, IDENTITY, SMALLIDENTITY, TIMESTAMP, UNIQUEIDENTIFIER
Polyhedra[167]Static INTEGER8 (8-bit), INTEGER(16-bit), INTEGER (32-bit), INTEGER64 (64-bit) FLOAT32 (32-bit), FLOAT (aka REAL; 64-bit) N/A VARCHAR, LARGEVARCHAR (aka CHARACTERLARGEOBJECT) LARGEBINARY (aka BINARYLARGEOBJECT) DATETIMEBOOLEANN/A
PostgreSQL[168]Static SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) REAL (32-bit), DOUBLEPRECISION (64-bit) DECIMAL, NUMERICCHAR, VARCHAR, TEXTBYTEADATE, TIME (with/without TIMEZONE), TIMESTAMP (with/without TIMEZONE), INTERVALBOOLEANENUM, POINT, LINE, LSEG, BOX, PATH, POLYGON, CIRCLE, CIDR, INET, MACADDR, BIT, UUID, XML, JSON, JSONB, arrays, composites, ranges, custom
SAP HANAStatic TINYINT, SMALLINT, INTEGER, BIGINTSMALLDECIMAL, REAL, DOUBLE, FLOAT, FLOAT(n)DECIMALVARCHAR, NVARCHAR, ALPHANUM, SHORTTEXTVARBINARY, BINTEXT, BLOBDATE, TIME, SECONDDATE, TIMESTAMPBOOLEANCLOB, NCLOB, TEXT, ARRAY, ST_GEOMETRY, ST_POINT, ST_MULTIPOINT, ST_LINESTRING, ST_MULTILINESTRING, ST_POLYGON, ST_MULTIPOLYGON, ST_GEOMETRYCOLLECTION, ST_CIRCULARSTRING
solidDBStatic TINYINT (8-bit), SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) REAL (32-bit), DOUBLE (64-bit), FLOAT (64-bit) DECIMAL, NUMERIC (51 digits) CHAR, VARCHAR, LONGVARCHAR, WCHAR, WVARCHAR, LONGWVARCHARBINARY, VARBINARY, LONGVARBINARYDATE, TIME, TIMESTAMP
SQLite[169]Dynamic INTEGER (64-bit) REAL (aka FLOAT, DOUBLE) (64-bit) N/A TEXT (aka CHAR, CLOB) BLOBN/A N/A N/A
SQream DB[170]Static TINYINT (8-bit), SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) REAL (32-bit), DOUBLE (aka FLOAT) (64-bit) N/A CHAR, VARCHAR, NVARCHARN/A DATE, DATETIME (aka TIMESTAMP) BOOLN/A
Type systemIntegerFloating pointDecimal StringBinaryDate/Time BooleanOther
TeradataStatic BYTEINT (8-bit), SMALLINT (16-bit), INTEGER (32-bit), BIGINT (64-bit) FLOAT (64-bit) DECIMAL, NUMERIC (38 digits) CHAR, VARCHAR, CLOBBYTE, VARBYTE, BLOBDATE, TIME, TIMESTAMP (w/wo TIMEZONE) PERIOD, INTERVAL, GEOMETRY, XML, JSON, UDT (User Defined Type)
UniDataDynamic N/A N/A N/A N/A N/A N/A N/A N/A
UniVerseDynamic N/A N/A N/A N/A N/A N/A N/A N/A
Type systemIntegerFloating pointDecimal StringBinaryDate/Time BooleanOther

Other objects

[edit]

Information about what other objects are supported natively.

Data domainCursorTriggerFunction1Procedure1External routine1
4th DimensionYes No Yes Yes Yes Yes
ADABAS? Yes ? Yes? Yes? Yes
Adaptive Server EnterpriseYes Yes Yes Yes Yes Yes
Advantage Database ServerYes Yes Yes Yes Yes Yes
AltibaseYes Yes Yes Yes Yes Yes
Apache DerbyNo Yes Yes Yes2Yes2Yes2
ClustrixDB No Yes No Yes Yes Yes
CUBRIDYes Yes Yes Yes Yes2Yes
Empress Embedded DatabaseYes via RANGE CHECK Yes Yes Yes Yes Yes
EXASolutionYes No No Yes Yes Yes
IBM Db2Yes via CHECK CONSTRAINT Yes Yes Yes Yes Yes
FirebirdYes Yes Yes Yes Yes Yes
HSQLDBYes No Yes Yes Yes Yes
H2Yes No Yes2Yes2Yes2Yes
Informix Dynamic ServerYes via CHECK Yes Yes Yes Yes Yes 5
IngresYes Yes Yes Yes Yes Yes
InterBaseYes Yes Yes Yes Yes Yes
Linter SQL RDBMSNo Yes Yes Yes Yes No
LucidDBNo Yes No Yes2Yes2Yes2
MariaDBYes[171]Yes Yes Yes Yes Yes
MaxDBYes Yes Yes Yes Yes ?
Microsoft Access (JET) Yes No No No Yes, But single DML/DDL Operation Yes
Microsoft Visual FoxproNo Yes Yes Yes Yes Yes
Microsoft SQL ServerYes Yes Yes Yes Yes Yes
Microsoft SQL Server Compact (Embedded Database)No Yes No No No No
Mimer SQLYes Yes Yes Yes Yes No
MonetDBNo No Yes Yes Yes Yes
MySQLNo 3Yes Yes Yes Yes Yes
OracleYes Yes Yes Yes Yes Yes
Oracle RdbYes Yes Yes Yes Yes Yes
OpenLink VirtuosoYes Yes Yes Yes Yes Yes
Actian Zen (PSQL)Yes Yes Yes Yes Yes No
Polyhedra DBMSNo No Yes Yes Yes Yes
PostgreSQLYes Yes Yes Yes Yes Yes
SAP HANA? ? ? ? ? ?
solidDBYes Yes Yes Yes Yes Yes
SQL AnywhereYes Yes Yes Yes Yes Yes
SQLiteNo No Yes No No Yes
TeradataNo Yes Yes Yes Yes Yes
UniDataNo No Yes Yes Yes Yes
UniVerseNo No Yes Yes Yes Yes
Data domainCursorTriggerFunction1Procedure1External routine1
  • Note (1): Both function and procedure refer to internal routines written in SQL and/or procedural language like PL/SQL. External routine refers to the one written in the host languages, such as C, Java, Cobol, etc. "Stored procedure" is a commonly used term for these routine types. However, its definition varies between different database vendors.
  • Note (2): In Derby, H2, LucidDB, and CUBRID, users code functions and procedures in Java.
  • Note (3): ENUM datatype exists. CHECK clause is parsed, but not enforced in runtime.
  • Note (5): Informix supports external functions written in Java, C, & C++.

Partitioning

[edit]

Information about what partitioning methods are supported natively.

Range Hash Composite (Range+Hash) List Expression Round Robin
4th Dimension? ? ? ? ? ?
ADABAS? ? ? ? ? ?
Adaptive Server EnterpriseYes Yes No Yes ? ?
Advantage Database ServerNo No No No ? ?
AltibaseYes Yes No Yes ? ?
Apache DerbyNo No No No ? ?
ClustrixDB Yes No No No No ?
CUBRIDYes Yes No Yes ? ?
IBM Db2Yes Yes Yes Yes Yes ?
Empress Embedded DatabaseNo No No No ? ?
EXASolutionNo Yes No No No ?
FirebirdNo No No No ? ?
HSQLDBNo No No No ? ?
H2No No No No ? ?
Informix Dynamic ServerYes Yes Yes Yes Yes Yes
IngresYes Yes Yes Yes ? ?
InterBaseNo No No No ? ?
Linter SQL RDBMSNo No No No No ?
MariaDBYes Yes Yes Yes ? ?
MaxDBNo No No No ? ?
Microsoft Access (JET) No No No No ? ?
Microsoft Visual FoxproNo No No No ? ?
Microsoft SQL ServerYes via computed column via computed column Yes via computed column ?
Microsoft SQL Server Compact (Embedded Database)No No No No ? ?
Mimer SQLNo No No No No ?
MonetDBYes No No No Yes ?
MySQLYes Yes Yes Yes ? ?
OracleYes Yes Yes Yes via Virtual Columns ?
Oracle RdbYes Yes ? ? ? ?
OpenLink VirtuosoYes Yes Yes Yes Yes ?
Actian Zen (PSQL)No No No No No ?
Polyhedra DBMSNo No No No No ?
PostgreSQLYes Yes Yes Yes Yes ?
SAP HANAYes Yes Yes Yes Yes ?
solidDBYes No No No ? ?
SQL AnywhereNo No No No ? ?
SQLiteNo No No No ? ?
TeradataYes Yes Yes Yes ? ?
UniVerseYes Yes Yes Yes ? ?
Range Hash Composite (Range+Hash) List Expression Round Robin

Access control

[edit]

Information about access control functionalities.

Native network encryption1Brute-force protectionEnterprise directory compatibility Password complexity rules2Patch access3Run unprivileged4Audit
Resource limit
Separation of duties
(RBAC)5
Security Certification
4DYes (with SSL) ? Yes ? Yes Yes ? ? ? ? ?
Adaptive Server EnterpriseYes (optional; to pay) Yes Yes (optional ?) Yes Partial (need to register; depend on which product)[172]Yes Yes Yes Yes Yes (EAL4+ 1) ?
Advantage Database ServerYes No No No Yes Yes No No Yes ? ?
CUBRIDYes (with SSL) ? No No Yes Yes Yes Yes Yes ? ?
IBM Db2Yes ? Yes (LDAP, Kerberos...) Yes ? Yes Yes Yes Yes Yes (EAL4+6) ?
Empress Embedded Database? ? No No Yes Yes Yes No Yes No ?
EXASolutionNo Yes Yes (LDAP) Yes Yes Yes Yes Yes Yes No ?
FirebirdYes Yes[173]Yes (Windows trusted authenification) Yes (by custom plugin) Yes (no security page)[174]Yes Yes[175]Yes No7? ?
HSQLDBYes No Yes Yes Yes Yes No No Yes No ?
H2Yes Yes ? No ? Yes ? Yes Yes No ?
Informix Dynamic ServerYes ? Yes10?10Yes Yes Yes Yes Yes ? Yes
Linter SQL RDBMSYes (with SSL) Yes Yes Yes (length only) Yes Yes Yes Yes Yes Yes Yes
MariaDBYes (SSL) No Yes (with 5.2, but not on Windows servers) Yes[176][177]Yes[178]Yes ? ? ?8No ?
Microsoft SQL ServerYes ? Yes (Microsoft Active Directory) Yes Yes Yes Yes (From 2008) Yes Yes Yes (EAL4+11) ?
Microsoft SQL Server Compact (Embedded Database)No (not relevant, only file permissions) No (not relevant) No (not relevant) No (not relevant) Yes Yes (file access) Yes Yes No ? ?
Mimer SQLYes ? ? ? Yes Yes (depending on OS) Yes ? Yes ? Yes
MySQLYes (SSL with 4.0) No Yes (with 5.5, but only in commercial edition) No Partial (no security page)[179]Yes ? ? ?8Yes ?
OpenLink VirtuosoYes Yes Yes Yes (optional) Yes (optional) Yes Yes (optional) Yes (optional) Yes No Yes (optional)
OracleYes Yes Yes Yes ? Yes Yes Yes Yes Yes (EAL21) ?
Actian Zen (PSQL)Yes ? No No Yes Yes Yes 12No No No ?
Polyhedra DBMSYes (with SSL. Optional) No No No No Yes Yes 13Yes Yes 13No ?
PostgreSQLYes Yes Yes (LDAP, Kerberos...9) Yes (with passwordcheck module) Yes[180]Yes Yes (with pgaudit extension)[181]Yes Yes Yes (EAL2+1) ?
SAP HANA? ? ? ? ? ? ? ? ? ? ?
solidDBNo No Yes No No Yes Yes No No No No
SQL AnywhereYes ? Yes (Kerberos) Yes ? Yes Yes No Yes Yes (EAL2+1 as Adaptive Server Anywhere) ?
SQLiteNo (not relevant, only file permissions) No (not relevant) No (not relevant) No (not relevant) Partial (no security page)[182]Yes (file access) Yes Yes No No ?
TeradataYes No Yes (LDAP, Kerberos...) Yes ? Yes Yes Yes Yes Yes Yes
Native network encryption1Brute-force protection Enterprise directory compatibility Password complexity rules2Patch access3Run unprivileged4Audit
Resource limit
Separation of duties
(RBAC)5
Security Certification
  • Note (1): Network traffic could be transmitted in a secure way (not clear-text, in general SSL encryption). Precise if option is default, included option or an extra modules to buy.
  • Note (2): Options are present to set a minimum size for password, respect complexity like presence of numbers or special characters.
  • Note (3): How do you get security updates? Is it free access, do you need a login or to pay? Is there easy access through a Web/FTP portal or RSS feed or only through offline access (mail CD-ROM, phone).
  • Note (4): Does database process run as root/administrator or unprivileged user? What is default configuration?
  • Note (5): Is there a separate user to manage special operation like backup (only dump/restore permissions), security officer (audit), administrator (add user/create database), etc.? Is it default or optional?
  • Note (6): Common Criteria certified product list.[183]
  • Note (7): FirebirdSQL seems to only have SYSDBA user and DB owner. There are no separate roles for backup operator and security administrator.
  • Note (8): User can define a dedicated backup user but nothing particular in default install.[184]
  • Note (9): Authentication methods.[185]
  • Note (10): Informix Dynamic Server supports PAM and other configurable authentication. By default uses OS authentication.
  • Note (11): Authentication methods.[186]
  • Note (12): With the use of Pervasive AuditMaster.
  • Note (13): User-based security is optional in Polyhedra, but when enabled can be enhanced to a role-based model with auditing.[187]

Databases vs schemas (terminology)

[edit]

The SQL specification defines what an "SQL schema" is; however, databases implement it differently. To compound this confusion the functionality can overlap with that of a parent database. An SQL schema is simply a namespace within a database; things within this namespace are addressed using the member operator dot ".". This seems to be a universal among all of the implementations.

A true fully (database, schema, and table) qualified query is exemplified as such: SELECT*FROMdatabase.schema.table

Both a schema and a database can be used to isolate one table, "foo", from another like-named table "foo". The following is pseudo code:

  • SELECT*FROMdatabase1.foo vs. SELECT*FROMdatabase2.foo (no explicit schema between database and table)
  • SELECT*FROM[database1.]default.foo vs. SELECT*FROM[database1.]alternate.foo (no explicit database prefix)

The problem that arises is that former MySQL users will create multiple databases for one project. In this context, MySQL databases are analogous in function to PostgreSQL-schemas, insomuch as PostgreSQL deliberately lacks off-the-shelf cross-database functionality (preferring multi-tenancy) that MySQL has. Conversely, PostgreSQL has applied more of the specification implementing cross-table, cross-schema, and then left room for future cross-database functionality.

MySQL aliases schema with database behind the scenes, such that CREATE SCHEMA and CREATE DATABASE are analogs. It can therefore be said that MySQL has implemented cross-database functionality, skipped schema functionality entirely, and provided similar functionality into their implementation of a database. In summary, PostgreSQL fully supports schemas and multi-tenancy by strictly separating databases from each other and thus lacks some functionality MySQL has with databases, while MySQL does not even attempt to support standard schemas.

Oracle has its own spin where creating a user is synonymous with creating a schema. Thus a database administrator can create a user called PROJECT and then create a table PROJECT.TABLE. Users can exist without schema objects, but an object is always associated with an owner (though that owner may not have privileges to connect to the database). With the 'shared-everything' Oracle RAC architecture, the same database can be opened by multiple servers concurrently. This is independent of replication, which can also be used, whereby the data is copied for use by different servers. In the Oracle implementation, a 'database' is a set of files which contains the data while the 'instance' is a set of processes (and memory) through which a database is accessed.

Informix supports multiple databases in a server instance like MySQL. It supports the CREATE SCHEMA syntax as a way to group DDL statements into a single unit creating all objects created as a part of the schema as a single owner. Informix supports a database mode called ANSI mode which supports creating objects with the same name but owned by different users.

PostgreSQL and some other databases have support for foreign schemas, which is the ability to import schemas from other servers as defined in ISO/IEC 9075-9 (published as part of SQL:2008). This appears like any other schema in the database according to the SQL specification while accessing data stored either in a different database or a different server instance. The import can be made either as an entire foreign schema or merely certain tables belonging to that foreign schema.[188] While support for ISO/IEC 9075-9 bridges the gap between the two competing philosophies surrounding schemas, MySQL and Informix maintain an implicit association between databases while ISO/IEC 9075-9 requires that any such linkages be explicit in nature.

See also

[edit]

References

[edit]
  1. ^"Product Release Life Cycle". 10 January 2020.
  2. ^"Apache Derby: Downloads". Retrieved 2024-03-18.
  3. ^"- ASF JIRA". issues.apache.org.
  4. ^"cockroachdb Issue tracker". GitHub. Archived from the original on 2021-05-06. Retrieved 2021-05-03.
  5. ^"Issue Navigator - CUBRID Bug Tracking System". jira.cubrid.org.
  6. ^Stevens, O. (Oct–Dec 2009). "The History of Datacom/DB". Annals of the History of Computing. 31 (4). IEEE: 87–91. doi:10.1109/MAHC.2009.108. ISSN 1058-6180. S2CID 16803811.
  7. ^"CA Datacom - CA Technologies". Archived from the original on 2016-02-14. Retrieved 2014-07-06.
  8. ^"Datacom Product Sheet"(PDF).
  9. ^"IBM unveils Db2 12.1". 21 October 2024. Retrieved 6 December 2024.
  10. ^"Release 5.0.2". 12 February 2025. Retrieved 20 February 2025.
  11. ^IPL, Firebird SQL
  12. ^IDPL, Firebird SQL
  13. ^"Firebird RDBMS Issue Tracker". Archived from the original on 2008-08-28. Retrieved 2017-11-01.
  14. ^"HyperSQL Database Engine (HSQLDB) / Bugs". sourceforge.net.
  15. ^"Issues · h2database/h2database". GitHub.
  16. ^"Actian X & Ingres - Lifecycle Dates".
  17. ^"Linter Techsupport". Archived from the original on 2019-03-27. Retrieved 2019-04-04.
  18. ^"Release 11.7.2". 13 February 2025. Retrieved 25 February 2025.
  19. ^"MariaDB licenses".
  20. ^"- Jira". jira.mariadb.org.
  21. ^"MaxDB PTS - Problem Tracking". maxdb.sap.com.
  22. ^"Explore SQL Server 2022 capabilities". Retrieved 6 January 2023.
  23. ^"MonetDB Foundation". 4 April 2023.
  24. ^"MonetDB Latest Release". 26 August 2024.
  25. ^MonetDB License MPL2.0, MonetDB Foundation, 8 February 2022
  26. ^"MonetDB Issues". GitHub. Archived from the original on 2021-05-13. Retrieved 2021-06-08.
  27. ^mSQL, Products, AU: Hughes, archived from the original on 2009-10-15, retrieved 2009-09-13
  28. ^"Changes in MySQL 8.0.38 (2024-07-01, General Availability)". 1 July 2024. Retrieved 1 July 2024.
  29. ^"MySQL Bugs". bugs.mysql.com.
  30. ^"Issues · openlink/virtuoso-opensource · GitHub". GitHub. Archived from the original on 2020-12-23. Retrieved 2017-11-01.
  31. ^"Oracle Database 23c: The Next Long Term Support Release".
  32. ^"Oracle Rdb Product Family Compatibility Matrix". oracle.com.
  33. ^Polyhedra Lite In-Memory Relational Database System Freeware Available Now from Enea, Press Release, EECatalog.
  34. ^"PostgreSQL 17.4, 16.8, 15.12, 14.17, and 13.20 Released!". PostgreSQL. The PostgreSQL Global Development Group. 2025-02-20. Retrieved 2025-02-21.
  35. ^"PostgreSQL: License". www.postgresql.org.
  36. ^"A bug tracker for PostgreSQL? [LWN.net]". lwn.net.
  37. ^"SQLite Release 3.49.1 On 2025-02-18". 18 February 2025. Retrieved 19 February 2025.
  38. ^"SQLite: Ticket Main Menu". www.sqlite.org.
  39. ^SQream DB Version 2.1 SQL Reference Guide, SQream Technologies, archived from the original on 2018-02-12, retrieved 2018-02-12
  40. ^"Bug Reports".
  41. ^"Release 8.5.1". 17 January 2025. Retrieved 30 January 2025.
  42. ^"Issues · pingcap/Tidb". GitHub.
  43. ^"yugabyte/yugabyte-db". github.com.
  44. ^"Issues · yugabyte/Yugabyte-db". GitHub.
  45. ^"Firebird: The true open source database for Windows, Linux, Mac OS X and more".
  46. ^"Ingres 11.0 Documentation". docs.actian.com.
  47. ^"Building MariaDB on Mac OS X using Homebrew". AskMonty KnowledgeBase. Archived from the original on October 20, 2011. Retrieved September 30, 2011.
  48. ^https://play.google.com/store/apps/details?id=com.esminis.server.mariadb&hl=de MariaDB Android Version by Tautvydas Andrikys
  49. ^"Announcing SQL Server on Linux". 7 March 2016.
  50. ^"Mimer SQL is now available for OpenVMS on x86". 31 March 2023.
  51. ^http://techotv.com/run-apache-mysql-php-http-web-server-android-os-phone-tablet/ Run Apache, Mysql, Php – Web server on Android mobile or Tablet
  52. ^"Aminet - dev/Gg/Postgresql632-mos-bin.lha". Archived from the original on 2017-03-14. Retrieved 2017-03-14.
  53. ^"PostgreSQL - Oss4zos". Archived from the original on 2015-05-27. Retrieved 2013-08-15.
  54. ^"Lock granularity". db.apache.org.
  55. ^"DB2 for Linux UNIX and Windows 9.7.0>Fundamentos de DB2>Performance tuning>Factors affecting performance>Application design>Concurrency issues>Isolation levels". Archived from the original on 2014-04-15. Retrieved 2014-04-14.
  56. ^"Advanced".
  57. ^ abcd"Transactional DDL in PostgreSQL: A Competitive Analysis - PostgreSQL wiki". wiki.postgresql.org.
  58. ^"[MDEV-4259] transactional DDL - Jira". jira.mariadb.org.
  59. ^"SQL Server Transaction Locking and Row Versioning Guide".
  60. ^"MySQL :: MySQL 5.6 Reference Manual :: 8.10.1 Internal Locking Methods". Archived from the original on 2018-03-06. Retrieved 2018-03-05.
  61. ^"dba-oracle.com".
  62. ^"Polyhedra 8.7 new headline feature: locking".
  63. ^"PostgreSQL: Documentation: Explicit Locking : Row-Level Locks". Archived from the original on 2021-05-13. Retrieved 2021-05-13.
  64. ^Lane, Tom (April 13, 2011). "Re: BUG #5974: UNION construct type cast gives poor error message". PostgreSQL Mailing List Archives.
  65. ^"SAP Help Portal". help.sap.com.
  66. ^"SAP Help Portal". help.sap.com.
  67. ^"SAP Help Portal". help.sap.com.
  68. ^"File Locking And Concurrency In SQLite Version 3". www.sqlite.org.
  69. ^SQLite Full Unicode support is optional and not installed by default in most systems (like Android, Debian...)
  70. ^"TiDB Features". docs.pingcap.com.
  71. ^"MySQL - The InnoDB Storage Engine".
  72. ^"InnoDB - Oracle Wiki".
  73. ^"MySQL 5.6 Reference Manual".
  74. ^"Identifier Names". MariaDB KnowledgeBase. Retrieved 26 September 2014.
  75. ^"PostgreSQL Limits". Retrieved 2021-05-13.
  76. ^"Large Objects: Introduction". Retrieved 2021-05-13.
  77. ^"Date/Time Types". Retrieved 2021-05-13.
  78. ^"SAP Help Portal". help.sap.com.
  79. ^Technical Specifications, Guide, Firebird SQL, archived from the original on 2010-06-15, retrieved 2008-03-30
  80. ^Library, MSDN, Microsoft, 21 May 2024
  81. ^ ab"Column count limit", Reference Manual, MySQL 5.1 Documentation, Oracle
  82. ^"Row-Overflow Considerations", TechNet Library, SQL Server Documentation, Microsoft, 2012
  83. ^"Date functions", Language, SQLite
  84. ^Online books, Sybase, archived from the original on 2005-10-23
  85. ^Informix Performance Guide, Info Centre, IBM
  86. ^Dynamic Materialized Views in MySQL, Pure, Red Noize, 2005, archived from the original on 2006-04-23
  87. ^"Derby", Full Text Indexing, Search, Issues, Apache
  88. ^ abc"CUBRID 9.0 release". Archived from the original on 2013-02-14. Retrieved 2013-02-05.
  89. ^Full-text search with Db2 Text Search, Developer Works, IBM
  90. ^Does Firebird support full-text search?, Firebird FAQ
  91. ^Fulltext Search, Tutorial, H2 Database
  92. ^Create Spatial Index, Grammar, H2 Database
  93. ^Informix 15.0.0 online documentation, IBM, 19 November 2024
  94. ^Full Text Search Functions(PDF), Documentation, RU: Linter, archived from the original(PDF) on 2011-08-20, retrieved 2010-06-06
  95. ^ abSPATIAL INDEX, MariaDB, mariadb.com, retrieved 24 September 2017
  96. ^"Storage Engine Index Types". mariadb.com. Retrieved 25 April 2016.
  97. ^Virtual Columns - MariaDB Knowledge Base
  98. ^"Fulltext Index Overview". mariadb.com. Retrieved 25 April 2016.
  99. ^Does Microsoft Access have Full Text Search?, Questions, Stack Overflow
  100. ^"Microsoft SQL Server Full-Text Search", Library, MSDN, Microsoft
  101. ^"Spatial Indexing Overview", Library, Tech Net, Microsoft, 4 October 2012
  102. ^"Microsoft SQL Server Compact Full-text search is not available", Forums, MSDN, Microsoft
  103. ^Index Types Per Storage Engine, MySQL, Oracle, retrieved 24 September 2017
  104. ^"Feature request #4990: Functional Indexes", Bugs, MySQL, Oracle
  105. ^"Feature request #13979: InnoDB engine doesn't support FULLTEXT", Bugs, MySQL, Oracle
  106. ^"MySQL v5.6.4 Release Notes", Release Notes, MySQL, Oracle
  107. ^Creating Spatial Indexes, MySQL, Oracle
  108. ^Changes in MySQL 5.7.5, Oracle
  109. ^Does Oracle support full text search?, Questions, Stack Overflow
  110. ^"Location Features for Database 11g", Spatial & Locator, Tech Network, Oracle
  111. ^"Oracle / PLSQL: ORA-01408 Error Message". www.techonthenet.com.
  112. ^Index Types, Documentation, PostgreSQL community, 11 November 2021
  113. ^Full Text Search, Documentation, PostgreSQL community, 11 November 2021
  114. ^Building Spatial Indexes, PostGIS Manual, The PostGIS Development Group, archived from the original on 2021-05-03, retrieved 2021-05-13
  115. ^"The SQLite R*Tree Module". www.sqlite.org.
  116. ^"Indexes On Expressions". sqlite.org.
  117. ^"SQLite FTS5 Extension". www.sqlite.org.
  118. ^SpatiaLite, IT: Gaia GIS 2.3.1, archived from the original on 2011-07-22, retrieved 2010-12-06
  119. ^Full-Text Search, Online Publications, Teradata
  120. ^geospatial
  121. ^UDF, Ad Hoc Data, archived from the original on 2019-09-14, retrieved 2007-01-11
  122. ^"Create DB", Library, MSDN, Microsoft
  123. ^"SQL", Library, MSDN, Microsoft
  124. ^Petkovic, Dusan (2005). Microsoft SQL Server 2005: A Beginner's Guide. McGraw-Hill Professional. p. 300. ISBN 978-0-07-226093-9.
  125. ^"InnoDB adaptive Hash", Reference manual 5.0, Development documentation, Oracle
  126. ^= "Forest of Trees", Informix 15.0 online documentation, Development documentation, IBM{{citation}}: Check |chapter-url= value (help)
  127. ^"Article", Library, Developer Works, IBM
  128. ^ abcdef"What's new in MariaDB 10.3".
  129. ^ ab"HyperSQL 2.5 New Features". hsqldb.org.
  130. ^"Advanced". h2database.com.
  131. ^"Functions". www.h2database.com.
  132. ^Clay, David (January 1, 1993). "Informix parallel data query (PDQ)". IEEE Computer Society Press. pp. 71–73 – via ACM Digital Library.
  133. ^"Ingres".
  134. ^"Ingres".
  135. ^"Ingres".
  136. ^"INTERSECT". mariadb.com.
  137. ^"EXCEPT". mariadb.com.
  138. ^"CTE implemented in 10.2.2". mariadb.org. Retrieved 26 July 2017.
  139. ^"Window Functions Overview". mariadb.com. Retrieved 25 April 2016.
  140. ^ ab"Feature request #1542: Parallel query", Bugs, MySQL, Oracle
  141. ^Only very limited functions available before SQL Server 2012, Microsoft
  142. ^"SQL Server Parallel Query Processing", Library, MSDN, Microsoft, 4 October 2012
  143. ^"INTERSECT". mysql.com.
  144. ^"EXCEPT". mysql.com.
  145. ^"Feature request #16244: SQL-99 Derived table WITH clause (CTE)", Bugs, MySQL, Oracle
  146. ^Window Functions, mysql.com, retrieved 20 July 2021
  147. ^Parallel Query, Wiki, Ora FAQ
  148. ^"New Features Oracle 12.1.0.1". Archived from the original on 2020-10-25.
  149. ^Parallel Query, PostgreSQL, 11 August 2022
  150. ^"SQLite Release 3.43.0 On 2023-08-24". sqlite.org.
  151. ^"The WITH Clause". sqlite.org.
  152. ^"Window Functions". sqlite.org.
  153. ^"Data Types", General Reference, HDB, Altibase
  154. ^ ab"10. Data Types", Reference manual, MySQL 5.0, Oracle
  155. ^"Data Types", CUBRID SQL Guide, Reference Manual, CUBRID[permanent dead link]
  156. ^"FileMaker 14 Tech Specs". FileMaker=May 12, 2015.
  157. ^"Migration from MS-SQL to Firebird". Firebird Project. Retrieved April 12, 2015.
  158. ^"General: HSQLDB data types", Guide, 2.0 Documents, HSQLDB
  159. ^"IBM Informix Guide to SQL: Reference, v11.50 (SC23-7750-04)". Publications. IBM. 20 August 2001. Retrieved August 7, 2013.
  160. ^"3: Understanding SQL Data Types", SQL 9.3 Reference Guide, Documents, Ingres, archived from the original on 2011-07-13, retrieved 2009-11-16
  161. ^"Data Types". mariadb.com. Retrieved 25 April 2016.
  162. ^"SQL Server Data Types", Library, MSDN, Microsoft, 21 May 2024
  163. ^"SQL Server Compact Data Types", Library, MSDN, Microsoft, 24 March 2011
  164. ^"Datatypes", SQL Reference, OpenLink Software
  165. ^"Data Types", SQL 11.2 Reference, Server documents, Oracle, archived from the original on 2010-03-14, retrieved 2009-09-21
  166. ^"Data Types", Pervasive PSQL Supported Data Types, Product documentation, Pervasive
  167. ^Polyhedra SQL Reference Manual, Product documentation, Enea AB, archived from the original on 2013-10-04, retrieved 2013-04-23
  168. ^"Data Types", Manual, PostgreSQL 10 Documentation, PostgreSQL community, 11 August 2022
  169. ^Datatypes, SQLite 3
  170. ^SQream SQL Reference Guide, SQream Technologies
  171. ^"Constraint". mariadb.com.
  172. ^Support, Downloads, Sybase, retrieved 2008-09-07[dead link]
  173. ^"Release", Engine, Development, Firebird SQL 2.0
  174. ^Files, Firebird SQL
  175. ^"Trace and Audit Services". Firebird Project. Retrieved April 12, 2015.
  176. ^"cracklib_password_check". mariadb.com. Retrieved 9 December 2014.
  177. ^"simple_password_check". mariadb.com. Retrieved 9 December 2014.
  178. ^"Security Vulnerabilities Fixed in MariaDB". mariadb.com. Retrieved 25 April 2016.
  179. ^"Downloads", Development, MySQL, Oracle
  180. ^Security, Support, PostgreSQL community, archived from the original on 2011-11-01, retrieved 2018-03-05
  181. ^Open Source PostgreSQL Audit Logging, September 2022
  182. ^Download, SQLite
  183. ^DB, Products, Common Criteria Portal, retrieved 2021-05-13
  184. ^Backup MySQL, How to, Gentoo wiki, archived from the original on 2008-09-02, retrieved 2008-09-07
  185. ^Authentication methods, 8.1 Documents, PostgreSQL community, 24 July 2014
  186. ^Common Criteria (CC, ISO15408), Microsoft, archived from the original on 2014-02-13
  187. ^Adding audit trails to a Polyhedra IMDB database, White paper, Enea AB
  188. ^"PostgreSQL: Documentation: IMPORT FOREIGN SCHEMA". www.postgresql.org. Retrieved 2016-06-11.
[edit]
close