uniconnect-client v0.6.2
Uniconnect-node-client
For queries with long process time and heavy output:
var uniconnect = require('uniconnect-client');
var client = new uniconnect.Client({user: 'username'});
client.execute({
query: 'select * from mysql1.retail_db.orders limit 4',
success : function(error, stats){
console.log({State: stats});
},
error: function(error){
console.log({Error: error});
},
data: function(error, data, columns, stats){
console.log(data);
},
state: function(error, query_id, stats){
console.log({message:"status changed", id:query_id, stats:stats});
},
columns: function(error, data){
console.log({resultColumns: data});
}
});
Installation
npm install -g uniconnect-client
Or add uniconnect-client
to your own packagen.json
, and do npm install
.
API
new Client(opts)
Instanciate client object and set default configurations.
- opts object
- host string
- UniConnect coordinator hostname or address (default: localhost)
- ssl object
- Setting a Hash object enables SSL and verify server certificate with options (default:
null
):ca
: An authority certificate or array of authority certificates to check the remote host againstcert
: Public x509 certificate to use (default :null
)ciphers
: Default cipher suite to use. (default: https://nodejs.org/api/tls.html#tls_modifying_the_default_tls_cipher_suite)key
: Private key to use for SSL (default:null
)passphrase
: A string of passphrase for the private key or pfx (default:null
)pfx
: Certificate, Private key and CA certificates to use for SSL. (default:null
).rejectUnauthorized
: If notfalse
the server will reject any connection which is not authorized with the list of supplied CAs. This option only has an effect if requestCert istrue
(default:true
)secureProtocol
: Optional SSL method to use. The possible values are listed as SSL_METHODS, use the function names as strings. For example, "SSLv3_method" to force SSL version 3 (default:SSLv23_method
)servername
: Server name for the SNI (Server Name Indication) TLS extension
- Setting a Hash object enables SSL and verify server certificate with options (default:
- port integer
- UniConnect coordinator port (default: 8080)
- user string
- Username of query (default: process user name)
- basic_auth object
- Pass in a user and password to enable Authorization Basic headers on all requests.
- basic_auth: {user: "user", password: "password"} (default:null)
- catalog string
- Default catalog name
- schema string
- Default schema name
- checkInterval integer
- Interval milliseconds of each RPC to check query status (default: 800ms)
- enableVerboseStateCallback boolean
- Enable more verbose callback for UniConnect query states (default: false)
- When set to
true
, this flag modifies the condition of the state change callback to return data everycheckInterval
(default: 800ms). ModifycheckInterval
if you wish to change the frequency. - Otherwise (
false
), the state change callback will only be called upon a change in state. - The purpose of this variable is to enable verbose update capability in state callbacks. This is such that "percentage complete" and "processed rows" may be extracted despite the state still remaining in a particular state eg. "RUNNING".
- jsonParser object
- Custom json parser if required (default:
JSON
)
- Custom json parser if required (default:
- host string
return value: client instance object
execute(arg, callback)
Execute query on UniConnect cluster, and fetch results.
- arg Object or string
- arg String: query string executed
catalog
andschema
must be specified innew Client()
for this argument type
- arg Object
- query string
- catalog string
- catalog string (default: instance default catalog)
- schema string
- schema string (default: intance default schema)
- session string
- set session variables via the X-Presto-Session header - string should have form
key1=val1,key2=val2
- set session variables via the X-Presto-Session header - string should have form
- timezone string :optional
- set time zone via X-Presto-Time-Zone header
- callback function(error, data, columns)
- called once when query finished
- data
- array of arrays of each field values
[ [ 'field1Value', 'field2Value', 3 ], [ 'field1Value', 'field2Value', 6 ], ... ]
- columns
- array of field names and types
[ { name: 'timestamp', type: 'varchar' }, { name: 'username', type: 'varchar' }, { name: 'cnt', type: 'bigint' } ]
execute(opts)
This is an API to execute queries that really read large amount of data.
Execute query on UniConnect cluster, and fetch results.
Attributes of opts object are:
- query string
- catalog string
- schema string
- timezone string :optional
- info boolean :optional
- fetch query info (execution statistics) for success callback, or not (default false)
- cancel function() :optional
- client stops fetch of query results if this callback returns
true
- client stops fetch of query results if this callback returns
- state function(error, query_id, stats) :optional
- called when query stats changed
stats.state
: QUEUED, PLANNING, STARTING, RUNNING, FINISHED, or CANCELED, FAILED
- query_id
- id string like
20140214_083451_00012_9w6p5
- id string like
- stats
- object which contains running query status
- called when query stats changed
- columns function(error, data) :optional
- called once when columns and its types are found in results
- data
- array of field info
[ { name: "username", type: "varchar" }, { name: "cnt", type: "bigint" } ]
- data function(error, data, columns, stats) :optional
- called per fetch of query results (may be called 2 or more)
- data
- array of array of each column
[ [ "tagomoris", 1013 ], [ "dain", 2056 ], ... ]
- columns (optional)
- same as data of
columns
callback
- same as data of
- stats (optional)
- runtime statistics object of query
- success function(error, stats, info) :optional
- called once when all results are fetched (default: value of
callback
)
- called once when all results are fetched (default: value of
- error function(error) :optional
- callback for errors of query execution (default: value of
callback
)
- callback for errors of query execution (default: value of
- callback function(error, stats) :optional
- callback for query completion (both of success and fail)
- one of
callback
orsuccess
must be specified
Callbacks order (success query) is: columns -> data (-> data xN) -> success (or callback)
query(query_id, callback)
Get query current status. (Same with 'Raw' of UniConnect Web in browser.)
- query_id string
- callback function(error, data)
kill(query_id, callback)
Stop query immediately.
- query_id string
- callback function(error) :optional
nodes(opts, callback)
Get node list of UniConnect cluster and return it.
- opts object :optional
- specify null, undefined or
{}
(currently)
- specify null, undefined or
- callback function(error,data)
- error
- data
- array of node objects
BIGINT value handling
Javascript standard JSON
module cannot handle BIGINT values correctly by precision problems.
JSON.parse('{"bigint":1139779449103133602}').bigint //=> 1139779449103133600
If your query puts numeric values in its results and precision is important for that query, you can swap JSON parser with any modules which has parse
method.
var JSONbig = require('json-bigint');
JSONbig.parse('{"bigint":1139779449103133602}').bigint.toString() //=> "1139779449103133602"
// set client option
var client = new uniconnect.Client({
// ...
jsonParser: JSONbig,
// ...
});