<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://panoptic.com/mediawiki/aolserver/index.php?action=history&amp;feed=atom&amp;title=Ns_dbquery</id>
	<title>Ns dbquery - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://panoptic.com/mediawiki/aolserver/index.php?action=history&amp;feed=atom&amp;title=Ns_dbquery"/>
	<link rel="alternate" type="text/html" href="https://panoptic.com/mediawiki/aolserver/index.php?title=Ns_dbquery&amp;action=history"/>
	<updated>2026-04-25T21:23:55Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.34.2</generator>
	<entry>
		<id>https://panoptic.com/mediawiki/aolserver/index.php?title=Ns_dbquery&amp;diff=5069&amp;oldid=prev</id>
		<title>Dossy at 14:56, 12 June 2007</title>
		<link rel="alternate" type="text/html" href="https://panoptic.com/mediawiki/aolserver/index.php?title=Ns_dbquery&amp;diff=5069&amp;oldid=prev"/>
		<updated>2007-06-12T14:56:19Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;pre&amp;gt;&lt;br /&gt;
#&lt;br /&gt;
# ns_dbquery --&lt;br /&gt;
#&lt;br /&gt;
#   Execute a SQL query against either a pool or an opened db handle,&lt;br /&gt;
#   and return the resultset as a list of lists.  The first list&lt;br /&gt;
#   contains the column names.&lt;br /&gt;
#&lt;br /&gt;
#   If the statement was a statement which does not return rows, the&lt;br /&gt;
#   result is an empty list.  TODO:  Perhaps return the number of rows&lt;br /&gt;
#   updated?&lt;br /&gt;
#&lt;br /&gt;
&lt;br /&gt;
proc ns_dbquery {args} {&lt;br /&gt;
    if {([llength $args] - 1) % 2 != 0} {&lt;br /&gt;
        error &amp;quot;wrong # args: should be \&amp;quot;ns_dbquery ?-pool name\&lt;br /&gt;
            | -handle dbId? ?-timeout secs? sql\&amp;quot;&amp;quot;&lt;br /&gt;
    }&lt;br /&gt;
    foreach {key value} [lrange $args 0 end-1] {&lt;br /&gt;
        switch -exact -- $key {&lt;br /&gt;
            -pool { set pool $value }&lt;br /&gt;
            -handle { set handle $value }&lt;br /&gt;
            -timeout { set timeout $value }&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    if {![info exists timeout]} {&lt;br /&gt;
        set timeout 0&lt;br /&gt;
    }&lt;br /&gt;
    if {[info exists pool]} {&lt;br /&gt;
        set db [ns_db gethandle -timeout $timeout $pool]&lt;br /&gt;
    } elseif {[info exists handle]} {&lt;br /&gt;
        set db $handle&lt;br /&gt;
    } else {&lt;br /&gt;
        # Use default pool, if configured.&lt;br /&gt;
        set db [ns_db gethandle -timeout $timeout]&lt;br /&gt;
    }&lt;br /&gt;
    if {![string length $db]} {&lt;br /&gt;
        error &amp;quot;couldn't get db handle&amp;quot;&lt;br /&gt;
    }&lt;br /&gt;
    set res [catch {&lt;br /&gt;
        set resultset [list]&lt;br /&gt;
        if {[ns_db exec $db [lindex $args end]] eq &amp;quot;NS_ROWS&amp;quot;} {&lt;br /&gt;
            set row [ns_db bindrow $db]&lt;br /&gt;
            set columns [list]&lt;br /&gt;
            foreach {key value} [ns_set array $row] {&lt;br /&gt;
                lappend columns $key&lt;br /&gt;
            }&lt;br /&gt;
            lappend resultset $columns&lt;br /&gt;
            while {[ns_db getrow $db $row]} {&lt;br /&gt;
                set data [list]&lt;br /&gt;
                foreach {key value} [ns_set array $row] {&lt;br /&gt;
                    lappend data $value&lt;br /&gt;
                }&lt;br /&gt;
                lappend resultset $data&lt;br /&gt;
            }&lt;br /&gt;
            ns_set free $row&lt;br /&gt;
        }&lt;br /&gt;
    } err]&lt;br /&gt;
    if {![info exists handle]} {&lt;br /&gt;
        ns_db releasehandle $db&lt;br /&gt;
    }&lt;br /&gt;
    if {$res} {&lt;br /&gt;
        error $err&lt;br /&gt;
    }&lt;br /&gt;
    return $resultset&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Dossy</name></author>
		
	</entry>
</feed>