-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGUITable.java
301 lines (245 loc) · 14 KB
/
GUITable.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
package databases;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class GUITable extends javax.swing.JFrame {
public GUITable() {
initComponents();
//Hides fields for adding new customer
jTextField1.setVisible(false);
jTextField2.setVisible(false);
AddCustomerButton.setVisible(false);
DeleteButton.setVisible(false);
}
/**
* This method is called from within the constructor to initialize the form.
* WARNING: Do NOT modify this code. The content of this method is always
* regenerated by the Form Editor.
*/
@SuppressWarnings("unchecked")
// <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
private void initComponents() {
jScrollPane2 = new javax.swing.JScrollPane();
jEditorPane1 = new javax.swing.JEditorPane();
jScrollPane1 = new javax.swing.JScrollPane();
jTable1 = new javax.swing.JTable();
AddCustomerButton = new javax.swing.JButton();
jTextField1 = new javax.swing.JTextField();
jTextField2 = new javax.swing.JTextField();
ViewButton = new javax.swing.JButton();
TableSelectComboBox = new javax.swing.JComboBox<>();
DeleteButton = new javax.swing.JButton();
jScrollPane2.setViewportView(jEditorPane1);
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
jScrollPane1.setViewportView(jTable1);
AddCustomerButton.setText("Add New Customer");
AddCustomerButton.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
AddCustomerButtonActionPerformed(evt);
}
});
ViewButton.setText("View Data");
ViewButton.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
ViewButtonActionPerformed(evt);
}
});
TableSelectComboBox.setModel(new javax.swing.DefaultComboBoxModel<>(new String[] { "Customers", "Products", "Order2ProductLink", "Orders" }));
TableSelectComboBox.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
TableSelectComboBoxActionPerformed(evt);
}
});
DeleteButton.setText("Delete Selected");
DeleteButton.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
DeleteButtonActionPerformed(evt);
}
});
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
getContentPane().setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGap(23, 23, 23)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
.addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 375, javax.swing.GroupLayout.PREFERRED_SIZE)
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
.addComponent(jTextField1, javax.swing.GroupLayout.PREFERRED_SIZE, 102, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(jTextField2)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(AddCustomerButton)))
.addGap(18, 18, 18)
.addComponent(DeleteButton, javax.swing.GroupLayout.DEFAULT_SIZE, 109, Short.MAX_VALUE))
.addGroup(layout.createSequentialGroup()
.addGap(73, 73, 73)
.addComponent(TableSelectComboBox, javax.swing.GroupLayout.PREFERRED_SIZE, 152, javax.swing.GroupLayout.PREFERRED_SIZE)
.addGap(18, 18, 18)
.addComponent(ViewButton)))
.addGap(18, 18, 18))
);
layout.setVerticalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGap(38, 38, 38)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(ViewButton)
.addComponent(TableSelectComboBox, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
.addGap(18, 18, 18)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
.addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 275, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(DeleteButton))
.addGap(18, 18, 18)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(AddCustomerButton)
.addComponent(jTextField1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(jTextField2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
.addContainerGap(55, Short.MAX_VALUE))
);
pack();
}// </editor-fold>//GEN-END:initComponents
private void AddCustomerButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_AddCustomerButtonActionPerformed
try {
Connection con = DriverManager.getConnection("jdbc:derby://localhost:1527/OrdersDatabase", "julie", "password");//Connects to my OrdersDatabase
//Change results set to be scrollable (otherwise you cant get individual elements)
Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
//Generate primary key
String SQL = "Select MAX(CustomerID) as maxID from TBL_Customers";
ResultSet rs = stmt.executeQuery(SQL);
//get value for max value in primary key column, add one to it. To be used for new primary key.
rs.next();
int id = rs.getInt("maxID") + 1;
//insert a record
SQL = "insert into TBL_Customers Values (" + id + ", '" + jTextField1.getText() + "', '" + jTextField2.getText() + "')";
stmt.executeUpdate(SQL);
rs.close();
con.close();
stmt.close();
//Refresh table data
UpdateTableData();
} catch (Exception e) {
System.out.println(e);
}
}//GEN-LAST:event_AddCustomerButtonActionPerformed
private void ViewButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_ViewButtonActionPerformed
UpdateTableData();//Refreshes table with data
if (TableSelectComboBox.getSelectedItem().equals("Customers")) {
jTextField1.setVisible(true);
jTextField2.setVisible(true);
AddCustomerButton.setVisible(true);
DeleteButton.setVisible(true);
} else {
jTextField1.setVisible(false);
jTextField2.setVisible(false);
AddCustomerButton.setVisible(false);
DeleteButton.setVisible(false);
}
}//GEN-LAST:event_ViewButtonActionPerformed
private void TableSelectComboBoxActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_TableSelectComboBoxActionPerformed
}//GEN-LAST:event_TableSelectComboBoxActionPerformed
private void DeleteButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_DeleteButtonActionPerformed
try {
int SelectedID = (int) jTable1.getValueAt(jTable1.getSelectedRow(), 0); //Gets the primary key for the record currently selected (primary key in column 0)
try {
Connection con = DriverManager.getConnection("jdbc:derby://localhost:1527/OrdersDatabase", "julie", "password");//Connects to my OrdersDatabase
//Change results set to be scrollable (otherwise you cant get individual elements)
Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
//insert a record
String SQL = "DELETE FROM TBL_CUSTOMERS WHERE CustomerID = " + SelectedID;
stmt.executeUpdate(SQL);
//Housekeeping
con.close();
stmt.close();
//Refresh table with new data
UpdateTableData();
} catch (Exception e) {
System.out.println(e);
}
} catch (Exception e) {
System.out.println("No record selected");
}
}//GEN-LAST:event_DeleteButtonActionPerformed
public void UpdateTableData() {
try {
Connection con = DriverManager.getConnection("jdbc:derby://localhost:1527/OrdersDatabase", "julie", "password");//Connects to my OrdersDatabase
Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE); //Change results set to be scrollable (otherwise you cant get individual elements)
String SQL = "SELECT * FROM TBL_" + TableSelectComboBox.getSelectedItem(); // selects all records for table currently selected in combo box
ResultSet rs = stmt.executeQuery(SQL);
String[] columns = new String[rs.getMetaData().getColumnCount()];//Gets how many columns are in the table
//Loops through metadata for selected table and adds column names to the columns array
for (int i = 0; i < columns.length; i++) {//Loops through metadata for selected table and adds column names to the columns array
columns[i] = rs.getMetaData().getColumnLabel(i + 1);
}
rs.last(); //Moves cursor to last element in result set, so we can get the number of rows in database
int totalrows = rs.getRow();
rs.first(); //moves cursor back to first row in database
Object[][] rows = new Object[totalrows][columns.length];//2D object array used for tableModel
for (int i = 0; i < totalrows; i++) { //Loops through all of the rows in the database
for (int j = 0; j < columns.length; j++) {//For each of the rows it loops through each of the the columns
rows[i][j] = rs.getObject(columns[j]); //gets the row name from the col array, gets the data in that column, and adds it to the rows 2d Array
}
rs.next();
}
//This sets up our new tableModel (This is copied by right clicking on Jtable and clicking customise code)
jTable1.setModel(new javax.swing.table.DefaultTableModel(
rows,
columns
));
//Housekeeping
rs.close();
con.close();
stmt.close();
//jTable1.setEnabled(false); //This makes the table so you can't click on it
} catch (Exception e) {
System.out.println(e);
}
}
public static void main(String args[]) {
/* Set the Nimbus look and feel */
//<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
/* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel.
* For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html
*/
try {
for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
if ("Nimbus".equals(info.getName())) {
javax.swing.UIManager.setLookAndFeel(info.getClassName());
break;
}
}
} catch (ClassNotFoundException ex) {
java.util.logging.Logger.getLogger(GUITable.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (InstantiationException ex) {
java.util.logging.Logger.getLogger(GUITable.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (IllegalAccessException ex) {
java.util.logging.Logger.getLogger(GUITable.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (javax.swing.UnsupportedLookAndFeelException ex) {
java.util.logging.Logger.getLogger(GUITable.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
}
//</editor-fold>
//</editor-fold>
/* Create and display the form */
java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
new GUITable().setVisible(true);
}
});
}
// Variables declaration - do not modify//GEN-BEGIN:variables
private javax.swing.JButton AddCustomerButton;
private javax.swing.JButton DeleteButton;
private javax.swing.JComboBox<String> TableSelectComboBox;
private javax.swing.JButton ViewButton;
private javax.swing.JEditorPane jEditorPane1;
private javax.swing.JScrollPane jScrollPane1;
private javax.swing.JScrollPane jScrollPane2;
private javax.swing.JTable jTable1;
private javax.swing.JTextField jTextField1;
private javax.swing.JTextField jTextField2;
// End of variables declaration//GEN-END:variables
}