Win a copy of OCP Java SE 8 Programmer II Exam Study Guide this week in the OCP forum!
  • Post Reply Bookmark Topic Watch Topic
  • New Topic

What is wrong with this syntax in Select with LIKE and % ?  RSS feed

 
Ranch Hand
Posts: 345
  • Mark post as helpful
  • send pies
  • Quote
  • Report post to moderator
Hi expert,

I have tried to search the web for the right syntax using LIKE but no matter what I did I'm still getting error as follows :


com.mysql.jdbc.JDBC4Connection@25232994com.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 'Start Java%' AND author LIKE'Betty%' AND publisher LIKE'Safari %'' at line 1
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:425)
at com.mysql.jdbc.Util.getInstance(Util.java:408)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:944)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3973)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3909)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2527)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2680)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2480)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2438)
at com.mysql.jdbc.StatementImpl.executeQuery(StatementImpl.java:1381)
at daomysql.itemsDAOImp.findItemByCriteria(itemsDAOImp.java:104)
at Controller.UserItemsController.process(UserItemsController.java:133)
at Controller.UserItemsController.doPost(UserItemsController.java:66)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:504)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:803)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:790)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1459)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)
Exception.MyDataException



And here's the sql that I am using :



Initially, I tried to use LIKE '%'" and tried LIKE '%';"; and then based on W3School I tried to put [A-Z] also cannot.

I am using MySQL ver 5.7

At the MYSQL site, all the regular expression contains some alphanumberic value....thus I tried to put [A-Z]
https://dev.mysql.com/doc/refman/5.7/en/pattern-matching.html

Hope someone can advise me ...

Thank you.
 
Ranch Foreman
Posts: 373
10
Java Notepad
  • Mark post as helpful
  • send pies
  • Quote
  • Report post to moderator
From the link you had provided: MySQL 5.7 Reference Manual  /  ...  /  Pattern Matching - 3.3.4.7 Pattern Matching: I found the following notes.

In addition to LIKE or NOT LIKE comparison operators -
The other type of pattern matching provided by MySQL uses extended regular expressions. When you test for a match for this type of pattern, use the REGEXP and NOT REGEXP operators (or RLIKE and NOT RLIKE, which are synonyms)...

This (REGEXP) is probably you may want to try.

Also:

selectSql = "SELECT * FROM caproject.items WHERE title LIKE '[A-Z]%'"
+ so.getTitle().trim() + " %' ";



Could you do a System.out.println(selectSql) and post the result here.
 
  • Post Reply Bookmark Topic Watch Topic
  • New Topic
Boost this thread!