如何使用mysql

时间:2017-11-25 19:11:56

标签: mysql angularjs node.js

有时,我需要从我的角度前端应用程序向我的后端(node + mysql)传递一个空值。我的列表内容可以为NULL。

我试过使用:NULL,'NULL'或空('')但是在所有情况下我都在服务器端有异常,因为mysql会抛出一个无效的列值。 错误是:

code: 'ER_TRUNCATED_WRONG_VALUE', errno: 1292,
 sqlMessage: 'Incorrect datetime value: \'\' for column \'DATE_CHECK\' at row 1',
 sqlState: '22007',

我怎么能这样做?

//有角度的前端控制器

var saveItem=async function(row){
        var item={}
        try{
          item.ID=row.ID;
          item.DATE_CHECK=row.DATE_CHECK?moment(row.DATE_CHECK).format('YYYY-MM-DD'):'';
          await  $http.post('/agenda_staff/' + item.ID, item)
        } catch(erro){
           console.log(erro)
        }
}

//节点服务器

router.post('/:id',async (req,res,next)=>{  
    var input = JSON.parse(JSON.stringify(req.body));
    var id = req.params.id;
    try {
       const connection = await pool.getConnection();
       try {
            var data = {
              ID: input.ID
            , DATE_CHECK: input.DATE_CHECK
            };

            var query=await connection.query("UPDATE AGENDA_STAFF set ? WHERE id = ? ",[data,id])
            var ret={success:true, message:'Registro foi atualizado'}
            return res.send(ret);
        } finally {
            pool.releaseConnection(connection);
        }
    } catch (err) {
        if (err instanceof Errors.NotFound)
            return res.status(HttpStatus.NOT_FOUND).send({ success:false, message: err.message, results:err.stack }); // 404
        console.log(err);
        return  res.status(HttpStatus.INTERNAL_SERVER_ERROR).send({ success:false,message: err.message, results:err.stack }); // 500
  }
});

// table def

CREATE TABLE AGENDA_STAFF (
    ID BIGINT AUTO_INCREMENT  NOT NULL
    , DATE_CHECK              TIMESTAMP 
    ,CONSTRAINT PK_STAFF
       PRIMARY KEY ( ID )
)ENGINE=INNODB;

1 个答案:

答案 0 :(得分:1)

正如文档所说:undefined / null are converted to NULL,不是字符串'null'或空字符串''。所以更改node server

中的代码
var data = {
    ID: input.ID,
    DATE_CHECK: input.DATE_CHECK === '' ? null : input.DATE_CHECK
};