Как исправить ER_PARSE_ERROR в node.js с помощью экспресс - PullRequest
0 голосов
/ 06 ноября 2019

Я устанавливаю crud в node.js с помощью Express, и я завершил создание и обновление, но я все еще застрял в функции удаления

Я пытался проанализировать код с руля и маршрут /удалите, но все еще не можете понять, почему user_id не может быть прочитан

user_list_view.hbs:

<form id="add-row-form" action="/delete" method="post">
<div class="modal fade" id="DeleteModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <h5 class="modal-title" id="myModalLabel">Delete Product</h5>
                <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
            </div>
            <div class="modal-body">
                <strong>Do you want to delete this data ?</strong>
            </div>
            <div class="modal-footer">
                <input type="hidden" name="user_id" class="form-control user_id" required>
                <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
                <button type="submit" class="btn btn-success">Delete</button>
            </div>
        </div>
    </div>
</div>

jquery в user_list_view.js:

<script>
$(document).ready(function () {
    $('#mytable').on('click','.delete',function(){
        var user_id = $(this).data('user_id');
        $('#DeleteModal').modal('show');
        $('.user_id').val(user_id);
    });
})

process.js:

router.post('/delete', (req,res) => {
let sql = "DELETE FROM users WHERE user_id="+req.body.user_id
let query = db.query(sql, (err, results) => {
    if (err) throw err
    res.redirect('/user_list')
 })
})


module.exports = router

Я ожидал, что результат удалит выбранного пользователя на основе user_id, но я получил сообщение об ошибке:

code: 'ER_PARSE_ERROR',
errno: 1064,
sqlMessage: "You have an error in your SQL syntax; check the manual that 
corresponds to your MariaDB server version for the right syntax to use 
near ''at line 1",
sqlState: '42000',
index: 0,
sql: 'DELETE FROM users WHERE user_id='
}
npm ERR! code ELIFECYCLE
npm ERR! errno 1
npm ERR! latihan3@0.0.0 start: `node ./bin/www`
npm ERR! Exit status 1

1 Ответ

0 голосов
/ 09 ноября 2019

В синтаксисе .query для mysql требуется 2 параметра, но первый - ваш запрос, второй - params, а не обратный вызов. Если только вы не завернули его для такой работы.

https://mariadb.com/kb/en/library/connector-nodejs-promise-api/

// DON'T HAVE TO DO THIS "DELETE FROM users WHERE user_id="+req.body.user_id

let query = db.query('DELETE FROM users WHERE user_id=,[req.body.user_id]).then(results => { if (err) throw err res.redirect('/user_list') })

...