java - 从servlet执行oracle查询结果错误

标签 java sql-server oracle servlets sqlplus

我使用以下代码来执行查询。我想通过使用 lpad 命令和串联将结果显示为“B010025”。(25 和 B01 作为输入值给出)。但它只显示B0125。当我从 SQL*Plus 执行此操作时,它显示了正确的结果。但在 servlet 中则不然。我无法理解这一点。谁能帮助我获得预期的结果。

public class PickOfferNo extends HttpServlet {


protected void processRequest(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    response.setContentType("text/html;charset=UTF-8");
    PrintWriter out = response.getWriter();
    try {
         //TODO output your page here
        out.println("<html>");
        out.println("<head>");
        out.println("<title>Servlet PickOfferNo</title>");  
        out.println("</head>");
        out.println("<body>");
        out.println("<h1>Servlet PickOfferNo at " + request.getContextPath () + "</h1>");
        out.println("</body>");
        out.println("</html>");

    } finally {            
        out.close();
    }
}

// <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">

@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    //processRequest(request, response);

    response.setContentType("text/html;charset=UTF-8");
    PrintWriter out = response.getWriter();
    try
    {
        out.println("<html>");
        out.println("<head>");
        out.println("<title>Servlet PickOfferNo</title>");
        out.println("</head>");
        out.println("<body>");
        out.println("<h1>Servlet PickOfferNo at " + request.getContextPath () + "</h1>");
        doPost(request,response);
        out.println("</body>");
        out.println("</html>");
    }
    finally
    {
       out.close(); 
    }
}


@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    //processRequest(request, response);
    String ofrn=null;
    //String cd=null;
    //String no=null;
    String cd="B01";
    String no="25";
    JSONObject obj = new JSONObject();
    //cd=request.getParameter("sec_code");
    PrintWriter out=response.getWriter();
    try
    {
        Class.forName("oracle.jdbc.driver.OracleDriver");
        java.sql.Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@192.168.1.200:1521:pdsm", "test", "test");
             Statement stmt=conn.createStatement();
                 conn.setAutoCommit(true);
                 //ResultSet rs=stmt.executeQuery("select to_char(nvl(max(substr(offerno,4,4)),0)+1) into '"+no+"' from offer1 where div_sec='"+cd+"'");
                 ResultSet rs1=stmt.executeQuery("select lpad(ltrim(rtrim('"+no+"')),4,'0') from dual");
                 //while(rs1.next())
                 ofrn=cd+no;

                 //obj.put("offrn", ofrn);
                 out.println(ofrn);
    }
    catch(Exception e)
    {
        out.println(e.getMessage());
    }
}


@Override
public String getServletInfo() {
    return "Short description";
}// </editor-fold>
}

提前致谢

最佳答案

这是因为你没有选择数据库返回的值。 执行

"select lpad(ltrim(rtrim('"+no+"')),4,'0') from dual"

不会改变“no”或“cd”的值。

您应该获取结果集并对其进行处理以访问结果集返回的第一行中的第一列。

以下代码应该完成分配。 (未测试。)

ResultSet rs1=stmt.executeQuery("select lpad(ltrim(rtrim('"+no+"')),4,'0') from dual");
if(rs1.next()){
no = rs1.getString(1);
}

关于java - 从servlet执行oracle查询结果错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14398377/

相关文章:

sql-server - 如何授予 MSSQL$SQL2016 写入文件夹的权限

sql-server - 通过SSIS将数据加载到Microsoft Azure VM的SQL Server数据库中

sql - 如何从 c 执行 DDL?

sql - PL/SQL 等效于 T-SQL 面向集合的变量串联

java - 如何通过返回数组来打印数组中的唯一元素?

java - 在 spring test mvc 中设置请求部分

sql - 获取日期的默认值

oracle - 如何处理Oracle数据格式错误?

java - 在 ArrayList 中搜索字符串;总是返回 false

java - 导入 javax.servlet 时遇到问题