У меня есть JTable в форме SERVER, он заполняется из базы данных MySQL, закодирован в конструкторе:
String sql = "SELECT * from fiekorari";
try{
pst=conn.prepareStatement(sql);
res=pst.executeQuery();
table.setModel(DbUtils.resultSetToTableModel(res));
pst.close();
res.close();
} catch (SQLException e1){
e1.printStackTrace();
}
Соединение установлено на главном с использованием TCP-соединения, СТОРОНА СЕРВЕРА:
public class Serveri extends JFrame {
private JPanel contentPane;
static ServerSocket ss;
static Socket s;
static DataInputStream din;
static DataOutputStream dout;
private JTextField txtMesazhi;
private static JTextArea txtA;
static Connection conn=null;
static ResultSet res= null;
static PreparedStatement pst = null;
private Object id;
/**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
Serveri frame = new Serveri();
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
});
SqlConn.getConnection();
String msgin="";
try
{
ss=new ServerSocket(1201);
s=ss.accept();
din=new DataInputStream(s.getInputStream());
dout=new DataOutputStream(s.getOutputStream()); //code continues with chat programming
Я хочу отправить данные с JTable на стороне сервера на JTable на стороне клиента, я не уверен, что это правильный подход, но я назначаю так, чтобы сервер считывал данные БД и отправлял их клиенту.
Ниже приведен код на стороне Клиента, который устанавливает соединение через TCP для чата, но теперь не нужно добавлять таблицу, которая считывает данные из таблицы серверов через сокеты:
public class Klienti extends JFrame {
private JPanel contentPane;
private JTextField txtMesazhi;
private static JTextArea txtShfaq1;
static Socket s;
static DataInputStream din;
static DataOutputStream dout;
private JButton btnNewButton;
public static String sql1;
private JTable table;
private JTextField txtEmri;
private JTextField txtMbiemri;
private JTextField txtOra;
static Connection conn=null;
static ResultSet res= null;
static PreparedStatement pst = null;
private Pattern pattern;
private Matcher matcher;
private String loc;
/**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
Klienti frame = new Klienti();
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
});
//SqlConn.getConnection();
try
{
s=new Socket("localhost",1201);
din=new DataInputStream(s.getInputStream());
dout=new DataOutputStream(s.getOutputStream());
//code in constructor Client side which sends text message to Server through sockets:
dout.writeUTF(msgout);
txtShfaq1.setText(txtShfaq1.getText().trim()+"\nJu:\t"+msgout);
txt.setText("");