1

メインクラスにロガーを次のように作成しました。

public static Logger logger = Logger.getLogger( MainClass.class.getName());

public static と宣言しました。

これは log4j.properties です:

ルートロガーオプション

log4j.rootLogger=INFO, file

ログ メッセージをログ ファイルに送信する

log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=D:\\loging.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=1
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

今、別のクラスでこのロガー オブジェクトにアクセスしたいと考えています。ロガーを直接与えようとすると、パブリック静的にしましたがエラーが発生します。

以下は、ロガーオブジェクトにアクセスしようとしているクラスです:

public class Db_Connector 
{
     MainClass.logger <------error
     //create ResultSet Class Object
     public ResultSet GetDataFromDB(){

        ResultSet resultset = null;
         try {  

                DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());   
                System.out.println("Connecting to the database...");   
                Connection connection = DriverManager.getConnection(
                        "jdbc:oracle:thin:@host:1521:Db", "User","pass01");
                Statement statement = connection.createStatement();   
                resultset = statement.executeQuery("select * from employee"); 

            } 
         catch (Exception e) {   
                System.out.println("The exception raised is:" + e);   
                            } 

         return resultset;
        }   
}
4

2 に答える 2