欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

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

更新时间: 2014-05-17 23:49:50 责任编辑: Author_N7

 

使用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正解.
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-05-17 23:49:50
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/838781/
本文WWW.DOC100.NET DOC100.NET版权所有。