-GENERAL
-
-* port Oracle backend to UFFI.
-
TESTS TO ADD
* CACHE-TABLE-QUERIES
-* :VOID-VALUE
-
-COMMONSQL SPEC
-
-* Missing:
-
- UPDATE-OBJECT-JOINS
-
-* Incompatible
-
- >> The functional sql interface
-
- SELECT
- o keyword arg :refresh should function as advertised
- o should return (values result-list field-names)
- o should coerce values returned as strings to appropriate lisp type
-
- QUERY
- o should coerce values returned as strings to appropriate lisp type
- for SQLite backend
-
- >> The object-oriented sql interface
-
- DEF-VIEW-CLASS
- o get :target-slot working
- o implement :retrieval :immediate
-
- DO-QUERY,MAP-QUERY,LOOP
- o should work with object queries as well as functional ones
-
-
- >> Symbolic SQL syntax
-
- o Complete sql expressions (see operations.lisp)
-
- substr
- some
- order-by
- times
- nvl
- null
- distinct
- except
- intersect
- between
- userenv
-
- o variables (e.g., table identifiers) should be instantiated at runtime
-
+* Test that ":db-kind :key" adds an index for that key. This is complicated by different
+ backends showing autogenerated primary key in different ways.
+* :db-constraint tests
+* test *db-auto-sync*
+* for-each-row macro
+* owner phrases for postgresql and oracle backends
+* Number and Char field types
+* Add test case for return type of (setf slot-value-using-class)
+* symbol slot
+* generalized-boolean slot
+VARIANCES FROM COMMONSQL
-NOTES ABOUT THE BACKENDS
+CLSQL starts with in transaction AUTOCOMMIT mode. To begin a transaction,
+START-TRANSACTION has to be called.
-MYSQL
+OPTIMIZATIONS
+
+* Revisit result-type list creation, perhaps caching
-drop-index: requires a table to be specified with the :from keyword parameter
-views: mysql does not support views
-queries: nested subqueries are not supported
+POSSIBLE EXTENSIONS
-SQLITE
+* extend large object support to databases beyond postgresql, improve large object api
+* add support for prepared statements
+* port Oracle backend to UFFI
-create-view: column-list parameter not supported