Я создал базовый CRUD GUI с Hibernate, но я получаю «индекс из привязанного исключения».В чем может быть проблема? - PullRequest
0 голосов
/ 19 февраля 2019

Вот графический интерфейс моего приложения с индексом сообщения об ошибке: GUI wit out of bound exception

Вот код для алгоритма поиска:

  private void searchButtonActionPerformed(java.awt.event.ActionEvent evt) {                                             
        try {
            String name = this.searchTextField.getText();
            if (name.equals("")) {
                FillData();
            }else{
            session=sessionFactory.openSession();
            transaction = session.beginTransaction();
            Criteria criteria = session.createCriteria(Items.class);
            Items list = (Items) criteria.add(Restrictions.eq("name", name).ignoreCase()).uniqueResult();
            transaction.commit();
            session.close();
            if (list.equals(null)) {
                    JOptionPane.showMessageDialog(null, "No results");
                }else{

                if (dtm.getColumnCount()==0) {
                dtm.addColumn("Name");
                dtm.addColumn("Category");
                dtm.addColumn("Quantity");
                dtm.addColumn("Net Price (per unit)");
                dtm.addColumn("Gross Pice (per unit)");
                dtm.addColumn("Net Price (total)");
                dtm.addColumn("Gross Price (total)");
                }
                Font f = new Font("Georgia", Font.BOLD, 16);      
                JTableHeader header = itemTable.getTableHeader();
                header.setFont(f);
                itemTable.setRowHeight(25);

                for (int i = 0; i < 1; i++) {
                    dtm.addRow(new Object[]{list.getName(), list.getCategory().getName(), getQuantity().get(i).getQuantity(), list.getNetPrice(), list.getNetPrice()*(list.getVatRate()+1), getQuantity().get(i).getQuantity()*list.getNetPrice(), list.getNetPrice()*(list.getVatRate()+1)*getQuantity().get(i).getQuantity()});
                }

                this.itemTable.setModel(dtm);}}} catch (Exception e) {
             JOptionPane.showMessageDialog(null, e.getMessage()); 
             e.printStackTrace();
        }
    }     

Я также пытался использовать другой алгоритм, в котором Список элементов был на самом деле Список списка , но я понял, что у меня будут только единичные результаты.

Любые идеи для решения приветствуются!

Я пытаюсь выписать необходимые данные с помощью этого класса.Обратите внимание на слово «try».

     public List<ItemAndQuantity> getQuantity()
        {
        List<ItemAndQuantity> quantity = new ArrayList<ItemAndQuantity>();       
            try {
                session = sessionFactory.openSession();
                transaction = session.beginTransaction();
//  Query query = session.createQuery("select sum(t.Flow * a.In_Or_Out), i.Item_ID from TRANSACTIONS t, and i.Item_ID = t.Item_ID group by i.Item_ID");
                Query query = session.createQuery("select sum(t.flow * a.inOrOut) from Advicenote a join a.transactions t join t.item i group by i.itemId");
                //Query query = session.createQuery("select sum(t.flow * a.inOrOut) from Advicenote a join Transactions t join Items i group by i.itemId");
                quantity.addAll(query.list());
                transaction.commit();
            } 
        catch (HibernateException e) {
            if (transaction != null) {
                transaction.rollback();
            }
        }
        finally {
             session.close();}
             return quantity;
        }

Вот исключение, которое у меня есть:

