Заполнение массива из результатов ResultSet SQL - PullRequest
2 голосов
/ 03 апреля 2012

Я извлек отдельные значения String из базы данных и преобразовал их в массив String, используя метод String split().

ResultSet set = state.executeQuery("SELECT * FROM numberLotto");
while(set.next())
{
    num1 = set.getString(1);                   
    num2 = set.getString(2);
    num3 = set.getString(3);
    num4 = set.getString(4);
    num5 = set.getString(5);
    num6 = set.getString(6);
    num7 = set.getString(7);
    totalLotto += num1 + " " + num2 + " " + num3 + " " +  num4 + " " +
        num5 + " " +  num6 + " " +  num7 + " " + "/";
}
String[]listOfNumbers = totalLotto.split("/");

Полученный результат выглядит следующим образом:

3 18 27 38 41 45 47     
4 7 11 15 22 33 42
2 9 15 23 24 39 44 
4 11 16 17 35 39 48

и т. Д.

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

С уважением

Ответы [ 7 ]

4 голосов
/ 03 апреля 2012

Почему вы вообще используете строки? Кажется, это числа, поэтому целые числа будут лучше соответствовать:

List<int[]> listOfNumbers = new ArrayList<int[]>();
while(set.next()) {
     int[] numbers = new int[7];
     for (int i = 0; i < numbers.length; i++) {
         numbers[i] = set.getInt(i + 1);
     }
     listOfNumbers.add(numbers);
}

Вы, очевидно, также можете использовать Integer[] при необходимости.

3 голосов
/ 03 апреля 2012

Вы можете присвоить значения из resultSet массиву строк и добавить его в список.

Пример:

ResultSet set = state.executeQuery("SELECT * FROM numberLotto");
List<String[]> lottoList = new LinkedList<String[]>();
while(set.next())
{
  String[] currentRow = new String[] {set.getString(1),
                                      set.getString(2), 
                                      set.getString(3), 
                                      set.getString(4), 
                                      set.getString(5), 
                                      set.getString(6),  
                                      set.getString(7)};
  lottoList.add(currentRow);
}
// do whatever you like with lottoList

Затем вы можете просмотреть список лото и проверить, сколько там выигрышных номеров.

2 голосов
/ 03 апреля 2012
       List<int[]> list = new ArrayList<int[]>();
        while (set.next()) {
            int[] array = new int[7];
            for (int i = 1; i <= 7; i++) {
                array[i - 1] = set.getInt(i);
            }

            list.add(array);
        }
2 голосов
/ 03 апреля 2012
ResultSet set = state.executeQuery("SELECT COUNT(*) FROM numberLotto");
String[][] array = new String[rs.getInt(1)][6];

ResultSet set = state.executeQuery("SELECT * FROM numberLotto");
int i = 0;
    while(set.next())
    {

                array[i][0] = set.getString(1);                   
                array[i][1]= set.getString(2);
                array[i][2]= set.getString(3);
                array[i][3]= set.getString(4);
                array[i][4]= set.getString(5);
                array[i][5]= set.getString(6);
                array[i][6]= set.getString(7);
          i ++;     
    }
2 голосов
/ 03 апреля 2012

Вы можете использовать ArrayList из String массивов:

ArrayList<String[]> numbers = new ArrayList<String[]>();

Затем разделите listOfNumbers[0] на пробелы и добавьте результат в коллекцию:

String[] listOfNumbers = totalLotto.split("/");
numbers.add(listOfNumbers[0].split(" "));

Итак, предположим, listOfNumbers[0] равно

3 18 27 38 41 45 47

Разделение по пробелам даст вам String[] с числом в каждой позиции.

1 голос
/ 03 апреля 2012
ResultSet set = state.executeQuery("SELECT * FROM numberLotto");
List<String[]> tmp = new ArrayList<String[]>();
while(set.next())
{
    String[] row = new String[7];
    row [0] = set.getString(1);                   
    row [1] = set.getString(2);
    row [2] = set.getString(3);
    row [3] = set.getString(4);
    row [4] = set.getString(5);
    row [5] = set.getString(6);
    row [6] = set.getString(7);
    tmp.add(row);
}
String[][] listOfNumbers = tmp.toArray(new String[tmp.size()][7]);
1 голос
/ 03 апреля 2012

Это пример, вы можете изменить его на свой стиль кода

String[] a = {"10 20 30 40 50","100 200 300 400 500","1000 2000 3000 4000"};
          String[][] b = new String[a.length][];
          for(int i = 0; i<a.length; i++){
              b[i] = a[i].split(" ");
          }
...