java模糊查询sql语句问题

ublicclassShbk{publicstaticfinalStringDBDRIVER="org.gjt.mm.mysql.Driver";publicstatic... ublic class Shbk{
public static final String DBDRIVER="org.gjt.mm.mysql.Driver";
public static final String dburl = "jdbc:mysql://localhost:3306/wang";
public static final String dbuser = "root";
public static final String dbpass = "wang";
public Shbk(String name,String book,String writer)throws Exception{
Connection coon=null; //连接数据库
PreparedStatement psmt=null; //数据库操作
ResultSet rs =null; //保存查询结果
JFrame frame =new JFrame("查询");
String[] titles={"id","姓名","书名","作者"};
Object[][] userinfo=new Object[10][4];
JButton but=new JButton("确定");
String sql="SELECT*"+" FROM library WHRERE name LIKE ? OR book LIKE ? OR writer LIKE ?";
Class.forName(DBDRIVER);
coon=DriverManager.getConnection(dburl,dbuser,dbpass);
psmt=coon.prepareStatement(sql);
psmt.setString(1,"%"+name+"%");
psmt.setString(2,"%"+book+"%");
psmt.setString(3,"%"+writer+"%");
rs=psmt.executeQuery();
for(int i=0;rs.next();i++){
userinfo[i][0]=rs.getInt(1);
userinfo[i][1]=rs.getString(2);
userinfo[i][2]=rs.getString(3);
userinfo[i][3]=rs.getString(4);
}
rs.close();
psmt.close();
coon.close();
frame.addWindowListener(new WindowAdapter(){
public void windowClosing(WindowEvent arg0){
System.exit(1);
}
});
JTable table =new JTable(userinfo,titles);
JScrollPane sp=new JScrollPane(table);
frame.add(sp);
frame.pack();
frame.setLocation(500,350);
frame.setVisible(true);
}
}

编译无问题 运行后出错
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in
your SQL syntax; check the manual that corresponds to your MySQL server version
for the right syntax to use near 'name LIKE '%ssss%' OR book LIKE '%123%' OR wri
ter LIKE '%xxx%'' at line 1
展开
 我来答
261667318
2014-08-12 · TA获得超过898个赞
知道小有建树答主
回答量:680
采纳率:100%
帮助的人:636万
展开全部
1.psmt.setString(1,"%"+name+"%");
psmt.setString(2,"%"+book+"%");
psmt.setString(3,"%"+writer+"%");

这边拼接字符串少了单引号。 "'%"+name+"'%"
2.SELECT* 最好select和*之间加一个空格
czd0001693
2014-08-12 · TA获得超过202个赞
知道小有建树答主
回答量:532
采纳率:0%
帮助的人:249万
展开全部
like 后面不需要加‘’ 可能跟你用的方法有关 psmt.setString(1,"%"+name+"%"); setString可能是自动添加引号了
更多追问追答
追问
我like后没加"啊
我like后没加"啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
z871472639
推荐于2017-10-09 · TA获得超过249个赞
知道小有建树答主
回答量:223
采纳率:0%
帮助的人:140万
展开全部
你那个 在拼接 like语句是 要在外面加 单引号 如 ....like ‘%..%’

也就是 psmt.setString(1,"‘%"+name+"%’");

注意是 在 两边的 % 要在 单引号里面 其他改的方法一样
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
helly84
2018-03-13 · TA获得超过329个赞
知道小有建树答主
回答量:737
采纳率:77%
帮助的人:325万
展开全部
select * 里面的*前后加个空格
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式