Java DAO 对象 SQLexception

Java DAO object SQLexception

Java 和 MySQL 的新手。

我正在使用 DAO 对象通过 Eclipse 查询 table、运行。 MySQL 通过 Workbench 编辑。 table 存在并出现以下异常:

SELECT movie_name, release_dd, release_mm, release_yyyy, duration, language, director, genre, actor_1, actor_2 FROM movie_details_table WHERE movie_name = 'Piku'

java.sql.SQLException: Before start of result set
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:998)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:937)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:926)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:872)
at com.mysql.jdbc.ResultSetImpl.checkRowPos(ResultSetImpl.java:787)
at com.mysql.jdbc.ResultSetImpl.getStringInternal(ResultSetImpl.java:5244)
at com.mysql.jdbc.ResultSetImpl.getString(ResultSetImpl.java:5167)
at com.mysql.jdbc.ResultSetImpl.getString(ResultSetImpl.java:5206)
at com.library.model.MovieDAO.getMovieDetails(MovieDAO.java:41)
at com.library.model.MovieDetTest.main(MovieDetTest.java:18)

MovieDAO class:

package com.library.model;


import java.util.*;
import java.sql.*;
import java.io.*;
import com.library.model.beans.*;

public class MovieDAO {

private static final String DB_URL = 
        "jdbc:mysql://localhost/planner";

//  Database credentials
private static final String USER = "Sudipto";
private static final String PASS = "sudi85";

public MovieDetails getMovieDetails(String inputMov) throws     
SQLException {

MovieDetails movieDetails = new MovieDetails();

    try {

        //Open a connection
        Connection conn = DriverManager.getConnection
                      (DB_URL,USER,PASS);

       //Create and execute query
       String queryString = "SELECT movie_name, release_dd, release_mm, release_yyyy, duration, language, director, genre, actor_1, actor_2 FROM movie_details_table WHERE movie_name = '" + inputMov + "'";

       System.out.println(queryString);

       PreparedStatement statement = conn.prepareStatement
    (queryString);



       ResultSet rsMovieDetails = statement.executeQuery();

       movieDetails.setMovieName(rsMovieDetails.getString
       ("movie_name"));
       movieDetails.setReleaseDate
      (rsMovieDetails.getInt ("release_dd"), rsMovieDetails.getInt ("release_mm"), rsMovieDetails.getInt ("release_yyyy"));
       movieDetails.setDuration(rsMovieDetails.getInt
       ("duration"));
       movieDetails.setLanguage(rsMovieDetails.getString
       ("language"));
       movieDetails.setDirector(rsMovieDetails.getString
       ("director"));
       movieDetails.setGenre(rsMovieDetails.getString
       ("genre"));
       movieDetails.setActor1(rsMovieDetails.getString
       ("actor_1"));
       movieDetails.setActor2(rsMovieDetails.getString
       ("actor_2"));

      }

      catch (SQLException e) {
            e.printStackTrace();
      }

  return movieDetails;

}

}

登录MySQL出现如下错误workbench:

2015-05-31T15:04:36, 27, Note, Aborted connection 27 to db: 'planner' user: 'Sudipto' host: 'localhost' (Got an error reading communication packets)

任何人都可以建议我如何以及需要修复什么吗?

使用 rsMovieDetails.next() 检索详细信息。就像在https://docs.oracle.com/javase/tutorial/jdbc/basics/retrieving.html中使用rs.next()一样。
rs.next() 将光标移动到数据库结果集的下一行,如果有任何行,则 returns 为真,否则 returns 为假。如果行存在,那么你应该检索数据