触发生成帐户号码插入表格

时间:2012-09-08 23:23:07

标签: java servlets jdbc

我是java servlet的初学者我的问题是我想生成一个帐户号。每次在我的桌子上都会有一个新帐户。但触发器不起作用请帮助其他值如fname lname用户名和pword等工作正常,servlet没问题,但创建accno的触发器无法正常工作

CREATE OR REPLACE TRIGGER T1 BEFORE INSERT ON UINFO
FOR EACH ROW
BEGIN
set new.UACCNO="jith"||to_char(SQ_1.nextval,'FM0009');
END;
/

// this is my servlet prog

String s1=hreq.getParameter("fname");
            String s2=hreq.getParameter("lname");
            String s3=hreq.getParameter("uacc");
            String s4=hreq.getParameter("uname");
            String s5=hreq.getParameter("pword");
            String s6=hreq.getParameter("pword2");
            String s7[]=hreq.getParameterValues("select");
            String s8=hreq.getParameter("uans");
            String s9=hreq.getParameter("ueid");
            PrintWriter pw=hres.getWriter();

    //if passwords match        

        if(s6.equals(s5))
        {

            PreparedStatement pstmt=con.prepareStatement("insert into uinfo(fname,lname,uacc,uname,pword,uques,uans,ueid) values(?,?,?,?,?,?,?,?)");
pstmt.setString(1,s1);
pstmt.setString(2,s2);
pstmt.setString(3,s3);
pstmt.setString(4,s4);
pstmt.setString(5,s5);
for(int i=0;i<s7.length;i++)
{
if(s7[i]!=null)
pstmt.setString(6,s7[i]);

}
pstmt.setString(7,s8);
pstmt.setString(8,s9);
pstmt.executeUpdate();
pw.println("<html><body  bgcolor=wheat text=blue>");
pw.println("<h1>user  "+s4+"  has Registered successfully</h1><br/><br/>");
pw.println("<h3><a href=login.html>Login Now?</a></h3>");
 pw.println("</body></html>");
 }
 else
 {
            pw.println("<html><body  bgcolor=wheat text=blue>");
            pw.println("<h1>**the passwords do not match go back and check</h1>");
            pw.println("</body></html>");
    }

1 个答案:

答案 0 :(得分:1)

使用触发器为记录创建连续是过度的,你应该从另一个PreparedStatement调用序列,如下所示:

PreparedStatement statement = con.prepareStatement( "SQ_1.nextval from dual")  

然后在拉出连续后,执行所需的转换以创建密钥并将其传递给insert语句。

您有另一个选择是直接在insert语句中传递SQ_1.nextval,但这可能取决于您使用的数据库引擎。

如果我怀疑它是oracle,那就是这样(请注意下面的例子不是在触发器中进行连接/转换,我把它留给你):

PreparedStatement pstmt=con.prepareStatement(
"insert into uinfo(UACCNO,fname,lname,uacc,uname,pword,uques,uans,ueid) values(SQ_1.nextval,?,?,?,?,?,?,?,?)");