使用Java中的hibernate从数据库填充组合框 [英] Filling combobox from database by using hibernate in Java

查看:165
本文介绍了使用Java中的hibernate从数据库填充组合框的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

Heyy;

我正在使用java中的hibernate开发一个基于swing的小应用程序。我想从数据库coloumn填充combobox。我可以这样做吗?

I am developing a small swing based application with hibernate in java. And I want fill combobox from database coloumn. How I can do that?

我不知道在哪里( initComponents buttonActionPerformd )我需要做。

And I don't know in where(under initComponents, buttonActionPerformd) I need to do.

使用jbutton保存I'am,代码如下:

For saving I'am using jbutton and it's code is here :

private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {

 int idd=Integer.parseInt(jTextField1.getText());

 String name=jTextField2.getText();

 String description=jTextField3.getText();

 Session session = null;

 SessionFactory sessionFactory = new Configuration().configure()
    .buildSessionFactory();

 session = sessionFactory.openSession();

 Transaction transaction = session.getTransaction();

   try {


       ContactGroup con = new ContactGroup();

       con.setId(idd);

       con.setGroupName(name);
       con.setGroupDescription(description);



       transaction.begin(); 
       session.save(con); 
       transaction.commit(); 


      } catch (Exception e) {
       e.printStackTrace();
      }

      finally{
       session.close(); 
      }    
}


推荐答案

I不使用Hibernate,但给定一个名为 Customer 的JPA实体和名为 CustomerJpaController 的JPA控制器,像这样。

I don't use Hibernate, but given a JPA entity named Customer and a JPA controller named CustomerJpaController, you can do something like this.

更新:代码更新以反映切换到EclipseLink(JPA 2.1)作为持久性库。

Update: Code updated to reflect a switch to EclipseLink (JPA 2.1) as the persistence library.

import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.List;
import javax.swing.JComboBox;
import javax.swing.JFrame;

/**
* @see http://stackoverflow.com/a/2531942/230513
*/
public class CustomerTest implements Runnable {

    public static void main(String[] args) {
        EventQueue.invokeLater(new CustomerTest());
    }

    @Override
    public void run() {
        CustomerJpaController con = new CustomerJpaController(
            Persistence.createEntityManagerFactory("CustomerPU"));
        List<Customer> list = con.findCustomerEntities();
        JComboBox combo = new JComboBox(list.toArray());
        combo.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                JComboBox cb = (JComboBox) e.getSource();
                Customer c = (Customer) cb.getSelectedItem();
                System.out.println(c.getId() + " " + c.getName());
            }
        });
        JFrame f = new JFrame();
        f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        f.add(combo);
        f.pack();
        f.setVisible(true);
    }
}

添加到 JComboBox get它们的显示名称来自对象的 toString()方法,因此 Customer 被修改为返回 getName ()用于显示:

Objects added to a JComboBox get their display name from the object's toString() method, so Customer was modified to return getName() for display purposes:

@Override
public String toString() {
    return getName();
}

您可以详细了解 JComboBox 在文章 如何使用组合框

You can learn more about JComboBox in the article How to Use Combo Boxes.

这篇关于使用Java中的hibernate从数据库填充组合框的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