java.lang.IndexOutOfBoundsException: индекс 0 вне границ для длины 0 Hibernate: выберите items0_.ITEM_IDв ITEM_ID1_2_, items0_.NAME как NAME2_2_, items0_.NET_PRICE как NET_PRIC3_2_, items0_.VAT_RATE как VAT_RATE4_2_, items0_.CATEGORY_ID в CATEGORY5_2_ из APP.ITEMS items0_ Hibernate: выберите categories0_.CATEGORY_ID в CATEGORY1_1_0_, categories0_.NAME в NAME2_1_0_ от APP.CATEGORIES categories0_где category0_.CATEGORY_ID =?Hibernate: выберите items0_.CATEGORY_ID как CATEGORY5_2_0_, items0_.ITEM_ID как ITEM_ID1_2_0_, items0_.ITEM_ID как ITEM_ID1_2_1_, items0_.NAME как NAME2_2_1_, items0_.NET_PRICE как NET_PRIC3_2_1_, items0_.VAT_RATE как VAT_RATE4_2_1_, items0_.CATEGORY_ID в CATEGORY5_2_1_ от APP.ITEMS items0_ гдеitems0_.CATEGORY_ID =?Режим гибернации: выберите items0_.ITEM_ID в качестве ITEM_ID1_2_, items0_.NAME в качестве NAME2_2_, items0_.NET_PRICE в качестве NET_PRIC3_2_, items0_.VAT_RATE в качестве VAT_RATE4_2_, items0_.CATEGORY_ID в качестве CATEGORY5_2_0.NAME2_1_0_ из APP.CATEGORIES Categories0_ где Categories0_.CATEGORY_ID =?в java.base / jdk.internal.util.Preconditions.outOfBounds (Preconditions.java:64) в java.base / jdk.internal.util.Preconditions.outOfBoundsCheckIndex (Preconditions.java:70) в java.base / jdk.internal.util.Preconditions.checkIndex (Preconditions.java:248) в java.base / java.util.Objects.checkIndex (Objects.java:372) в java.base / java.util.ArrayList.get (ArrayList.java:458) на stock.view.StockView.searchButtonActionPerformed (StockView.java:479) на stock.view.StockView $ FormListener.actionPerformed (StockView.java:359) на java.desktop / javax.swing.AbstractButton.fireActionPerformed (AbstractButton.j).1967) в java.desktop / javax.swing.AbstractButton $ Handler.actionPerformed (AbstractButton.java:2308) в java.desktop / javax.swing.DefaultButtonModel.fireActionPerformed (DefaultButtonModel.java:405top / jax:40des) / jax: jax:40des / jax.desk.ax jax:40des) / jax: jax:40des / jax: jax:40des) / jax: jax:40des / jax: jax:40des / jax: jax:40des / jax: jax:40des) / jax: jax:40des / jax: jax:40des) / jax: jax:40des / jax: jax:40des) / jax: jax:40des / jax: jax:40des) / jax: jax:40des.top / jax.DefaultButtonModel.setPressed (DefaultButtonModel.java:262) в java.desktop / javax.swing.plaf.basic.BasicButtonListener.mouseReleased (BasicButtonListener.java:279) в java.desktop / java.awt.Component.processMouseEvent (Component.java:6632) в java.desktop / javax.swing.JComponent.processMouseEvent (JComponent.java:3342) в java.desktop / java.awt.Component.processEvent (Component.java:639).) в java.desktop / java.awt.Container.processEvent (Container.java:2263) в java.desktop / java.awt.Component.dispatchEventImpl (Component.java:5008) в java.desktop / java.awt.Container.dispatchEventImpl (Container.java:2321) в java.desktop / java.awt.Component.dispatchEvent (Component.java:4840) в java.desktop / java.awt.LightweightDispatcher.retargetMouseEvent (Container.java:4918top) в java./java.awt.LightweightDispatcher.processMouseEvent(Container.java:4547) в java.desktop / java.awt.LightweightDispatcher.dispatchEvent (Container.java:4488) в java.desktop / java.awt.Container.dislatchEj для контейнера: 2307) в java.desktop / java.awt.Window.dispatchEventImpl (Window.java:2772) в java.desktop / java.awt.Component.dispatchEvent (Component.java:4840) в java.desktop / java.awt.EventQueue.dispatchEventImpl (EventQueue.java:772)в java.desktop / java.awt.EventQueue $ 4.run (EventQueue.java:721) в java.desktop / java.awt.EventQueue $ 4.run (EventQueue.java:715) Hibernate: выберите items0_.CATEGORY_ID в качестве CATEGORY5_2_0_,.ITEM_ID, как ITEM_ID1_2_0_, items0_.ITEM_ID как ITEM_ID1_2_1_, items0_.NAME как NAME2_2_1_, items0_.NET_PRICE как NET_PRIC3_2_1_, items0_.VAT_RATE как VAT_RATE4_2_1_, items0_.CATEGORY_ID как CATEGORY5_2_1_ от APP.ITEMS items0_, где items0_.CATEGORY_ID =?в java.base / java.security.AccessController.doPrivileged (собственный метод) в java.base / java.security.ProtectionDomain $ JavaSecurityAccessImpl.doIntersectionPrivilege (ProtectionDomain.java:85) в java.base / java.securityImp.Doec.doIntersectionPrivilege (ProtectionDomain.java:95) в java.desktop / java.awt.EventQueue $ 5.run (EventQueue.java:745) в java.desktop / java.awt.EventQueue $ 5.run (EventQueue.java:743) в java..base / java.security.AccessController.doPrivileged (собственный метод) в java.base / java.security.ProtectionDomain $ JavaSecurityAccessImpl.doIntersectionPrivilege (ProtectionDomain.java:85) в java.desktop / java.awt.EquueEvent.Java: 742) в java.desktop / java.awt.EventDispatchThread.pumpOneEventForFilters (EventDispatchThread.java:203) в java.desktop / java.awt.EventDispatchThread.pumpEventsForFilter (EventDispatchTh4) java..EventDispatchThread.pumpEventsForHierarchy (EventDispatchThread.java:113) в java.desktop / java.awt.EventDispatchThread.pumpEvents (EventDispatchThread.java:109) в java.desktop / java.awt.EventDispatchThread.pumpEvents (EventDispatchThread.java:101) в java.desktop / java.awt.This.Datch90)

1 Ответ

0 голосов
/ 19 февраля 2019

Эта ошибка генерируется, когда ваш код пытается вывести первый элемент из пустого списка.

Вместо проверки на ноль: list.equals(null), проверьте на пустое: list.isEmpty().

null и empty - это два разных понятия.Нулевой список - это ссылка, которая ни на что не указывает.Пустой список - это ссылка на существующий объект, реализующий List, который содержит 0 элементов.

Кроме того, list.equals(null) никогда не будет работать, если list равен null, тогда код вызовет исключение NullPointerException.Методы экземпляра (например, equals) нуждаются в объекте для выполнения, вы не можете выполнить метод экземпляра для пустой ссылки.Поэтому, если вы хотите проверить на ноль, вам придется использовать list == null вместо этого.

Вот почему вы увидите код, который проверяет ненулевой, непустой список, например:

if (list != null && !list.isEmpty()) {

, потому что он проверяет как пустоту, так и пустоту.Это безопасно (избегая разыменования null), поскольку сначала проверяется наличие ненулевого значения, а также операции && для короткого замыкания операции, когда list имеет значение null.

Можно с уверенностью предположить, что вам не нужно проверять, что список возвращенHibernate это ноль.Если бы возвращенный список был нулевым, то ваш код потерпел бы неудачу с NPE.

...