有时,我需要从我的角度前端应用程序向我的后端(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;
答案 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
};