2024-08-23 16:43:32 +00:00
|
|
|
const Result = require('./result');
|
2016-09-26 09:28:47 +00:00
|
|
|
|
2015-01-23 13:09:30 +00:00
|
|
|
/**
|
|
|
|
* This class stores the database results.
|
2022-05-24 10:18:44 +00:00
|
|
|
*/
|
2022-05-05 13:56:17 +00:00
|
|
|
module.exports = new Class({
|
2024-08-23 16:43:32 +00:00
|
|
|
results: null,
|
|
|
|
error: null,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initilizes the resultset object.
|
|
|
|
*/
|
|
|
|
initialize(results, error) {
|
|
|
|
this.results = results;
|
|
|
|
this.error = error;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the query error.
|
|
|
|
*
|
|
|
|
* @return {Db.Err} the error or null if no errors hapened
|
|
|
|
*/
|
|
|
|
getError() {
|
|
|
|
return this.error;
|
|
|
|
},
|
|
|
|
|
|
|
|
fetch() {
|
|
|
|
if (this.error) {
|
|
|
|
throw this.error;
|
|
|
|
}
|
|
|
|
console.log('this.results', this.results);
|
|
|
|
if (this.results !== null && this.results.length > 0) {
|
|
|
|
return this.results.shift();
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetchs the next result from the resultset.
|
|
|
|
*
|
|
|
|
* @return {Db.Result} the result or %null if error or there are no more results
|
|
|
|
*/
|
|
|
|
fetchResult() {
|
|
|
|
const result = this.fetch();
|
|
|
|
console.log('test result', result);
|
|
|
|
if (result !== null) {
|
|
|
|
if (result.data instanceof Array) {
|
|
|
|
return new Result(result);
|
|
|
|
} else {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetchs the first row object from the next resultset.
|
|
|
|
*
|
|
|
|
* @return {Array} the row if success, %null otherwise
|
|
|
|
*/
|
|
|
|
fetchObject() {
|
|
|
|
const result = this.fetch();
|
|
|
|
|
|
|
|
if (
|
|
|
|
result !== null &&
|
|
|
|
result.data instanceof Array &&
|
|
|
|
result.data.length > 0
|
|
|
|
) {
|
|
|
|
return result.data[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetchs data from the next resultset.
|
|
|
|
*
|
|
|
|
* @return {Array} the data
|
|
|
|
*/
|
|
|
|
fetchData() {
|
|
|
|
const result = this.fetch();
|
|
|
|
|
|
|
|
if (result !== null && result.data instanceof Array) {
|
|
|
|
return result.data;
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetchs the first row and column value from the next resultset.
|
|
|
|
*
|
|
|
|
* @return {Object} the value if success, %null otherwise
|
|
|
|
*/
|
|
|
|
fetchValue() {
|
|
|
|
const row = this.fetchRow();
|
|
|
|
|
|
|
|
if (row instanceof Array && row.length > 0) {
|
|
|
|
return row[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetchs the first row from the next resultset.
|
|
|
|
*
|
|
|
|
* @return {Array} the row if success, %null otherwise
|
|
|
|
*/
|
|
|
|
fetchRow() {
|
|
|
|
const result = this.fetch();
|
|
|
|
|
|
|
|
if (
|
|
|
|
result !== null &&
|
|
|
|
result.data instanceof Array &&
|
|
|
|
result.data.length > 0
|
|
|
|
) {
|
|
|
|
const object = result.data[0];
|
|
|
|
const row = new Array(result.columns.length);
|
|
|
|
for (let i = 0; i < row.length; i++) {
|
|
|
|
row[i] = object[result.columns[i].name];
|
|
|
|
}
|
|
|
|
return row;
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
2015-01-23 13:09:30 +00:00
|
|
|
});
|