Rework do-query to use database for special case
authorKevin Rosenberg <kevin@rosenberg.net>
Fri, 4 Sep 2009 17:46:09 +0000 (11:46 -0600)
committerKevin Rosenberg <kevin@rosenberg.net>
Fri, 4 Sep 2009 17:46:09 +0000 (11:46 -0600)
        * sql/fdml.lisp: Rework do-query to use supplied database
        parameter when passed a sql-object-query
        (thanks to JTK <jetmonk@gmail.com>)

ChangeLog
sql/fdml.lisp

index 1e9678c7e1bf4920a7cedcebae16cf17c7f6a0d2..8e85b698e83fcfca1a3379df9548889b77fd9a8d 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+04 Sep 2009  Kevin Rosenberg <kevin@rosenberg.net>
+       * sql/fdml.lisp: Rework do-query to use supplied database
+       parameter when passed a sql-object-query 
+       (thanks to JTK <jetmonk@gmail.com>)
+
 31 Aug 2009  Kevin Rosenberg <kevin@rosenberg.net>
        * sql/db-interface.lisp: Fix spelling error (thanks to 
        David Thompson)
index dc725f41e03623a0999363b758f7d5ca30fa1f98..fcd6a3dd637e3ada63170a81486825820f794f23 100644 (file)
@@ -1,8 +1,6 @@
 ;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*-
 ;;;; *************************************************************************
 ;;;;
-;;;; $Id$
-;;;;
 ;;;; The CLSQL Functional Data Manipulation Language (FDML).
 ;;;;
 ;;;; This file is part of CLSQL.
@@ -212,28 +210,28 @@ types are automatically computed for each field."
         (columns (gensym "COLUMNS-"))
         (row (gensym "ROW-"))
         (db (gensym "DB-")))
-    `(let ((,qe ,query-expression))
+    `(let ((,qe ,query-expression)
+           (,db ,database))
       (typecase ,qe
         (sql-object-query
-         (dolist (,row (query ,qe))
+         (dolist (,row (query ,qe :database ,db))
            (destructuring-bind ,args
                ,row
              ,@body)))
         (t
          ;; Functional query
-         (let ((,db ,database))
-           (multiple-value-bind (,result-set ,columns)
-               (database-query-result-set ,qe ,db
-                                          :full-set nil
+         (multiple-value-bind (,result-set ,columns)
+             (database-query-result-set ,qe ,db
+                                        :full-set nil
                                           :result-types ,result-types)
-             (when ,result-set
-               (unwind-protect
-                    (do ((,row (make-list ,columns)))
-                        ((not (database-store-next-row ,result-set ,db ,row))
-                         nil)
-                      (destructuring-bind ,args ,row
-                        ,@body))
-                 (database-dump-result-set ,result-set ,db))))))))))
+           (when ,result-set
+             (unwind-protect
+                  (do ((,row (make-list ,columns)))
+                      ((not (database-store-next-row ,result-set ,db ,row))
+                       nil)
+                    (destructuring-bind ,args ,row
+                      ,@body))
+               (database-dump-result-set ,result-set ,db)))))))))
 
 (defun map-query (output-type-spec function query-expression
                   &key (database *default-database*)