JSP 把信息提交到数据库,出错,无法插入到数据库
企业报刊订阅系统,填写订阅单后提交,将信息插入到数据库。错误的信息是:Theserverencounteredaninternalerror()thatprevented...
企业报刊订阅系统,填写订阅单后提交,将信息插入到数据库。
错误的信息是:
The server encountered an internal error () that prevented it from fulfilling this request.
在SQL SERVER2000 数据库中,数据类型是
dno char 20 0
nno char 20 0
account char 20 0
dcount int 4 0
dbegin datetime 8 0
dend datetime 8 0
以下是我的部分JSP代码:
/*获取表单传递过来的注册信息*/
String dno=request.getParameter("dno"); //订阅编号
String nno=request.getParameter("nno"); //报刊号
String account=request.getParameter("account");//用户号
String dcount=request.getParameter("dcount");//订阅数量
String dbegin=request.getParameter("dbegin");//订阅起始日期
String dend=request.getParameter("dend");//订阅终止日期
String sql="insert into dingyuedan(dno,nno,account,dcount,dbegin,dend) values('"+dno+"','"+nno+"','"+account+"','"+dcount+"','"+dbegin+"',"+dend+"')";//插入记录的SQL语句
int i=stmt.executeUpdate(sql);
if (i==1)
{
out.println("恭喜,注册成功!");
response.sendRedirect(" dingyue_show.jsp");
%>
</p>
<div align="center">
<%
}
else{
out.println("订阅时发生错误,请重新订阅!");
%>
</div>
<div align="center">
<%}%>
<%
stmt.close();
conn.close();//关闭数据库链接
%>
请问我哪里出错,应该怎么修改,谢谢。。 展开
错误的信息是:
The server encountered an internal error () that prevented it from fulfilling this request.
在SQL SERVER2000 数据库中,数据类型是
dno char 20 0
nno char 20 0
account char 20 0
dcount int 4 0
dbegin datetime 8 0
dend datetime 8 0
以下是我的部分JSP代码:
/*获取表单传递过来的注册信息*/
String dno=request.getParameter("dno"); //订阅编号
String nno=request.getParameter("nno"); //报刊号
String account=request.getParameter("account");//用户号
String dcount=request.getParameter("dcount");//订阅数量
String dbegin=request.getParameter("dbegin");//订阅起始日期
String dend=request.getParameter("dend");//订阅终止日期
String sql="insert into dingyuedan(dno,nno,account,dcount,dbegin,dend) values('"+dno+"','"+nno+"','"+account+"','"+dcount+"','"+dbegin+"',"+dend+"')";//插入记录的SQL语句
int i=stmt.executeUpdate(sql);
if (i==1)
{
out.println("恭喜,注册成功!");
response.sendRedirect(" dingyue_show.jsp");
%>
</p>
<div align="center">
<%
}
else{
out.println("订阅时发生错误,请重新订阅!");
%>
</div>
<div align="center">
<%}%>
<%
stmt.close();
conn.close();//关闭数据库链接
%>
请问我哪里出错,应该怎么修改,谢谢。。 展开
2个回答
展开全部
数据类型不符合
dcount int 4 0
dbegin datetime 8 0
dend datetime 8 0
以上是你的表中的数据类型
以下是你获取的数据类型 String
String dcount=request.getParameter("dcount");//订阅数量
String dbegin=request.getParameter("dbegin");//订阅起始日期
String dend=request.getParameter("dend");//订阅终止日期
String sql="insert into dingyuedan(dno,nno,account,dcount,dbegin,dend) values('"+dno+"','"+nno+"','"+account+"','"+dcount+"','"+dbegin+"',"+dend+"')";//插入记录的SQL语句
当执行,会因数据类型不符合,产生异常
修改方法:
方法1.把表的数据类型都改成char
懒人的做法
方法2.数据之间转换
String到Date
DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
str = "2007-1-18";
date = format1.parse(str);
String到int
int d=Integer.valueOf(xxx); xxx为变量
sql语句不严格,没有分号结尾
另外~提醒一点,尽量不要用jsp直接访问数据库
dcount int 4 0
dbegin datetime 8 0
dend datetime 8 0
以上是你的表中的数据类型
以下是你获取的数据类型 String
String dcount=request.getParameter("dcount");//订阅数量
String dbegin=request.getParameter("dbegin");//订阅起始日期
String dend=request.getParameter("dend");//订阅终止日期
String sql="insert into dingyuedan(dno,nno,account,dcount,dbegin,dend) values('"+dno+"','"+nno+"','"+account+"','"+dcount+"','"+dbegin+"',"+dend+"')";//插入记录的SQL语句
当执行,会因数据类型不符合,产生异常
修改方法:
方法1.把表的数据类型都改成char
懒人的做法
方法2.数据之间转换
String到Date
DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
str = "2007-1-18";
date = format1.parse(str);
String到int
int d=Integer.valueOf(xxx); xxx为变量
sql语句不严格,没有分号结尾
另外~提醒一点,尽量不要用jsp直接访问数据库
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询