Class: DBI::DBD::Pg::Tuples

Inherits:
Object
  • Object
show all
Defined in:
lib/dbd/pg/tuples.rb

Overview

Tuples is a class to represent result sets.

Many of these methods are extremely similar to the methods that deal with result sets in DBI::BaseStatement and are wrapped by the StatementHandle. Unless you plan on working on this driver, these methods should never be called directly.

Instance Method Summary collapse

Constructor Details

#initialize(db, pg_result) ⇒ Tuples

Returns a new instance of Tuples.



11
12
13
14
15
16
# File 'lib/dbd/pg/tuples.rb', line 11

def initialize(db, pg_result)
    @db = db
    @pg_result = pg_result
    @index = -1
    @row = []
end

Instance Method Details

#column_infoObject

See DBI::BaseStatement#column_info. Additional attributes:

  • array_of_type: True if this is actually an array of this type. In this case, dbi_type will be the type authority for conversion.



23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'lib/dbd/pg/tuples.rb', line 23

def column_info
    a = []
    0.upto(@pg_result.num_fields-1) do |i|
        str = @pg_result.fname(i)

        typeinfo = nil

        begin
            typmod = @pg_result.fmod(i)
        rescue
        end

        if typmod and typ = @pg_result.ftype(i)
            res = @db._exec("select format_type(#{typ}, #{typmod})")
            typeinfo = DBI::DBD::Pg.parse_type(res[0].values[0])
        end

        map = @db.type_map[@pg_result.ftype(i)] || { }
        h = { "name" => str }.merge(map)

        if typeinfo
            h["precision"]     = typeinfo[:size]
            h["scale"]         = typeinfo[:decimal]
            h["type"]          = typeinfo[:type]
            h["array_of_type"] = typeinfo[:array]

            if typeinfo[:array]
                h['dbi_type'] = 
                    DBI::DBD::Pg::Type::Array.new(
                        DBI::TypeUtil.type_name_to_module(typeinfo[:type])
                )
            end
        end

        a.push h
    end

    return a
end

#fetch_scroll(direction, offset) ⇒ Object

Just don’t use this method. It’ll be fixed soon.



79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# File 'lib/dbd/pg/tuples.rb', line 79

def fetch_scroll(direction, offset)
    # Exact semantics aren't too closely defined.  I attempted to follow the DBI:Mysql example.
    case direction
    when SQL_FETCH_NEXT
        # Nothing special to do, besides the fetchrow
    when SQL_FETCH_PRIOR
        @index -= 2
    when SQL_FETCH_FIRST
        @index = -1
    when SQL_FETCH_LAST
        @index = @pg_result.num_tuples - 2
    when SQL_FETCH_ABSOLUTE
        # Note: if you go "out of range", all fetches will give nil until you get back
        # into range, this doesn't raise an error.
        @index = offset-1
    when SQL_FETCH_RELATIVE
        # Note: if you go "out of range", all fetches will give nil until you get back
        # into range, this doesn't raise an error.
        @index += offset - 1
    else
        raise NotSupportedError
    end
    self.fetchrow
end

#fetchrowObject



63
64
65
66
67
68
69
70
71
72
73
74
# File 'lib/dbd/pg/tuples.rb', line 63

def fetchrow
    @index += 1
    if @index < @pg_result.num_tuples && @index >= 0
        @row = Array.new
        0.upto(@pg_result.num_fields-1) do |x|
            @row.push(@pg_result.getvalue(@index, x))
        end
        @row
    else
        nil
    end
end

#finishObject



118
119
120
# File 'lib/dbd/pg/tuples.rb', line 118

def finish
    @pg_result.clear
end

#row_countObject

The number of rows returned.



107
108
109
# File 'lib/dbd/pg/tuples.rb', line 107

def row_count
    @pg_result.num_tuples
end

#rows_affectedObject

The row processed count. This is analogue to DBI::StatementHandle#rows.



114
115
116
# File 'lib/dbd/pg/tuples.rb', line 114

def rows_affected
    @pg_result.cmdtuples
end