首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Java Web开发 >

使用PreparedStatement对象,往sql语句中的”?“设值,出现错误

2013-07-08 
使用PreparedStatement对象,往sql语句中的”?“设值,出现异常想执行一个模糊查询, sql语句是:SELECT * FROM

使用PreparedStatement对象,往sql语句中的”?“设值,出现异常
想执行一个模糊查询, sql语句是:"SELECT * FROM teacher WHERE t_name LIKE %?%";
  其中想通过文本框获取值,用setString()方法将值传入sql语句的?中,但是执行,总是有异常
,说sql语法有问题。
  该怎么解决。。。 SQL 异常
[解决办法]
?用'xxx'替换后去数据库执行一下。
oracle改成
SELECT * FROM teacher WHERE t_name LIKE '%'
[解决办法]
?
[解决办法]
'%'


[解决办法]
试试
String sql = "SELECT * FROM teacher WHERE t_name LIKE ?";
PreparedStatement pst = cnn.prepareStatement(sql);
pst.setString(1, "%"+name+"%");//name是你的传值

不然把你的报什么错,贴出来看下。
[解决办法]
可以不用setString()方法:
sql="select * from teacher where t_name like '%"+setString()方法中要设置的值+"%'";
[解决办法]
SELECT * FROM teacher WHERE t_name LIKE %?%
替换成
SELECT * FROM teacher WHERE t_name LIKE %'abc'%
有可能不报错吗
[解决办法]
5L正解.

热点排行