2011-06-27 Nathan Bird <nathan@acceleration.net>
* db-odbc/: memory management improvements: leak slower
+ * MSSQL: TOP + DISTINCT work together
2011-06-20 Nathan Bird <nathan@acceleration.net>
(defmethod output-sql ((expr sql-query-modifier-exp) database)
(with-slots (modifier components)
expr
- (output-sql modifier database)
+ (%write-operator modifier database)
(write-string " " *sql-stream*)
(output-sql (car components) database)
(when components
(when *in-subselect*
(write-string "(" *sql-stream*))
(write-string "SELECT " *sql-stream*)
- (when (and limit (eql :mssql (database-underlying-type database)))
- (write-string " TOP " *sql-stream*)
- (output-sql limit database)
- (write-string " " *sql-stream*))
(when all
(write-string " ALL " *sql-stream*))
(when (and distinct (not all))
(write-string " ON " *sql-stream*)
(output-sql distinct database)
(write-char #\Space *sql-stream*)))
+ (when (and limit (eql :mssql (database-underlying-type database)))
+ (write-string " TOP " *sql-stream*)
+ (output-sql limit database)
+ (write-string " " *sql-stream*))
(let ((*in-subselect* t))
(output-sql (apply #'vector selections) database))
(when from