SQL データベースに接続し、テーブルから特定の情報を取得するクラス (SQLRequests) があります。これらは、resultSet (rsUpdate および rsNew) に格納されます。以下はその方法です。正しいデータが引き出されることを確認するために、少しコードを追加しました。
public void ProcessSQLUpdate (Connection conn)
{
try
{
Statement stmt = conn.createStatement();
String sql = SQLDataAdaptor.SELECT_PROCESS_SQL_UPDATE;
ResultSet rsUpdate = stmt.executeQuery(sql);
while(rsUpdate.next ())
{
System.out.println("Applix Number: " + rsUpdate.getString(2) + " " + ("Change: " + rsUpdate.getString(1)));
logger.info("Applix Number: " + rsUpdate.getString(2) + " " + ("Change: " + rsUpdate.getString(1)));
}
if(stmt!=null)
stmt.close();
if(conn!=null)
conn.close();
}
この情報を別のクラス (EmailSender) の電子メール メソッドで送信したいのですが、この情報を追加する方法がわかりません。
public void sendEmail () throws PollingException
{
Properties props = new Properties();
PollingProperties properties = PollingProperties.getInstance();
props.put("mail.smtp.host", (properties.getProperty(PollingProperties.POL_EMAIL_SMTP)));
Date date = new Date();
try {
Session mailSession = Session.getDefaultInstance(props, null);
MimeMessage message = new MimeMessage(mailSession);
message.setSubject (properties.getProperty(PollingProperties.POL_EMAIL_SUBJECT));
message.setFrom(new InternetAddress(properties.getProperty(PollingProperties.POL_EMAIL_FROM)));
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(properties.getProperty(PollingProperties.POL_EMAIL_TO)));
message.setText("Applix Update for " + date +
"\n\n New Rows: " [rsUpdate info here]+
"\n\n Updated Rows:");
Transport.send(message);
それが理にかなっていることを願っています