Запись информации из базы данных SQL в список

Я работаю над своей домашней работой, и я не могу выполнить одну часть своей программы ...

У меня есть класс JTable, который делает таблицу в моем коде ... Мне нужно написать метод, который берет информацию из базы данных sql и записывает ее в список

метод ДОЛЖЕН выглядеть так:

public static List selectAnswers (int questionId) вызывает SQLException, IOException

следующий код написан мной:

public static List selectAnswers (int questionId) throws SQLException, IOException
{
    Connection veza = connectToDatabase();

    Properties query = new Properties();

    AnswersTableModel atm = new AnswersTableModel();

    String selectAnswers = query.getProperty("selectAnswers");

    PreparedStatement preparedStatement = veza.prepareStatement(selectAnswers);

    ResultSet rs = preparedStatement.executeQuery();

    List lista = new ArrayList();

    while(rs.next()){

        String answerText = rs.getString("answerText");
        boolean isRight = rs.getBoolean("answerRight");

                    ?????????????????????????????????????????????????


    }

    closeConnectionToDatabase(veza);

    return lista;
}

????? поле отсутствует, и я не знаю, что написать там, чтобы написать информацию answeText и isRight в класс AnswerRow, в AnswerTableModel, в список ...

Код, который делает JTable (и предоставляется мне и не может быть изменен моим учителем), находится здесь:

package hr.tvz.java.deveti.model;

import java.util.List;
import java.util.ArrayList;

import javax.swing.table.AbstractTableModel;

public class AnswersTableModel extends AbstractTableModel {

    private Object[][] answers;
    private String[] columnNames;

    public AnswersTableModel (String[] colNames){
        super();
        columnNames = colNames;
    }

    public AnswersTableModel() {
        super();
        this.columnNames = new String[AnswerRow.TABLE_COLUMNS];
        this.columnNames[0] = "Odgovor";
        this.columnNames[1] = "Točan/Netočan";
    }

    public java.lang.Class<?> getColumnClass(int columnIndex) {
        return getValueAt(0, columnIndex).getClass();
    }

    public int getColumnCount() {
        return AnswerRow.TABLE_COLUMNS;
    }

    public int getRowCount() {
        if (answers != null)
            return answers.length;
        else
            return 0;
    }

    public Object getValueAt(int row, int column) {
        return answers[row][column];
    }

    public String getColumnName(int column){
        return columnNames[column];
    }

    public void setValueAt (Object aValue, int rowIndex, int columnIndex){
        answers[rowIndex][columnIndex] = aValue;
    }

    public boolean isCellEditable (int rowIndex, int columnIndex){
        return true;
    }

    public void addNewRow(){
        Object[] o = new Object[] {"", false};
        if ((answers == null) || (answers.length == 0)) {
            answers = new Object[][] {o};
        }else{
            Object[][] answersTemp = new Object[answers.length + 1][AnswerRow.TABLE_COLUMNS];
            for (int i = 0; i < answers.length; i++)
                answersTemp[i] = answers[i];
            answersTemp[answersTemp.length - 1] = o;
            answers = answersTemp;
        }
    }

    public List getAnswerRows() {
        List list = new ArrayList<>();
        for (Object[] oRow : answers) {
            AnswerRow row = new AnswerRow();
            row.setAnswer((String) oRow[0]);
            row.setRight((boolean) oRow[1]);
            list.add(row);
        }

        return list;
    }

    public void setAnswerRows(List answerRows){
        if (answerRows.size() == 0 ) {
            this.answers = new Object[0][0];
            return;
        }
        this.answers = new Object[answerRows.size()][AnswerRow.TABLE_COLUMNS];
        for (int i = 0; i < answers.length; i++){
            answers[i][0] = answerRows.get(i).getAnswer();
            answers[i][1] = answerRows.get(i).isRight();
        }
        this.columnNames = new String[AnswerRow.TABLE_COLUMNS];
        this.columnNames[0] = "Odgovor";
        this.columnNames[1] = "Točno/Netočno";
    }

    public class AnswerRow {
        public static final int TABLE_COLUMNS = 2;
        private boolean isRight;
        private String answer;

        public AnswerRow(){
            answer = "";
            isRight = false;
        }

        public AnswerRow(String answer, boolean isRight){
            this.answer = answer;
            this.isRight = isRight;
        }

        public String getAnswer() {
            return answer;
        }

        public void setAnswer(String answer){
            this.answer = answer;
        }

        public boolean isRight(){
            return isRight;
        }

        public void setRight(boolean isRight){
            this.isRight = isRight;
        }
    }
}

Пожалуйста, помогите мне .. спасибо!

