- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有数据关系
Person-Attends-Course
Person
-------
id: integer primary key
name: string
prename: string
age: integer
Course
-------
courseName: string primary key
hours: integer
Attends
--------
id: integer primary key references Person
courseName: string primary key references Course
我需要进行数据验证。在网上查了很久,决定通过扩展DefaultTableModel来实现。到目前为止,我创建了下面的代码,但我有一些问题:
类(class)人物
class Person{
private String name, prename,id;
private int age;
public Person(){}
public String getName(){return this.name;}
public String getPrename(){return this.prename;}
public int getAge(){return this.age;}
public String getId(){return this.id;}
public void setName(String name){
try{
if(name.equals(""))
JOptionPane.showMessageDialog(null, "Must insert name");
else
this.name = name;
}
catch(NullPointerException e){
this.name = "";
}
}
public void setPrename(String prename){
if(prename.equals(""))
JOptionPane.showMessageDialog(null, "Must insert prename");
else
this.prename = prename;
}
public void setAge(int age){
try{
if(age <0 || age >=100)
JOptionPane.showMessageDialog(null, "Must insert valid age");
else
this.age = age;
}
catch(Exception e){
this.age = 0;
}
}
public void setId(String id){
this.id = id;
}
}
Class PersonTM
class PersonTM extends DefaultTableModel{
private final List<Person> personlist;
private final String[] columnNames = {"id", "name", "prename","age"};
private final Class[] columnClass = {String.class, String.class, String.class, Integer.class};
public PersonTM(){this.personlist = new ArrayList<>();}
@Override
public Class<?> getColumnClass(int columnIndex){
return columnClass[columnIndex];
}
@Override
public String getColumnName(int column){
return columnNames[column];
}
public String[] getColumnNames(){return this.columnNames;}
@Override
public int getColumnCount() {
return columnNames.length;
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
Person row = personlist.get(rowIndex);
switch(columnIndex){
case 0:
return row.getId();
case 1:
return row.getName();
case 2:
return row.getPrename();
case 3:
return row.getAge();
default:
return null;
}
}
@Override
public void setValueAt(Object obj, int rowIndex, int columnIndex){
Person row = personlist.get(rowIndex);
switch(columnIndex){
case 0:
row.setId((String)obj);
break;
case 1:
row.setName((String)obj);
break;
case 2:
row.setPrename((String)obj);
break;
case 3:
row.setAge((Integer)obj);
break;
}
}
}
类类(class)
class Courses{
private String courseName;
private int hours;
public Courses(){}
public String getCourseName(){return this.courseName;}
public int getHours() {return this.hours;}
public void setCourseName(String courseName){
if(courseName.equals(""))
JOptionPane.showMessageDialog(null, "Must insert courseName");
else
this.courseName = courseName;
}
public void setHours(int hours){
if(hours <=0 || hours >=50)
JOptionPane.showMessageDialog(null, "Must insert valid hours");
else
this.hours = hours;
}
}
类类(class)TM
class CoursesTM extends DefaultTableModel{
private final List<Courses> courseslist;
private final String[] columnNames = {"course name","hours"};
private final Class[] columnClass = {String.class,Integer.class};
public CoursesTM(){this.courseslist = new ArrayList<>();}
@Override
public Class<?> getColumnClass(int columnIndex){
return columnClass[columnIndex];
}
@Override
public String getColumnName(int column){
return columnNames[column];
}
public String[] getColumnNames(){return this.columnNames;}
@Override
public int getColumnCount() {
return columnNames.length;
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
Courses row = courseslist.get(rowIndex);
switch(columnIndex){
case 0:
return row.getCourseName();
case 1:
return row.getHours();
default:
return null;
}
}
@Override
public void setValueAt(Object obj, int rowIndex, int columnIndex){
Courses row = courseslist.get(rowIndex);
switch(columnIndex){
case 0:
row.setCourseName((String)obj);
break;
case 1:
row.setHours((Integer)obj);
break;
}
}
}
上课
//here I am a little confused
class Attends{
private final Person p;
private final Course c;
public Attends(Person p,Course c){
this.p = p;
this.c = c;
}
public Person getPerson(){return this.p;}
public Course getCourse(){return this.c;}
}
类出勤TM
class AttendsTM extends DefaultTableModel{
private final PersonTM p;
private final CoursesTM c;
private final Map<Person,List<Course>> attendslist;
private String[] columnNames;
private final Class[] columnClass = {Person.class,Courses.class};
public AttendsTM(Map<Person,List<Courses>> attendslist){
this.attendslist = attendslist;
this.p = new PersonTM();
this.c = new CoursesTM();
}
public void setColumnNames(){
for (int i = 0; i < p.getColumnCount(); i++)
columnNames[i] = p.getColumnName(i);
for (int i = p.getColumnCount(); i < c.getColumnCount(); i++)
columnNames[i] = c.getColumnName(i);
}
}
类(class)查看器
class viewer extends JFrame{
private final JScrollPane scrollPane;
private final AttendsTM model;
private final JTable table;
public viewer(){
//collect data from db
Person p1 = new Person();
p1.setId("00001");
p1.setName("John");
p1.setPrename("Johnson");
p1.setAge(30);
Person p2 = new Person();
p2.setId("00002");
p2.setName("Jack");
p2.setPrename("Jackson");
p2.setAge(30);
Courses c1 = new Courses();
c1.setCourseName("History of art");
c1.setHours(25);
Courses c2 = new Courses();
c2.setCourseName("Music");
c2.setHours(15);
List<Courses> coursesList = new ArrayList<>();
coursesList.add(c1);
coursesList.add(c2);
Map<Person,List<Courses>> attendsMap = new LinkedHashMap<>();
attendsMap.put(p1, coursesList);
attendsMap.put(p2, coursesList);
model = new AttendsTM(attendsMap);
table = new JTable(model);
//add a blank row at the end of Jtable
model.addRow(new Object[model.getColumnCount()]);
table.putClientProperty("terminateEditOnFocusLost", Boolean.TRUE);
table.setCellSelectionEnabled(true);
table.setColumnSelectionAllowed(false);
table.setRowSelectionAllowed(true);
//resize columns and use horizontal scroll bar to view data
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
//disable column dragging
table.getTableHeader().setReorderingAllowed(false);
scrollPane = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED, JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
}
public void initializeUI(){
add(scrollPane);
setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
setSize(300,300);
setVisible(true);
}
}
类TableModelExample
public class TableModelExample {
public static void main(String[] af){
Runnable runnable = new Runnable(){
@Override
public void run() {
new viewer().initializeUI();
}
};
EventQueue.invokeLater(runnable);
}
}
所以我的问题是:
我应该如何显示包含人员和类(class)中所有列的 JTable?我应该通过 attends 执行此操作以及如何执行此操作?
我如何从 attendsTM 中的人员和类(class)收集数据?我这样做对吗?
任何建议都将非常受欢迎。预先感谢您。
最佳答案
我没有彻底阅读你的代码(相当多),但基本上你会执行以下操作:
如果您使用DefaultTableModel
,您很可能会使用构造函数DefaultTableModel(Object[][] data, Object[] columnNames)
。在这种情况下,您将加载人员和类(class)并构建需要显示的数据的二维数组。此外,您只需根据需要传递列名称,例如如果 2D 数组中每行的第一个元素包含人名,您将传递类似“name”的内容作为列名称数组中的第一个元素。
二维数组的布局取决于您想要如何显示数据。行的每个元素对应于表中的一个单元格。如果您希望每个类(class)和每个人都有一行,您只需生成多行,很可能会获得冗余/重复的单元格。当然,您可以只填充第一个单元格并清空所有多余元素,以便在需要时呈现空单元格,但在这种情况下,您不应允许排序。
如果您想将一个人参加的所有类(class)放入一个单元格中,您可以使用预先格式化的字符串(据我所知,默认渲染器可以显示 html 格式的文本)或提供您自己的渲染器。
使用重复单元格的简单方法示例:
Object[][] data = new Object[numrows][];
int curRow = 0;
for( Person p : persons ) { //assuming you have loaded the persons already
for( Course c : p.getCourses() ) { //loop over all courses a person has taken
Object[] row = new Object[numcols]; //create a new row array
//just an example of how to fill the elements
row[0] = p.getName(); //column 1 will contain the person's name
row[1] = c.getCourseName(); //column 2 will contain the course name
...
data[curRow] = row;
curRow++;
}
}
然后您只需将该数组传递给 DefaultTableModel
构造函数即可。结果可能如下所示:
+-------------+------------------------+
| Person name | Course |
+=============+========================+
| Vassilis De | Java Programming |
+-------------+------------------------+
| Thomas | Java Programming |
+-------------+------------------------+
| Thomas | How to answer in SO |
+-------------+------------------------+
| Thomas | Writing good examples |
+-------------+------------------------+
| Thomas | Being polite |
+-------------+------------------------+
请注意,这仅涵盖如何从已加载的数据构建表模型。如何加载数据取决于您的应用程序,但在示例中我假设您使用的是 JPA 或类似的东西。
更新:
如果我正确理解您的评论,有两个基本问题:
我会在 Controller 类中执行这两项操作,然后将数据传递到表模型,即您甚至可能不需要 AttendsTM
等。请查看 MVC 模式以获取更多信息如何创建和使用 Controller 。
保存输入的数据时, Controller 将从表模型中读取数据并以允许您向数据库添加新条目的方式进行解释。同样,如何完成此操作取决于您的应用程序。
使用自定义表模型(例如,作为 DefaultTableModel
的子类)可能有一个原因:如果您想向模型添加一些允许您识别实体但不应该识别实体的键显示在表格中,然后您可以覆盖 getValueAt()
等以隐藏某些列。
关于Java DefaultTableModel 从多个表收集数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27545658/
我有一台 MySQL 服务器和一台 PostgreSQL 服务器。 需要从多个表中复制或重新插入一组数据 MySQL 流式传输/同步到 PostgreSQL 表。 这种复制可以基于时间(Sync)或事
如果两个表的 id 彼此相等,我尝试从一个表中获取数据。这是我使用的代码: SELECT id_to , email_to , name_to , status_to
我有一个 Excel 工作表。顶行对应于列名称,而连续的行每行代表一个条目。 如何将此 Excel 工作表转换为 SQL 表? 我使用的是 SQL Server 2005。 最佳答案 这取决于您使用哪
我想合并两个 Django 模型并创建一个模型。让我们假设我有第一个表表 A,其中包含一些列和数据。 Table A -------------- col1 col2 col3 col
我有两个表:table1,table2,如下所示 table1: id name 1 tamil 2 english 3 maths 4 science table2: p
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 1 年前。 Improve th
下面两个语句有什么区别? newTable = orginalTable 或 newTable.data(originalTable) 我怀疑 .data() 方法具有性能优势,因为它在标准 AX 中
我有一个表,我没有在其中显式定义主键,它并不是真正需要的功能......但是一位同事建议我添加一个列作为唯一主键以随着数据库的增长提高性能...... 谁能解释一下这是如何提高性能的? 没有使用索引(
如何将表“产品”中的产品记录与其不同表“图像”中的图像相关联? 我正在对产品 ID 使用自动增量。 我觉得不可能进行关联,因为产品 ID 是自动递增的,因此在插入期间不可用! 如何插入新产品,获取产品
我有一个 sql 表,其中包含关键字和出现次数,如下所示(尽管出现次数并不重要): ____________ dog | 3 | ____________ rat | 7 | ____
是否可以使用目标表中的LAST_INSERT_ID更新源表? INSERT INTO `target` SELECT `a`, `b` FROM `source` 目标表有一个自动增量键id,我想将其
我正在重建一个搜索查询,因为它在“我看到的”中变得多余,我想知道什么 (albums_artists, artists) ( ) does in join? is it for boosting pe
以下是我使用 mysqldump 备份数据库的开关: /usr/bin/mysqldump -u **** --password=**** --single-transaction --databas
我试图获取 MySQL 表中的所有行并将它们放入 HTML 表中: Exam ID Status Assigned Examiner
如何查询名为 photos 的表中的所有记录,并知道当前用户使用单个查询将哪些结果照片添加为书签? 这是我的表格: -- -- Table structure for table `photos` -
我的网站都在 InnoDB 表上运行,目前为止运行良好。现在我想知道在我的网站上实时发生了什么,所以我将每个页面浏览量(页面、引荐来源网址、IP、主机名等)存储在 InnoDB 表中。每秒大约有 10
我在想我会为 mysql 准备两个表。一个用于存储登录信息,另一个用于存储送货地址。这是传统方式还是所有内容都存储在一张表中? 对于两个表...有没有办法自动将表 A 的列复制到表 B,以便我可以引用
我不是程序员,我从这个表格中阅读了很多关于如何解决我的问题的内容,但我的搜索效果不好 我有两张 table 表 1:成员 id*| name | surname -------------------
我知道如何在 ASP.NET 中显示真实表,例如 public ActionResult Index() { var s = db.StaffInfoDBSet.ToList(); r
我正在尝试运行以下查询: "insert into visits set source = 'http://google.com' and country = 'en' and ref = '1234
我是一名优秀的程序员,十分优秀!