JAVA:对于UPDATE和INSERT,我可以使用端点或GET请求来处理servlet中的数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA:对于UPDATE和INSERT,我可以使用端点或GET请求来处理servlet中的数据相关的知识,希望对你有一定的参考价值。

我有一个状态类型为Tinyint的数据库。我想使用链接和端点(例如'notifi?id =&status = 1&userid =')将0更改为1(总是)。似乎没有POST请求它不起作用。

我已经尝试为状态设置一个永久号码,并尝试更新和插入命令,但可以使用。

这是我的代码:

public void markRead(Notify notify)  {

    try {
        Connection con= NotifyDao.getConnection();
        PreparedStatement ps=con.prepareStatement(
                "UPDATE notifications set status=? where userid=?");

        ps.setInt(1,notify.getNotifyid());
        ps.setInt(2,notify.getNotifystatus());

        ps.executeUpdate();

        con.close();
    } catch (SQLException e) {
        e.printStackTrace();
    }


}

我的servlet代码

 protected void doPost(HttpServletRequest request,
                      HttpServletResponse response) throws ServletException, IOException {

Notify notify = new Notify();

    int id = Integer.parseInt(request.getParameter("id"));
    int status = Integer.parseInt(request.getParameter("status"));
    int userid = Integer.parseInt(request.getParameter("userid"));

    if (status==1){

        request.setAttribute("status", status);

        NotifyDao notifyDao = new NotifyDao();

        notifyDao.markRead(notify);

    }else  {

        response.sendRedirect("error.jsp");
    }

任何帮助或方向将不胜感激

答案

在你的servlet中覆盖另一个方法doGet(HttpServletRequest request, HttpServletResponse response)doPost()并从那里调用do post方法,

像这样:

protected void doPost(HttpServletRequest request, HttpServletResponse response)
{
//your existing code
}  

protected void doGet(HttpServletRequest request, HttpServletResponse response)
{
doPost(request,response);
}

另请参阅Oracle Docs

以上是关于JAVA:对于UPDATE和INSERT,我可以使用端点或GET请求来处理servlet中的数据的主要内容,如果未能解决你的问题,请参考以下文章

在多模块 Java 应用程序中的 INSERT/UPDATE 之前禁用 SELECT

Mysql----insert/update/delete

mysql笔记(10)-数据的插入和更新(insert/update/case)

update和insert + delete哪个更快?

Java笔记-JdbcTemplate批量执行insert及update

Java笔记-JdbcTemplate批量执行insert及update