问题描述
- 用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是变量,要用实际的内容替换掉