dpq2 0.1.4

Medium-level binding to the PostgreSQL database


To use this package, run the following command in your project's root directory:

Manual usage
Put the following dependency into your project's dependences section:

dpq2

Build Status

This is yet another attempt to create a good interface to PostgreSQL from the D programming language.

It adds only tiny overhead to the original low level library libpq but make convenient use PostgreSQL from D.

Features

  • Arguments list support
  • Async queries support
  • Reading of the text query results to native D text types
  • Representation of the binary query results to native D types
  • Text types
  • Integer and decimal types (except "numeric")
  • Timestamp type (with and without timezone)
  • Access to PostgreSQL's multidimensional arrays
  • LISTEN/NOTIFY support

Building

Bindings for libpq can be static or dynamic.

The static bindings are generated by default. Add --config=dynamic to the dub parameters to generate dynamic bindings.

Example

####Source

#!/usr/bin/env rdmd

import dpq2.all;
import std.stdio: writeln;

void main()
{
    Connection conn = new Connection;
    conn.connString = "dbname=postgres";
    conn.connect();

    // Only text query result can be obtained by this call:
    auto s = conn.exec(
        "SELECT now() as current_time, 'abc'::text as field_name, "
        "123 as field_3, 456.78 as field_4"
        );
    
    writeln( "Text query result: ", s[0][3].as!PGtext );
    
    // Separated arguments query with binary result:
    queryParams p;
    p.sqlCommand = "SELECT "
        "$1::double precision, "
        "$2::timestamp with time zone, "
        "$3::text, "
        "$4::text, "
        "$5::integer[]";
    
    p.args.length = 5;
    
    p.args[0].value = "-1234.56789012345";
    p.args[1].value = "2012-10-04 11:00:21.227803+08";
    p.args[2].value = "first line\nsecond line";
    p.args[3].value = null;
    p.args[4].value = "{1, 2, NULL}";
    
    auto r = conn.exec(p);
    
    writeln( "0: ", r[0][0].as!PGdouble_precision );
    writeln( "1: ", r[0][1].as!PGtime_stamp.toSimpleString );
    writeln( "2: ", r[0][2].as!PGtext );
    writeln( "3 isNULL: ", r[0].isNULL(3) );
    writeln( "4.1: ", r[0][4].asArray.getValue(1).as!PGinteger );
    writeln( "4.2: ", r[0][4].asArray.isNULL(0) );
    writeln( "4.3: ", r[0][4].asArray.isNULL(2) );
}

####Compile and run:

$ cd example
$ dub build --build=release
$ sudo -u postgres ./dpq2-example
Text query result: 456.78
0: -1234.57
1: 0013-Oct-05 03:00:21.227803Z
2: first line
second line
3 isNULL: true
4.1: 2
4.2: false
4.3: true

TODO

  • PostGIS binary data support
  • Checking types by Oid
  • Row by row result reading
  • Binary arguments types
Authors:
  • Denis Feklushkin
  • Anton Gushcha
Dependencies:
derelict-pq
Versions:
1.2.0-rc.1 2024-Jul-24
1.1.7 2024-Apr-02
1.1.7-rc.1 2023-Nov-15
1.1.6 2018-Mar-10
1.1.6-rc.1 2023-Mar-29
Show all 180 versions
Download Stats:
  • 4 downloads today

  • 45 downloads this week

  • 345 downloads this month

  • 82078 downloads total

Score:
4.5
Short URL:
dpq2.dub.pm