倔强的娃娃笑 2015-10-02 04:44 采纳率: 37.5%
浏览 1880
已采纳

用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条回答 默认 最新

  • 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+ '"'这一句,将变量放在字符串外面。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 WPF使用Canvas绘制矢量图问题
  • ¥15 用三极管设计一个单管共射放大电路
  • ¥15 孟德尔随机化r语言运行问题
  • ¥15 pyinstaller编译的时候出现No module named 'imp'
  • ¥15 nirs_kit中打码怎么看(打码文件是csv格式)
  • ¥15 怎么把多于硬盘空间放到根目录下
  • ¥15 Matlab问题解答有两个问题
  • ¥15 LCD12864中文显示
  • ¥15 在使用CH341SER.EXE时不小心把所有驱动文件删除了怎么解决
  • ¥15 gsoap生成onvif框架