JSP 把信息提交到数据库,出错,无法插入到数据库

来源:百度知道 编辑:UC知道 时间:2024/06/01 22:25:51
企业报刊订阅系统,填写订阅单后提交,将信息插入到数据库。
错误的信息是:
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+

数据类型不符合
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直接访问数据库

服务器内部出错了。