无线&移动互联网技术研发

换位思考·····
posts - 19, comments - 53, trackbacks - 0, articles - 283
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

java.sql.SQLException: '@P0' 附近有语法错误

Posted on 2009-12-10 11:00 Gavin.lee 阅读(3521) 评论(1)  编辑  收藏 所属分类: JDBC
SQL语句:
String sql = "select top ? * from bbs_posts where p_fid=? order by p_addtime desc";
        prepStmt 
= conn.prepareStatement(sql);
        prepStmt.setInt(
1, xxx);
        prepStmt.setInt(
2, xx);
        prepStmt.executeQuery()

预编译:
Exception:
java.sql.SQLException: '@P0' 附近有语法错误。
    at net.sourceforge.jtds.jdbc.SQLDiagnostic.addDiagnostic(SQLDiagnostic.java:
368)
    at net.sourceforge.jtds.jdbc.TdsCore.tdsErrorToken(TdsCore.java:
2816)
    at net.sourceforge.jtds.jdbc.TdsCore.nextToken(TdsCore.java:
2254)
    at net.sourceforge.jtds.jdbc.TdsCore.getMoreResults(TdsCore.java:
631)
    at net.sourceforge.jtds.jdbc.JtdsStatement.executeSQLQuery(JtdsStatement.java:
477)
    at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.executeQuery(JtdsPreparedStatement.java:
777)
    at yixun.wap.db.DBConnection.executeQuery(DBConnection.java:
41)
    at yixun.wap.bbs.dao.ForumDAO.get500WANforum(ForumDAO.java:
282)
    at yixun.wap.bbs.BbsCache.get500WANforumCache(BbsCache.java:
91)
    at yixun.wap.bbs.service.ForumBO.get500WANforum(ForumBO.java:
143)
    at _jsp._page._bbs._space._second__jsp._jspService(_second__jsp.java:
83)

原因:sql不支持为select top ? 预编译,换成动态拼接
String sql = "select top %s * from bbs_posts where p_fid=? order by p_addtime desc";
        sql 
= String.format(sql, num);

评论

# re: java.sql.SQLException: '@P0' 附近有语法错误  回复  更多评论   

2014-02-01 22:24 by 单独
你这样在?号加个括号就行的了.
String sql = "select top (?) * from bbs_posts where p_fid=(? )order by p_addtime desc";

只有注册用户登录后才能发表评论。


网站导航: