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

用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的值就是‘郭海涛’,没有乱码。

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

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

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

"DELETE FROM customers WHERE customername ='name'"

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