¿Cómo puedo usar el filtro entre cuadros combinados en Java?

Tengo dos tablas en mi base de datos como tabla de semestre y tabla de curso. Hay semesterId, courseId, courseName y Sdepartment (nombre del departamento) en la tabla de semestre. La tabla del curso tiene courseId y courseName. Tengo dos cuadros combinados mi jframe. El primero es para seleccionar un departamento. El segundo es seleccionar curso. Quiero seleccionar el curso como departamento seleccionado. ¿Cómo puedo llamar al nombre del curso en el cuadro combinado cuando selecciono un departamento? Aquí mi código;

      public void coursename(){
     Session session = HibernateUtil.getSessionFactory().getCurrentSession();
     session.beginTransaction();
     //Query query= session.createQuery("select a.courseName,e.semesterId from Semester e inner join e.course as a"); 
     Query query= session.createQuery("FROM Senior.entity.Semester S  ");
     //for (Iterator it = query.iterate(); it.hasNext();) {
      //Object  row[] = (Object[])   it.next();
      //combocourse.addItem(new CourseItem((String)row[0], (int)row[1]));
      //}  
     List <Semester>re= query.list(); 
     if (re.size() > 0){ 
     Iterator iterate= re.iterator(); 
     final Semester resultAccount= (Semester)iterate.next(); 
     combocourse.removeAllItems();
     for(Semester inv:re){
     combocourse.addItem(new CourseItem(inv.getSemesterId(),inv.getSCourse()));
     }        
     }
      session.close();
   }


      public void depart(){
     Session session = HibernateUtil.getSessionFactory().getCurrentSession();
     session.beginTransaction();

     Query query= session.createQuery("FROM Senior.entity.Semester f "); 
     List <Semester>results= query.list(); 
     if (results.size() > 0){ 
     Iterator iterate= results.iterator(); 
     final Semester resultAccount= (Semester)iterate.next(); 
     combodepart.removeAllItems();
     for(Semester inv:results){
     combodepart.addItem(new DepartItem(inv.getSemesterId(),inv.getSDepartment()));

         //  combodepart.addActionListener(combocourse); 
               /*
            @Override
         public void actionPerformed(ActionEvent e) {
              JComboBox combocourse;
             combocourse = (JComboBox) e.getSource();
         //     Object selected = combocourse.getSelectedItem();
          Session session = HibernateUtil.getSessionFactory().getCurrentSession();
     session.beginTransaction();

     Query query= session.createQuery("FROM Senior.entity.Semester f "); 
     List <Semester>results= query.list(); 
     if (results.size() > 0){ 
     Iterator iterate= results.iterator(); 
     final Semester resultAccount= (Semester)iterate.next(); 
     combodepart.removeAllItems();
     for(Semester inv:results){
     combodepart.addItem(new DepartItem(inv.getSemesterId(),inv.getSDepartment()));
         }
     });

     */

     }        
     }
     session.close();
     }

Respuestas a la pregunta(1)

Su respuesta a la pregunta