12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- var common = require('../../common');
- var connection = common.createConnection();
- var assert = require('assert');
- common.useTestDb(connection);
- var table = 'nested_test';
- connection.query([
- 'CREATE TEMPORARY TABLE `' + table + '` (',
- '`id` int(11) unsigned NOT NULL AUTO_INCREMENT,',
- '`title` varchar(255),',
- 'PRIMARY KEY (`id`)',
- ') ENGINE=InnoDB DEFAULT CHARSET=utf8'
- ].join('\n'));
- connection.query('INSERT INTO ' + table + ' SET ?', {title: 'test'});
- var options1 = {
- nestTables: true,
- sql: 'SELECT * FROM ' + table
- };
- var options2 = {
- nestTables: '_',
- sql: 'SELECT * FROM ' + table
- };
- var options3 = {
- rowsAsArray: true,
- sql: 'SELECT * FROM ' + table
- };
- var rows1, rows2, rows3, rows1e, rows2e, rows3e;
- connection.query(options1, function(err, _rows) {
- if (err) throw err;
- rows1 = _rows;
- });
- connection.query(options2, function(err, _rows) {
- if (err) throw err;
- rows2 = _rows;
- });
- connection.query(options3, function(err, _rows) {
- if (err) throw err;
- rows3 = _rows;
- });
- connection.execute(options1, function(err, _rows) {
- if (err) throw err;
- rows1e = _rows;
- });
- connection.execute(options2, function(err, _rows) {
- if (err) throw err;
- rows2e = _rows;
- });
- connection.execute(options3, function(err, _rows) {
- if (err) throw err;
- rows3e = _rows;
- connection.end();
- });
- process.on('exit', function() {
- assert.equal(rows1.length, 1);
- assert.equal(rows1[0].nested_test.id, 1);
- assert.equal(rows1[0].nested_test.title, 'test');
- assert.equal(rows2.length, 1);
- assert.equal(rows2[0].nested_test_id, 1);
- assert.equal(rows2[0].nested_test_title, 'test');
- assert.equal(Array.isArray(rows3[0]), true);
- assert.equal(rows3[0][0], 1);
- assert.equal(rows3[0][1], 'test');
- assert.deepEqual(rows1, rows1e);
- assert.deepEqual(rows2, rows2e);
- assert.deepEqual(rows3, rows3e);
- });
|