在Struts中怎么把中文数据从JSP页面提交到MySql数据库中

suny999 2009-04-05 03:37:32
Struts中的Action文件代码:
public class TiJiaoAction extends Action {
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) throws UnsupportedEncodingException {
ActionForward actionforward = new ActionForward();

UserInfoActionForm userInfoForm = (UserInfoActionForm)form;

request.setCharacterEncoding("gb2312");
String id = userInfoForm.getId();
String name = userInfoForm.getName();

Connection con = null;
Statement sta = null;

try{
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost/china";
String user = "root";
String pwd = "111";

con = DriverManager.getConnection(url,user,pwd);
sta = con.createStatement();

String sql = "insert into user_info values('"+id+"','"+name+"')";
sta.executeUpdate(sql);
actionforward = mapping.findForward("success");

}catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (sta != null) {
try {
sta.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (con != null) {
try {
con.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
return actionforward;
}
}
JSP页面中编码(<%@ page language="java" pageEncoding="gb2312"%>)也是GB2312。
但是在jsp页面提交时显示下面错误信息(在数据库平台可以直接向表中插入中文数据):
com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'name' at row 1
跪求天下IT豪杰,代码尽量写的详细点,本人比较笨,思念答案早日到来...
...全文
122 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
suny999 2009-04-17
  • 打赏
  • 举报
回复
谢谢各位朋友
jixiuffff 2009-04-12
  • 打赏
  • 举报
回复
String sql = "insert into user_info values('"+id+"','"+name+"')";


打印一下sql这句话,然后复制到mysql 测试一下
suny999 2009-04-12
  • 打赏
  • 举报
回复
是UTF-8,有什么问题吗
流星谜 2009-04-12
  • 打赏
  • 举报
回复
这里有完整答案,慢慢看
http://topic.csdn.net/u/20090411/11/9457d41a-f7bd-48f3-ada7-b3a05a86f5f1.html
palm_civet 2009-04-07
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 suny999 的回复:]
各位前辈,不是数据长度不够,我已经测试过了,就算只输入一个汉字也会报错,数据库中的name字段长度为16,不短了,不是这个问题
[/Quote]

是字符编码不对,你mysql是什么编码的?
suny999 2009-04-07
  • 打赏
  • 举报
回复
各位前辈,不是数据长度不够,我已经测试过了,就算只输入一个汉字也会报错,数据库中的name字段长度为16,不短了,不是这个问题
jigjhajeig 2009-04-05
  • 打赏
  • 举报
回复
great1681 2009-04-05
  • 打赏
  • 举报
回复
是啊,你测试的时候将name输入的简短些,
例如:aa
看看如何?
或者将数据库的name字段长度加长些试试~~
jourqel 2009-04-05
  • 打赏
  • 举报
回复
Data too long for column 'name' at row 1
数据超出长度了~你把数据库里面的长度值改大些~如果数据比较长改成文本域类型吧~那样肯定不会超出长度~

81,077

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