2

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);

それが理にかなっていることを願っています

4

1 に答える 1

1

探しているのはDTO: Data Transfer Objectです。

DTO は、2 つのレイヤー (または 2 つのメソッド...) 間の呼び出しの冗長性を減らすために使用される設計パターンです。必要なすべてのフィールドを含むオブジェクトを使用し、パラメーターとして渡して、複数の呼び出しを行ったり、宛先メソッドに巨大なコンストラクターを持たせたりしないようにします。 .

たとえば、人物の詳細を照会していて、それらを印刷するメソッドを呼び出したい場合は、次のようにします。

// Query the db and fill the resultset, then

String firstName = rs.getString("firstName");
String lastName  = rs.getString("lastName");
int    age       = rs.getString("age");

// close the connection, the resultset etc, and then

printPersonDetail(firstName);           // first call
printPersonDetail(lastName);            // second call
printPersonDetail(String.valueOf(age)); // another call

そしてどこか

private static void printPersonDetail(String something){
    System.out.println(something);
}

代わりに DTO を使用して、表現する必要があるエンティティ (この場合は人) を反映するオブジェクトを作成します。

public Class PersonDTO{

    String firstName;
    String lastName;  
    int    age;       

    /* Generate Getters and Setters with your IDE, 
       eg. in Eclipse: "ALT + SHIFT + S"  ->  "Generate Getters and Setters" */
    public String getFirstName() {
        return firstName;
    }
    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }
    public String getLastName() {
        return lastName;
    }
    public void setLastName(String lastName) {
        this.lastName = lastName;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}

そしてあなたのクラスから

// Query the db and fill the resultset, then

PersonDTO person = new PersonDTO(); 
person.setFirstName(rs.getString("firstName"));
person.setLastName(rs.getString("lastName"));
person.setAge(rs.getString("age"));

// close the connection, the resultset etc, and then

printPersonDetail(person); // only call: you are passing a DTO as parameter

そしてどこか

private static void printPersonDetail(PersonDTO person){
    System.out.println(person.getFirstName());
    System.out.println(person.getLastName());
    System.out.println(person.getAge());
}

これは些細な例ですが、アイデアを得るのに役立つことを願っています。DTO を使用してより大きなエンティティを設計し、その値を他のクラスと交換します。それらに値のみを入れ、ロジックをまったく入れず、単一の値を受け取る代わりにエンティティを受け取る方法を固めます。

注: 完了したら常に結果セットを閉じ、常にインデックスの代わりに名前を使用し、 Springの Resultsets や RowMappers などgetString()、おそらくこの千年紀のものを使用してください。

MSDN の DTO に関する詳細情報

于 2013-07-30T14:17:03.490 に答える