Сложить данные из бд в массив/список

 
 
 
Сообщения:2
Добрый день. Необходимо сложить полученные данные из таблицы бд в список/массив. Есть такой код, но я не понимаю, как тут можно обращаться потом объектам. Мне нужно будет сравнить data[count][3] с целым числом, но пр компиляции выходит ошибка, что data[count][3] это объект. Подскажите пожалуйста, как можно обращаться к массиву объектов как к числам или как переделать его в обычный массив/список.
String Querry = "SELECT  [Id],[Lat],[Long],[Rad] FROM [***]";
               ResultSet rs = stmt.executeQuery(Querry);
			   int count = 0;
				while(rs.next()) {
					count++;
				}
				Object[][] data = new Object[count][4];
               count = 0;

				while(rs.next()) { 
				rs.beforeFirst();				
                data[count][0] = rs.getString(1);/*int*/
                data[count][1] = rs.getString(2);/*float*/
                data[count][2] = rs.getString(3);/*float*/
                data[count][3] = rs.getString(4);/*int*/

                count++;
				
				}
 
 
Сообщения:117
Удобно конечно пользоваться списками List, чем с массивами. И тогда не придётся использовать вот такой код:
int count = 0;
while(rs.next()) {
    count++;
}

Да и значение полей обычно никто в массиве не хранит, а создают для этого отдельный класс.
У ResultSet есть методы для извлечения значений полей типа int, float и т.д. Например, rs.getInt(1).
И значение полей обычно извлекают не по индексу поля, а по его наименованию. Такой код легче читать и уменьшает вероятность ошибиться. По индексу обычно извлекают, если полей мало, один или два.
Код для примера:
create table coords (
  id int serial primary key ,
  lat float not null ,
  long float not null ,
  rad int not null
);


package db;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

public class CoordsDemo {
    private static final String URL = "jdbc:h2:./test";

    public static void main(String[] args) throws SQLException {
        System.out.println(getCoords());
    }

    private static List<Coord> getCoords() throws SQLException {
        try (Connection conn = DriverManager.getConnection(URL);
             Statement stmt = conn.createStatement()) {

            ResultSet rs = stmt.executeQuery("SELECT id, lat, long, rad FROM coords");
            List<Coord> coords = new ArrayList<>();

            while (rs.next()) {
                Coord coord = new Coord();
                coords.add(coord);

                coord.setId( rs.getInt("id") );
                coord.setLat( rs.getFloat("lat") );
                coord.setLong( rs.getFloat("long") );
                coord.setRad( rs.getInt("rad") );
            }

            return coords;
        }
    }
}

class Coord {
    private Integer id;
    private Float lat;
    private Float long_;
    private Integer rad;

    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public Float getLat() {
        return lat;
    }
    public void setLat(Float lat) {
        this.lat = lat;
    }
    public Float getLong() {
        return long_;
    }
    public void setLong(Float long_) {
        this.long_ = long_;
    }
    public Integer getRad() {
        return rad;
    }
    public void setRad(Integer rad) {
        this.rad = rad;
    }

    @Override
    public String toString() {
        return "Coord{" +
                "id=" + id +
                ", lat=" + lat +
                ", long_=" + long_ +
                ", rad=" + rad +
                '}';
    }
}
Изменен:14 июн 2019 05:44
 
 
Сообщения:2
В Java особо не разбираюсь, поэтому можно, пожалуйста, пример по проще без создания классов и методов
 
 
Сообщения:117
Ну тогда используйте свой пример. Чтобы получить нужный тип из массива используйте кастинг:
Object[][] data = ...
...
if (((Integer) data[index][0]) == 10 { ...
 
Модераторы:frymock
Сейчас эту тему просматривают:Нет