| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 765 人关注过本帖
标题:Java SQL 异常 HelpHelpHelpHelpHelpHelpHelpHelpHelp
只看楼主 加入收藏
我很幽默
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2009-9-30
收藏
 问题点数:0 回复次数:3 
Java SQL 异常 HelpHelpHelpHelpHelpHelpHelpHelpHelp
public List  News(int i,int b)
{
 List list=new ArrayList();
 PreparedStatement pstmt = null;
 DbUtil con=new DbUtil();
 int c=i*b+1;
 Connection  connnection=con.getConn();
     try{
     String sql="SELECT TOP ? * FROM news WHERE (ID >=(SELECT MAX(ID) FROM (SELECT TOP ? ID FROM news ORDER BY ID) AS T)) ORDER BY ID";
     pstmt=connnection.prepareStatement(sql);
     pstmt.setInt(1, i);
     pstmt.setInt(2, c);
     ResultSet rs =pstmt.executeQuery();
     while(rs.next())
     {
    System.out.println("-----------------OK------------");
    News  news=new News();  
    String str=rs.getString("title");
    news.setTitle(str);
    System.out.println(str);
    list.add(news);
     }
     connnection.close();
     }catch(Exception ex)
     {
         ex.printStackTrace();
     }
     return  list;
}

出这样的错!!!怎么呢? 我把 ?? 换成数字在查询分析器里执行SQL语句可以查到结果啊   哪位前辈帮帮我这个菜鸟
java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][SQL Server]第 1 行: '@P1' 附近有语法错误。
at sun.jdbc.odbc.JdbcOdbc.createSQLException(Unknown Source)
at sun.jdbc.odbc.JdbcOdbc.standardError(Unknown Source)
at sun.jdbc.odbc.JdbcOdbc.SQLExecute(Unknown Source)
at sun.jdbc.odbc.JdbcOdbcPreparedStatement.execute(Unknown Source)
at sun.jdbc.odbc.JdbcOdbcPreparedStatement.executeQuery(Unknown Source)
at com.xinya.dao.NewsInfoDao.News(NewsInfoDao.java:160)
搜索更多相关主题的帖子: Java SQL 
2009-09-30 08:21
我很幽默
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2009-9-30
收藏
得分:0 
upupupup
2009-10-09 12:41
xnceo
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2009-10-12
收藏
得分:0 
没见过这样引用?的,你要不改成用存储过程试下。
2009-10-12 17:37
我很幽默
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2009-9-30
收藏
得分:0 
public List  News(int i,int b)
{  
List list=new ArrayList();
PreparedStatement pstmt = null;
DbUtil con=new DbUtil();
int c=i*b+1;
  Connection  connnection=con.getConn();
     try{
           String sql="SELECT TOP "+i+" * FROM news WHERE (ID >=(SELECT MAX(ID) FROM (SELECT TOP "+c+" ID FROM news ORDER BY ID) AS T)) ORDER BY ID";
           pstmt=connnection.prepareStatement(sql);
             ......
}

为了进度的需要 ,我把代码改成这样就不报错了,不过这样写是可以注入式攻击的!前面的错误到底是哪个地方错了 现在还没明白,谁来帮帮我,upupupupupupup........
2009-10-15 09:05
快速回复:Java SQL 异常 HelpHelpHelpHelpHelpHelpHelpHelpHelp
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.046787 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved