Форум программистов, компьютерный форум, киберфорум
Java: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/53: Рейтинг темы: голосов - 53, средняя оценка - 4.55
4 / 4 / 2
Регистрация: 14.07.2009
Сообщений: 39

Заполнение JTable данными из SQL

27.07.2009, 12:28. Показов 10632. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
тут возник вопрос как заполнять таблицу. Нашел интересный пример, вот только он нерабочий :\ а за исправление ошибок америкосы хотят денег:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import java.awt.*;
import javax.swing.*;
import java.awt.event.*;
import javax.swing.table.*;
import java.sql.*;
import java.applet.Applet;
 
public class CartonResearchDev extends JFrame{
 
     //Define the application contents
     Container contentPane;
     JTextField txtDate1;
     JTextField txtDate2;
     JLabel lblDate1;
     JLabel lblDate2;
     JButton btn1;
     JTable table;
     ResultSet rs;
     
     public void ExecuteSQL(){
     
 
     }          
 
     public CartonResearchDev(String args[]){
 
          //Main title of application
          super("Carton Research");
          //Create the contents of the app
          this.setResizable(false);
          this.setDefaultCloseOperation(EXIT_ON_CLOSE);
          contentPane = getContentPane();
          contentPane.setLayout(new FlowLayout());
          lblDate1 = new JLabel("Enter First Date:");
          lblDate2= new JLabel("Enter Second Date:");
          txtDate1 = new JTextField(10);
          txtDate2 = new JTextField(10);
          contentPane.add(lblDate1);
          contentPane.add(txtDate1);
          contentPane.add(lblDate2);
          contentPane.add(txtDate2);
          btn1 = new JButton("Click Me To Run Query");
          //btn1.setMnemonic(KeyEvent.VK_C);
          btn1.addActionListener(new ActionListener(){
               public void actionPerformed (ActionEvent ae){}
          });
 
          contentPane.add(btn1);
 
        try {                    
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); 
        } catch (ClassNotFoundException ex) {
            ex.printStackTrace();
        }
 
        String connectionUrl = "jdbc:sqlserver://localhost:4623;" +
            "databaseName=kherson;user=testing;password=J5O6QF0A;";
        Connection con = DriverManager.getConnection(connectionUrl);
        Statement stmt = con.createStatement();
 
               //query to be run against pkms
         ResultSet rs = stmt.executeQuery("SELECT * FROM ds_orders");              
               //Create table for query results to be displayed
         JTable table = new JTable(rs);
         table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
         JScrollPane resultsPane = new JScrollPane(table);
         contentPane.add(resultsPane, BorderLayout.CENTER);        
          pack();
          setVisible(true);
          
     }
 
     public static void main(String args[]){
          //Create the Application window
          CartonResearchDev cr = new CartonResearchDev(args);
          cr.setSize(500, 500);
          cr.setVisible(true);
     }
 
}
Пример адаптирован под уже мою базу. Кто знает почему выдается ошибка в 64 строке?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.07.2009, 12:28
Ответы с готовыми решениями:

Обнуление и заполнение новыми данными JTable
Здравствуйте. У меня возникла следующая проблема: В некотороый момент работы программы необходимо сделать "рефрешь" таблицы....

