i using knex 0.13.0
, trying insert mysql database following function:
async function create(title, description) { //trim spaces console.log("title: " + title) console.log("description: " + description) title = title.trim() description = description.trim() createdat = _.now() deleted = false console.log("create post: " + title + " " + description + " " + createdat + " " + deleted) if (title.length < 1 || title.length > 255) throw new error('title not valid.') if (description.length < 1) throw new error('description not valid.') try { await knex('posts').insert({ title, description, createdat, deleted }) console.log("added db") return true; } catch (e) { return "an error occured: " + e; } }
the last console output create post: title description 1505062847788 false
is shown right, nothing happening, after waiting
- i guess asynch part of function, else in meanwhile?
- is there standard way create entry when using knex?
appreciate reply!
i'm using node 6, can't test 'await' @ moment (came in node 7) this post looks should assign await response variable. like:
... var awresponse; // new variable try { awresponse = await knex('posts').insert({ ...
in detail:
async function create(title, description) { //trim spaces console.log("title: " + title) console.log("description: " + description) title = title.trim() description = description.trim() createdat = _.now() deleted = false console.log("create post: " + title + " " + description + " " + createdat + " " + deleted) if (title.length < 1 || title.length > 255) throw new error('title not valid.') if (description.length < 1) throw new error('description not valid.') var awresponse; // new variable try { awresponse = await knex('posts').insert({ title, description, createdat, deleted }) console.log("added db") return true; } catch (e) { return "an error occured: " + e; } }
what have should work fine, i've been doing (as alternative you) directly using promises, , constructing data access functions follows:
function create(title, description) { return promise.resolve().then(function () { // first section preping record insert. // //trim spaces console.log("title: " + title) console.log("description: " + description) title = title.trim() description = description.trim() // createdat = _.now() // have error "_" not valid createdat = (new date()).toisostring(); deleted = false console.log("create post: " + title + " " + description + " " + createdat + " " + deleted) if (title.length < 1 || title.length > 255) throw new error('title not valid.') if (description.length < 1) throw new error('description not valid.') return { "title": title, "description": description, "createdat": createdat, "deleted": deleted }; }) .then(function (recordtoinsert) { // second section insert. // console.log("part #2"); return knex('posts').insert(recordtoinsert) .on('query-error', function(ex, obj) { // console.log("knex query-error ex:", ex); // console.log("knex query-error obj:", obj); // below logs db errors custom encapsulation of winston logging. // ... , .catch further down still executed. log.logmsg('error', "dba.ins88", "knex create.on.query-error", {"fnc": "create", "obj":obj, "ex":ex} ); }) }) .then(function (insertresult) { // third section post-processing result (if needed). // console.log("part #3 added db :", insertresult); return insertresult; // returns id value insert; }) .catch(function (e) { // omit .catch let caller know , handle exceptions console.log( "an error occured: " + e); }); };
hope helps!
Comments
Post a Comment