2002-08-14 04:08:12 +04:00
|
|
|
#
|
|
|
|
# Run this script to generated a omitted.html output file
|
|
|
|
#
|
2005-11-03 03:41:17 +03:00
|
|
|
set rcsid {$Id: omitted.tcl,v 1.10 2005/11/03 00:41:18 drh Exp $}
|
2004-05-31 19:06:28 +04:00
|
|
|
source common.tcl
|
|
|
|
header {SQL Features That SQLite Does Not Implement}
|
2002-08-14 04:08:12 +04:00
|
|
|
puts {
|
2004-05-31 19:06:28 +04:00
|
|
|
<h2>SQL Features That SQLite Does Not Implement</h2>
|
|
|
|
|
2002-08-14 04:08:12 +04:00
|
|
|
<p>
|
|
|
|
Rather than try to list all the features of SQL92 that SQLite does
|
|
|
|
support, it is much easier to list those that it does not.
|
2002-08-15 17:45:17 +04:00
|
|
|
Unsupported features of SQL92 are shown below.</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
The order of this list gives some hint as to when a feature might
|
|
|
|
be added to SQLite. Those features near the top of the list are
|
|
|
|
likely to be added in the near future. There are no immediate
|
|
|
|
plans to add features near the bottom of the list.
|
2002-08-14 04:08:12 +04:00
|
|
|
</p>
|
|
|
|
|
|
|
|
<table cellpadding="10">
|
|
|
|
}
|
|
|
|
|
|
|
|
proc feature {name desc} {
|
|
|
|
puts "<tr><td valign=\"top\"><b><nobr>$name</nobr></b></td>"
|
2002-08-15 17:45:17 +04:00
|
|
|
puts "<td width=\"10\"> </th>"
|
2002-08-14 04:08:12 +04:00
|
|
|
puts "<td valign=\"top\">$desc</td></tr>"
|
|
|
|
}
|
|
|
|
|
2002-08-15 17:45:17 +04:00
|
|
|
feature {FOREIGN KEY constraints} {
|
|
|
|
FOREIGN KEY constraints are parsed but are not enforced.
|
2002-08-14 04:08:12 +04:00
|
|
|
}
|
|
|
|
|
2002-08-24 22:24:51 +04:00
|
|
|
feature {Complete trigger support} {
|
|
|
|
There is some support for triggers but it is not complete. Missing
|
|
|
|
subfeatures include FOR EACH STATEMENT triggers (currently all triggers
|
|
|
|
must be FOR EACH ROW), INSTEAD OF triggers on tables (currently
|
|
|
|
INSTEAD OF triggers are only allowed on views), and recursive
|
|
|
|
triggers - triggers that trigger themselves.
|
|
|
|
}
|
|
|
|
|
2005-03-19 04:41:21 +03:00
|
|
|
feature {Complete ALTER TABLE support} {
|
|
|
|
Only the RENAME TABLE and ADD COLUMN variants of the
|
|
|
|
ALTER TABLE command are supported. Other kinds of ALTER TABLE operations
|
|
|
|
such as
|
|
|
|
DROP COLUMN, ALTER COLUMN, ADD CONSTRAINT, and so forth are omitted.
|
2002-08-14 04:08:12 +04:00
|
|
|
}
|
|
|
|
|
2002-08-24 22:24:51 +04:00
|
|
|
feature {Nested transactions} {
|
|
|
|
The current implementation only allows a single active transaction.
|
|
|
|
}
|
|
|
|
|
2002-08-15 17:45:17 +04:00
|
|
|
feature {RIGHT and FULL OUTER JOIN} {
|
|
|
|
LEFT OUTER JOIN is implemented, but not RIGHT OUTER JOIN or
|
|
|
|
FULL OUTER JOIN.
|
|
|
|
}
|
|
|
|
|
|
|
|
feature {Writing to VIEWs} {
|
|
|
|
VIEWs in SQLite are read-only. You may not execute a DELETE, INSERT, or
|
|
|
|
UPDATE statement on a view. But you can create a trigger
|
|
|
|
that fires on an attempt to DELETE, INSERT, or UPDATE a view and do
|
|
|
|
what you need in the body of the trigger.
|
|
|
|
}
|
|
|
|
|
|
|
|
feature {GRANT and REVOKE} {
|
|
|
|
Since SQLite reads and writes an ordinary disk file, the
|
|
|
|
only access permissions that can be applied are the normal
|
|
|
|
file access permissions of the underlying operating system.
|
|
|
|
The GRANT and REVOKE commands commonly found on client/server
|
|
|
|
RDBMSes are not implemented because they would be meaningless
|
|
|
|
for an embedded database engine.
|
2002-08-14 04:08:12 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
puts {
|
|
|
|
</table>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
If you find other SQL92 features that SQLite does not support, please
|
2003-06-30 14:36:23 +04:00
|
|
|
add them to the Wiki page at
|
2003-08-22 06:34:30 +04:00
|
|
|
<a href="http://www.sqlite.org/cvstrac/wiki?p=UnsupportedSql">
|
|
|
|
http://www.sqlite.org/cvstrac/wiki?p=Unsupported</a>
|
2002-08-14 04:08:12 +04:00
|
|
|
</p>
|
2004-05-31 19:06:28 +04:00
|
|
|
}
|
|
|
|
footer $rcsid
|