0
nl ja de
запрос работает нормально (selectAnswers = SELECT * FROM QUIZ.ANSWERS WHERE questionId =? и SQL-база данных в порядке) ... единственная проблема заключается в написании этой информации (answerText, isRight) в список
добавлено автор Kristijan Delivuk, источник
вы можете подтвердить, что что-то происходит с объектом запроса между: Свойства query = new Properties (); и String selectAnswers = query.getProperty ("selectAnswers"); ? В противном случае проблема заключается в том, что ваш объект запроса не имеет значения для «selectAnswers», поэтому запрос на выполнение не выполняется.
добавлено автор Gus, источник

2 ответы

List lista = new ArrayList();

    while(rs.next()){

        String answerText = rs.getString("answerText");
        boolean isRight = rs.getBoolean("answerRight");

        //Create AnswerRow instance and set values to it and Add it to list.
        AnswersTableModel .AnswerRow ansrow = atm.new AnswerRow();
        ansrow.setAnswer(answerText);
        ansrow.setRight(isRight);

       //Add it to list.
       lista.add(ansrow);
    }

Одно я не уверен, почему у вас есть AnswersTableModel и что вы с этим делаете.

2
добавлено
ОК. AnswerRow - это внутренний класс, поэтому синтаксис должен быть другим, обновленным ответом. Прочтите этот учебник docs.oracle.com/javase/tutorial/java/javaOO /nested.html
добавлено автор kosa, источник
я пробовал этот путь, но потом на AnswerRow ar = new AnswerRow (); строка является ошибкой: «нет экземпляра экземпляра типа AnswerTableModel доступен. Должен квалифицировать выделение с помощью экземпляра экземпляра типа ReplyTableModel (например, x.new A (), где x является экземпляром AnswerTableModel« AnswersTableModel class создает JTable с ответами ...
добавлено автор Kristijan Delivuk, источник
@Nambari спасибо
добавлено автор Kristijan Delivuk, источник
Я думаю, что модель действительно не должна создаваться внутри метода selectAnswers, но везде, где вызывается метод selectAnswer, а затем присваивать результат метода модели с помощью метода setAnswerRows.
добавлено автор asermax, источник

Использовать открытый конструктор AnswerRow (String answer, boolean isRight) для создания объекта

AnswerRow ar=null;
while(rs.next()){

    String answerText = rs.getString("answerText");
    boolean isRight = rs.getBoolean("answerRight");
    ar=new AnswerRow(answerText, isRight);
    lista.add(ar);

}
0
добавлено
Я пробовал этот путь, но затем на ar = new AnswerRow (...); строка является ошибкой: «нет экземпляра экземпляра типа AnswerTableModel является доступным. Должен квалифицировать выделение с помощью экземпляра экземпляра типа AnswerTableModel (например, x.new A (), где x является экземпляром AnswerTableModel"
добавлено автор Kristijan Delivuk, источник
pro.jvm
pro.jvm
3 503 участник(ов)

Сообщество разработчиков Java Scala Kotlin Groovy Clojure Чат для нач-их: @javastart Наш сайт: projvm.com projvm.ru Наш канал: @proJVM Вакансии: @jvmjobs Конфы: @jvmconf

Java & Co
Java & Co
2 370 участник(ов)

Можно обсуждать с матом и без всё, что касается жабы, вплоть до холиваров. НЕ ИМЕЕТ ОТНОШЕНИЯ К САЙТУ JAVARUSH.RU ПРАВИЛА - https://t.me/javarush/75723 Вакансии сюда - https://telegram.me/joinchat/B7IzvUCnfo6d8t3yIxKguQ По вопросам - @thedude

learn.java
learn.java
1 888 участник(ов)

Чат для начинающих и не только Статистика: https://combot.org/chat/-1001083535868 Основной чат - @jvmchat

Java Underground
Java Underground
169 участник(ов)

https://vk.com/javatutorial

Javanese Questions
Javanese Questions
109 участник(ов)

Чат предназначен для обмена знаниями строго в формате в вопрос-ответ. Тема — Java, Kotlin и Android. Вопрос должен быть предварительно прогуглен, понятно и грамотно сформулирован, помечен хэштегами. Ответ — тем более. Куски кода размером в несколько строк можно писать прямо здесь, для больших кусков кода стоит использовать http://gist.github.com/, http://pastebin.com/, https://codeshare.io/ или любой аналогичный сервис. В некоторых случаях можно прикреплять скриншоты. Стикеры и гифки запрещены. Дополнять и уточнять вопросы и ответы — редактированием исходного сообщения. Обсуждения должны приводить к редактированию вопроса/ответа и удаляться. По хештегам можно искать существующие вопросы и овтеты: #вопрос #ответ #git #generics #java #server #awt #javafx #swing #kotlin #anko #tornadofx #ktor #android #recyclerView #performance #arch #network #permissions #storage #async