如何在追加textArea
时格式化文字?
try{
//establish connection to database
connection= DriverManager.getConnection(DATABASE_URL, "Hotel", "1234");
//create statement for querying database
statement = connection.createStatement();
// statement.executeUpdate("INSERT INTO TBLSTUDENT VALUES("+id+",'"+name+"','"+course+"',"+age+")");
//query database
resultSet = statement.executeQuery("SELECT * FROM Customer");
//process query results
ResultSetMetaData metaData = resultSet.getMetaData();
int numberOfColumns = metaData.getColumnCount();
textArea.append("Hotel Database: \n");
for(int i=1; i<=numberOfColumns; i++){
textArea.append(metaData.getColumnName(i));//"%-8s\t",
}
System.out.println();
while(resultSet.next()){
for(int i=1; i<=numberOfColumns;i++){
textArea.append(resultSet.getObject(i).toString());
}
System.out.println();
}
}catch(SQLException sqlException){
sqlException.printStackTrace();
}
现在输出的是它只会附加到一行。
它应该是
第1栏 - 第2栏 - 第3栏
data1-data 2-data 3
我尝试使用格式%-8s\t
,但它不适用于.append()
答案 0 :(得分:2)
一般来说,JTextArea
不是最佳选择,您应该使用JTable
有关详细信息,请参阅How to Use Tables
但是,请尝试使用更像textArea.append(String.format("%-8s\t", metaData.getColumnName(i)));
的内容
您还需要append
行之间的新行字符(\n
)