Заполнение DropDownList данными из SQL запроса
Ребята, добрый день! Посмотрите код, что-то я запуталась как всегда ( Имеем SQL запрос SqlConnection cn = new...

Заполнение treeview данными из БД linq to sql
Есть 3 таблицы: Производитель id name категории id name продукты

7
 Аватар для 0xAX
2451 / 362 / 9
Регистрация: 27.06.2009
Сообщений: 880
27.07.2009, 15:37
Какая именно ошибка вылетает?
0
4 / 4 / 2
Регистрация: 14.07.2009
Сообщений: 39
27.07.2009, 15:43  [ТС]
C:\Documents and Settings\..........\mars\CartonResearchD ev.java:79: cannot find symbol
symbol : constructor JTable(java.sql.ResultSet)
location: class javax.swing.JTable
JTable table = new JTable(rs);
1 error
BUILD FAILED (total time: 1 second)
0
 Аватар для 0xAX
2451 / 362 / 9
Регистрация: 27.06.2009
Сообщений: 880
27.07.2009, 15:55
К сожалению нет под рукой java, могу только предположить, Во первых не помешало бы:
Java
1
2
rs.close();
stmt.close();
Во втрых вы уверены что rs что то возвращает. Попробуйте для начала засунуть результат rs не в JTable а отя бы вевести на консоль.
1
4 / 4 / 2
Регистрация: 14.07.2009
Сообщений: 39
27.07.2009, 15:59  [ТС]
так в том и дело - хочется сразу же в таблицу, минуя все стринги и т.д.
0
 Аватар для 0xAX
2451 / 362 / 9
Регистрация: 27.06.2009
Сообщений: 880
27.07.2009, 16:01
Так в string's данные все таки заносятся?
0
4 / 4 / 2
Регистрация: 14.07.2009
Сообщений: 39
27.07.2009, 16:18  [ТС]
изменил:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import java.awt.*;
import javax.swing.*;
import java.awt.event.*;
import javax.swing.table.*;
import java.sql.*;
import java.applet.Applet;
 
public class CartonResearchDev extends JFrame{
 
     //Define the application contents
     Container contentPane;
     JTextField txtDate1;
     JTextField txtDate2;
     JLabel lblDate1;
     JLabel lblDate2;
     JButton btn1;
     JTable table;
     ResultSet rs;
     
     public void ExecuteSQL(){
     
 
     }          
 
     public CartonResearchDev(String args[]) throws SQLException{
 
          //Main title of application
          super("Carton Research");
          //Create the contents of the app
          this.setResizable(false);
          this.setDefaultCloseOperation(EXIT_ON_CLOSE);
          contentPane = getContentPane();
          contentPane.setLayout(new FlowLayout());
          lblDate1 = new JLabel("Enter First Date:");
          lblDate2= new JLabel("Enter Second Date:");
          txtDate1 = new JTextField(10);
          txtDate2 = new JTextField(10);
          contentPane.add(lblDate1);
          contentPane.add(txtDate1);
          contentPane.add(lblDate2);
          contentPane.add(txtDate2);
          btn1 = new JButton("Click Me To Run Query");
          //btn1.setMnemonic(KeyEvent.VK_C);
          btn1.addActionListener(new ActionListener(){
               public void actionPerformed (ActionEvent ae){}
          });
 
          contentPane.add(btn1);
 
        try {                    
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); 
        } catch (ClassNotFoundException ex) {
            ex.printStackTrace();
        }
 
        String connectionUrl = "jdbc:sqlserver://localhost:4623;" +
            "databaseName=kherson;user=testing;password=J5O6QF0A;";
        Connection con = DriverManager.getConnection(connectionUrl);
        Statement stmt = con.createStatement();
 
               //query to be run against pkms
         ResultSet rs = stmt.executeQuery("SELECT * FROM ds_orders");              
         String str = rs.getString(1);
         System.out.println(str);
               //Create table for query results to be displayed
         //JTable table = new JTable(rs);
       //  table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
        // JScrollPane resultsPane = new JScrollPane(table);
       //  contentPane.add(resultsPane, BorderLayout.CENTER); 
         rs.close();
         stmt.close();
         pack();
         setVisible(true);        
     }
 
     public static void main(String args[]) throws SQLException{
          //Create the Application window
          CartonResearchDev cr = new CartonResearchDev(args);
          cr.setSize(500, 500);
          cr.setVisible(true);
     }
 
}
и получил:
Exception in thread "main" com.microsoft.sqlserver.jdbc.SQLServerEx ception: The result set has no current row.
at com.microsoft.sqlserver.jdbc.SQLServerEx ception.makeFromDriverError(SQLServerExc eption.java:170)
at com.microsoft.sqlserver.jdbc.SQLServerRe sultSet.verifyResultSetHasCurrentRow(SQL ServerResultSet.java:457)
at com.microsoft.sqlserver.jdbc.SQLServerRe sultSet.getterGetColumn(SQLServerResultS et.java:1947)
at com.microsoft.sqlserver.jdbc.SQLServerRe sultSet.getValue(SQLServerResultSet.java :1982)
at com.microsoft.sqlserver.jdbc.SQLServerRe sultSet.getValue(SQLServerResultSet.java :1967)
at com.microsoft.sqlserver.jdbc.SQLServerRe sultSet.getString(SQLServerResultSet.jav a:2292)
at mars.CartonResearchDev.<init>(CartonRese archDev.java:78)
at mars.CartonResearchDev.main(CartonResear chDev.java:93)
Java Result: 1

Добавлено через 1 минуту 52 секунды
----------------------------
УПД:

while (rs.next()) {
String str = rs.getString(1);
System.out.println(str);
}

и все заработало. забегали цифры, все вывелось
0
iMiKE
16.10.2009, 08:08
Интересует такой же вопрос - почему ошибку генерит. Судя по всему, там еще много методов должно быть по приведению полей РезалтСета к виду ЖТабле. Видимо, их и опустили разрабы.
Антов Феоктистов - так как запустили прогу, как передали из бд сразу на ЖТабле данные?
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.10.2009, 08:08
Помогаю со студенческими работами здесь

Заполнение данными на SQL двух связанных таблиц
Есть 2 таблицы: Объявление и Автор поля: Объявление.id, Объявление.Текст, Автор.Фамилия, Автор.Id_автора, Автор.Адрес ,где...

Заполнение шаблона документа excel данными из БД (SQL SERVER)
Сил больше нету искать решение. Ребята, помогите. Нужно из vb6 открыть шаблон документа excel и заполнить его данными из БД. Для примера...

Автоматическое заполнение ячеек данными, взятыми из одной ячейки с динамическими данными
Добрый день! Подскажите, есть ли решение моей задачи: В одной и той же ячейке постоянно (ежесекундно) меняется число (данные...

Заполнение jTable
Здравствуйте! Проблема с заполнением jTable. Хочу заполнить ее массивом значений: 1 колонка- Название товара, 2- Тип, 3- Код товара, 4- Вес...

Повторое заполнение JTable из MySQL
Товарищи! добрый вечер! Разбирался разбирался... собственно, вот код: akvaPic.addActionListener(new ActionListener(){ public...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru