Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Дополнительные данные к ячейке Jtable 
V
    Опции темы
shtrih
Дата 13.6.2011, 02:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 10.2.2011

Репутация: нет
Всего: нет



Можно ли добавить к отдельной ячейке JTable дополнительные данные, которые не изменяются при изменении значения в ячейке и, которых не видно?
Например, для обновления значения в БД, я записываю его ID как дополнительную строку. А при редактировании, я считываю новое значение из ячейки, а также ID и обновляю запись в БД, где ID = ...
PM MAIL   Вверх
mstalker26
Дата 13.6.2011, 22:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 206
Регистрация: 4.7.2009

Репутация: 3
Всего: 11



Вариант с дополнительной колонкой, которая скрыта, не рассматривали? Или необходим ID для каждой ячейки в одной строке?
--------------------
Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
PM   Вверх
shtrih
Дата 14.6.2011, 00:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 10.2.2011

Репутация: нет
Всего: нет



Да, необходимо хранить в каждой ячейке свой ID.
PM MAIL   Вверх
Skipy
Дата 14.6.2011, 11:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 487
Регистрация: 24.8.2006
Где: Москва, Россия

Репутация: 4
Всего: 16



Пишите свою модель таблицы и храните для каждой ячейки хоть черта в ступе.


--------------------
С уважением,
Евгений aka Skipy
www.skipy.ru
PM MAIL WWW ICQ   Вверх
shtrih
Дата 16.6.2011, 15:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 10.2.2011

Репутация: нет
Всего: нет



Спасибо. Реализовал новую модель таблицы, добавив поле, в котором и хранятся данные.

Код

import java.util.Vector;
import javax.swing.SwingWorker;
import javax.swing.event.TableModelEvent;
import javax.swing.event.TableModelListener;
import javax.swing.table.DefaultTableModel;
import labgen.SQLite;

/**
 *
 * @author shtrih
 */
public class MyTableModel extends DefaultTableModel {

    protected TableModelListener myTableModelListener;
    protected Vector<Object[]> cellMeta;

    public MyTableModel(Object[] columnNames, int rowCount) {
        super(columnNames, rowCount);

        int length = columnNames.length;
        cellMeta = new Vector<Object[]>();
        for (int i = 0; i < rowCount; i++) {
            cellMeta.add(new Object[length]);
            for (int j = 0; j < length; j++) {
                cellMeta.get(i)[j] = "";
            }
        }

        myTableModelListener = new myTableModelListener();
        addTableModelListener(myTableModelListener);
    }

    class myTableModelListener implements TableModelListener {

        public void tableChanged(final TableModelEvent e) {

            if (e.getType() == TableModelEvent.UPDATE) {

                VedomostTableModel model = (VedomostTableModel) e.getSource();
                final String[] ids = model.getCellMeta(e.getLastRow(), e.getColumn()).toString().split(","); // "1,2,3"
//                System.out.println(ids[0] +", "+ids[1] +", "+ ids[2]);

                new SwingWorker() {

                    @Override
                    protected Object doInBackground() throws Exception {
                        SQLite.Update("Labs_ex",
                                new String[]{"score"},
                                new String[]{getValueAt(e.getLastRow(), e.getColumn()).toString()},
                                "studentID = " + ids[0] + " AND labID = " + ids[1] + " AND exID",
                                ids[2]);
                        return null;
                    }
                }.execute();
            }
        }
    }

    @Override
    public void insertRow(int row, Vector rowData) {
        super.insertRow(row, rowData);

        int colCount = getColumnCount();
        Object[] meta = new Object[colCount];

        for (int j = 0, n = colCount; j < n; j++) {
            meta[j] = "";
        }
        cellMeta.add(meta);
    }

    public void setCellMetaAt(Object aValue, int row, int column) {
        this.cellMeta.elementAt(row)[column] = aValue;
    }

    public Object getCellMeta(int rowIndex, int colIndex) {
        return cellMeta.get(rowIndex)[colIndex];
    }
}

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   jk1
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, jk1.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: GUI и Java FX приложения | Следующая тема »


 




[ Время генерации скрипта: 0.0587 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.