iBATIS - การดีบัก
ง่ายต่อการดีบักโปรแกรมของคุณในขณะที่ทำงานกับ iBATIS iBATIS มีการรองรับการบันทึกในตัวและทำงานร่วมกับไลบรารีการบันทึกต่อไปนี้และค้นหาตามลำดับนี้
- Jakarta Commons Logging (JCL)
- Log4J
- การบันทึก JDK
คุณสามารถใช้ไลบรารีที่ระบุไว้ข้างต้นร่วมกับ iBATIS
การดีบักด้วย Log4J
สมมติว่าคุณกำลังจะใช้ Log4J สำหรับการบันทึก ก่อนดำเนินการต่อคุณต้องตรวจสอบประเด็นต่อไปนี้ -
- ไฟล์ Log4J JAR (log4j- {version} .jar) ควรอยู่ใน CLASSPATH
- คุณมี log4j.properties พร้อมใช้งานใน CLASSPATH
ต่อไปนี้คือไฟล์ log4j.properties โปรดทราบว่ามีการแสดงความคิดเห็นบางบรรทัด คุณสามารถยกเลิกการแสดงความคิดเห็นได้หากต้องการข้อมูลการแก้ไขข้อบกพร่องเพิ่มเติม
# Global logging configuration
log4j.rootLogger = ERROR, stdout
log4j.logger.com.ibatis = DEBUG
# shows SQL of prepared statements
#log4j.logger.java.sql.Connection = DEBUG
# shows parameters inserted into prepared statements
#log4j.logger.java.sql.PreparedStatement = DEBUG
# shows query results
#log4j.logger.java.sql.ResultSet = DEBUG
#log4j.logger.java.sql.Statement = DEBUG
# Console output
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %5p [%t] − %m%n
คุณสามารถค้นหาเอกสารที่สมบูรณ์สำหรับ Log4J จากเว็บไซต์ของอาปาเช่ - เอกสาร Log4J
iBATIS ตัวอย่างการดีบัก
คลาส Java ต่อไปนี้เป็นตัวอย่างง่ายๆที่เริ่มต้นแล้วใช้ไลบรารีการบันทึก Log4J สำหรับแอ็พพลิเคชัน Java เราจะใช้ไฟล์คุณสมบัติดังกล่าวข้างต้นซึ่งอยู่ใน CLASSPATH
import org.apache.log4j.Logger;
import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
import java.io.*;
import java.sql.SQLException;
import java.util.*;
public class IbatisUpdate{
static Logger log = Logger.getLogger(IbatisUpdate.class.getName());
public static void main(String[] args) throws IOException,SQLException{
Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);
/* This would insert one record in Employee table. */
log.info("Going to update record.....");
Employee rec = new Employee();
rec.setId(1);
rec.setFirstName( "Roma");
smc.update("Employee.update", rec );
log.info("Record updated Successfully ");
log.debug("Going to read records.....");
List <Employee> ems = (List<Employee>)
smc.queryForList("Employee.getAll", null);
Employee em = null;
for (Employee e : ems) {
System.out.print(" " + e.getId());
System.out.print(" " + e.getFirstName());
System.out.print(" " + e.getLastName());
System.out.print(" " + e.getSalary());
em = e;
System.out.println("");
}
log.debug("Records Read Successfully ");
}
}
รวบรวมและเรียกใช้
ก่อนอื่นตรวจสอบให้แน่ใจว่าคุณได้ตั้งค่า PATH และ CLASSPATH อย่างเหมาะสมก่อนดำเนินการรวบรวมและดำเนินการ
- สร้าง Employee.xml ตามที่แสดงด้านบน
- สร้าง Employee.java ตามที่แสดงด้านบนและรวบรวม
- สร้าง IbatisUpdate.java ตามที่แสดงด้านบนและคอมไพล์
- สร้าง log4j.properties ดังที่แสดงด้านบน
- เรียกใช้ไบนารี IbatisUpdate เพื่อรันโปรแกรม
คุณจะได้รับผลลัพธ์ดังต่อไปนี้ บันทึกจะได้รับการอัปเดตในตารางพนักงานและในภายหลังบันทึกเดียวกันจะถูกอ่านจากตารางพนักงาน
DEBUG [main] - Created connection 28405330.
DEBUG [main] - Returned connection 28405330 to pool.
DEBUG [main] - Checked out connection 28405330 from pool.
DEBUG [main] - Returned connection 28405330 to pool.
1 Roma Ali 5000
2 Zara Ali 5000
3 Zara Ali 5000
วิธีการดีบัก
ในตัวอย่างข้างต้นเราใช้เฉพาะ info() วิธีการอย่างไรก็ตามคุณสามารถใช้วิธีการใด ๆ ต่อไปนี้ตามความต้องการของคุณ -
public void trace(Object message);
public void debug(Object message);
public void info(Object message);
public void warn(Object message);
public void error(Object message);
public void fatal(Object message);