25

私は非常に単純なコードを持っています:

pstat=con.prepareStatement("select typeid from users where username=? and password=?");             
pstat.setString(1, username);
pstat.setString(2, password);
rs=pstat.executeQuery();
int rowCount=0;
while(rs.next())
{       
    rowCount++;         
}
rs.beforeFirst();
if(rowCount>=1)
{
while(rs.next())
{
    typeID=rs.getInt(1);
}

しかし、このコードを実行すると...

java.sql.SQLException: Result set type is TYPE_FORWARD_ONLY
at sun.jdbc.odbc.JdbcOdbcResultSet.beforeFirst(Unknown Source)
at server.ClientImpl.login(ClientImpl.java:57)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at sun.rmi.server.UnicastServerRef.dispatch(Unknown Source)
at sun.rmi.transport.Transport$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at sun.rmi.transport.Transport.serviceCall(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport.handleMessages(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)

何が原因で、どうすれば修正できますか?

4

9 に答える 9

31

最初のステートメントをこれに変更します

pstat=con.prepareStatement("select typeid from users where username=? and password=?",
                            ResultSet.TYPE_SCROLL_SENSITIVE, 
                        ResultSet.CONCUR_UPDATABLE);

このようにして、前後に移動できるので、心配することは少なくなります

于 2011-06-16T06:14:46.080 に答える
19

タイプTYPE_FORWARD_ONLYは、結果セットを前方にのみ移動でき、後方に移動できないことを意味するため、 で戻ろうとすると例外が発生しますbeforeFirst()。代わりに、結果セットの型をパラメーターとして受け取る次のprepareStatement()を使用するか、次のことを行うことができます。

        pstat=con.prepareStatement("select typeid from users where username=? and password=?");             
        pstat.setString(1, username);
        pstat.setString(2, password);
        rs=pstat.executeQuery();
        int rowCount=0;

        while(rs.next())
        {
            rowCount++;
            typeID=rs.getInt(1);
        }
于 2011-06-16T06:08:38.323 に答える
9

これは、タイプ TYPE_SCROLL_SENSITIVE の結果セットでのみ実行できます。これは、「スクロール可能で、一般に他のユーザーによる変更に敏感な ResultSet オブジェクトのタイプを示す定数」として定義されています。

次のようなことをする必要があります...

Statement statement = 
 connection.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
    ResultSet.CONCUR_READ_ONLY);
于 2011-06-16T06:15:35.390 に答える
5

java.sql.SQLException:結果セットのタイプはTYPE_FORWARD_ONLYです

JDBC 2.0 APIを使用すると、ユーザーはカーソルを前後に移動できる柔軟性があります。

次のようにstatemntを作成することで、エラーを取り除くことができます。

Statement st = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);

また、行数を数えるためのより良い方法は

rs=pstat.executeQuery();                //execute the query
rs.last();                              //move the cursor to the last row
int numberOfRows = rs.getRow();         //get the number of rows
rs.beforeFirst();                       //back to initial state
于 2012-05-28T09:56:11.820 に答える
3

例外が言うように:結果セットを前方以外の方向にスクロールすることはできません。したがって、結果セットをループして行数を取得すると (なぜそれを行うのかさえわかりません)、この行はその例外をスローします。

rs.beforeFirst();

それは逆にスクロールするからです。

スクロールできるようにステートメントを作成するか (たとえば Google)、その行カウントを削除します。カウントは不要に思えるので、後者をお勧めします。

于 2011-06-16T06:09:18.610 に答える
3

この質問はかなり古いです。解決策はすでに見つかっていると思います。ただし、ここで Aditya が行ったこととは異なることを提案したいと思います。

pstat=con.prepareStatement("select typeid from users where username=? and password=?",
                                ResultSet.TYPE_SCROLL_INSENSITIVE, 
                            ResultSet.CONCUR_UPDATABLE);

ResultSet.TYPE_SCROLL_SENSITIVE の代わりに、INSENSITIVE を使用します

このリンクを参照して確認してください

于 2013-01-08T08:24:53.213 に答える
1

rowCount変数は必要ありません。rsで2つのループを実行しています。コードのこの部分によって実行される行数を取得するには、2番目のループのみが必要です。

 while (rs.next()){
 typeID=rs.getInt(1); //typeID is the number of rows in the ResultSet
}
于 2011-06-16T06:22:45.597 に答える