qq_20083767
倔强的娃娃笑
2015-10-02 04:44
采纳率: 37.5%
浏览 1.8k

用jsp删除数据库数据时数据库无返回。但是如果SQL语句直接写出变量,返回删除成功了。


<%
response.setContentType("text/html");
request.setCharacterEncoding("GBK");
response.setCharacterEncoding("GBK");
String name = new String(request.getParameter("name").getBytes("ISO-8859-1"),"GBK");
out.print(name);
String driverName = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; //加载JDBC驱动

String dbURL = "jdbc:sqlserver://localhost:1433; DatabaseName=化妆品管理系统"; //连接服务器和数据库sample

String userName = "sa"; //默认用户名

String userPwd = "123456"; //密码
Connection conn;
Class.forName(driverName);
conn = DriverManager.getConnection(dbURL, userName, userPwd);
Statement stat = conn.createStatement();
String sql =
"DELETE FROM customers WHERE customername ='郭海涛'";
int i = stat.executeUpdate(sql);
out.println(i);
%>

** "DELETE FROM customers WHERE customername ='郭海涛'";**
这样就可以删除成功。
** "DELETE FROM customers WHERE customername ='name'";**
这样就删除不了。
但是打印出来name的值就是‘郭海涛’,没有乱码。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • ice__snow
    ffiirree 2015-10-03 02:08
    已采纳

    如果使用的是这句话,"DELETE FROM customers WHERE customername ='name'",这句话被包含在双引号中间,显然是个字符串,其中的name被当做字符串的一部分,所以送给数据库的语句就是DELETE FROM customers WHERE customername ='name',也就是说你的变量name没有被'郭海涛'替换掉,你可以使用"DELETE FROM customers WHERE customername =" +'"' + name+ '"'这一句,将变量放在字符串外面。

    点赞 评论
  • villare
    villare 2015-10-02 06:12

    编码问题吧,看看这个 http://blog.sina.cn/dpool/blog/s/blog_641d569301010vsj.html?vt=4
    可以debug输出查询语句,看看是不是在提交到数据库之前就已经乱码了,,,

    点赞 评论
  • Marksinoberg
    泰 戈 尔 2015-10-02 08:04

    你试试改成国际化的utf-8的编码试一试,还有可能是你的数据库与之不匹配的问题

    点赞 评论
  • lzp_lrp
    WorldMobile 2015-10-26 12:44

    "DELETE FROM customers WHERE customername ='name'"

    name是变量,要用实际的内容替换掉

    点赞 评论

相关推荐