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

sql

4个回答

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

qq_20083767
倔强的娃娃笑 恩,是这样的
接近 5 年之前 回复
qq_20083767
倔强的娃娃笑 恩,是这样的
接近 5 年之前 回复

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

qq_20083767
倔强的娃娃笑 没有,提交之前的输出还是正常的,谢谢O(∩_∩)O
接近 5 年之前 回复

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

qq_20083767
倔强的娃娃笑 sql编码默认的是GBK,utf-8不行。
接近 5 年之前 回复

"DELETE FROM customers WHERE customername ='name'"

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

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问