지금까지 우리는 사용자 등록, 즉 데이터베이스에 사용자를 추가하는 실질적인 문제를 다루지 않았습니다. 이제 이 요구 사항을 처리해 보겠습니다.
먼저 데이터베이스 액세스에 사용되는 기술을 결정해야 합니다. 여기에서 Hibernate, JPA 또는 JDBC를 선택할 수 있습니다. 나는 대다수의 애플리케이션이 데이터베이스 액세스 기술로 Hibernate를 사용한다고 생각합니다. 다른 사람들은 JPA를 선택할 수도 있지만 여기서는 JDBC를 선택합니다. 그 이유는 상대적으로 간단합니다. 근본적인 것들이 더 복잡해 보이지만 일단 익히면 내용이 적기 때문에 익히기가 상대적으로 쉽습니다. 이 O-R 매핑 모델은 많은 추상적인 개념과 세부 사항을 추가합니다. 우리는 일반적으로 이러한 아키텍처의 빙산의 일각만을 살펴봅니다. 빙산 아래에 있는 것들을 마스터하려는 경우 JDBC를 직접 마스터하는 것보다 훨씬 더 어렵습니다.
또한 우리의 테스트 중심 개발 아키텍처 덕분에 다른 아키텍처로 변환하려는 경우 테스트 케이스 보장 하에 기존 코드를 안전하게 수정할 수 있습니다.
먼저 DAO 모드를 사용하여 데이터베이스 액세스 인터페이스 클래스인 UserDao를 정의해 보겠습니다. 코드는 다음과 같습니다.
public interface UserDao { public long registerUser(Map<String, Object> userInfo); }
일반적으로 우리는 Mysql 데이터베이스를 사용하므로 정의합니다. Dao 클래스 UserMysqlDao의 구현 코드는 다음과 같습니다.
public class UserMysqlDao implements UserDao { @Override public long registerUser(Map<String, Object> userInfo) { // TODO Auto-generated method stub return 0; }
물론 우리는 사용자가 사용된 데이터베이스를 결정한 다음 해당 구현 클래스를 인스턴스화하는 것을 원하지 않습니다. 팩토리 모드를 채택하고 DaoFactory 클래스를 도입해야 합니다. 코드는 다음과 같습니다.
public class DaoFactory { public static UserDao getUserDao() { UserDao dao = null; switch (dbms) { case "mysql": dao = new UserMysqlDao(); break; } return dao; } public static String getDbms() { return dbms; } public static void setDbms(String dbms) { DaoFactory.dbms = dbms; } private static String dbms = "mysql"; }
위 코드에서 볼 수 있듯이 호출자는 구현을 얻기 위해 DaoFactory.getUserDao()만 호출하면 됩니다. 수업.
다음은 데이터베이스 연결 문제입니다. Jboss 등 애플리케이션 서버에서 실행할 때 데이터베이스 연결 풀을 사용하고, 유닛 테스트에서는 DriverManager를 사용하기를 원하므로 DataSource 캡슐화 클래스 JdbcDs를 정의해야 합니다. 위 상황을 처리하세요. 코드는 다음과 같습니다.
public class JdbcDs { public static Connection getConnection() throws SQLException { Connection conn = null; if (iDebug <= 0) { conn = appDs.getConnection(); } else { try { Class.forName("com.mysql.jdbc.Driver").newInstance(); } catch (InstantiationException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalAccessException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } Properties connectionProps = new Properties(); connectionProps.put("user", "root"); connectionProps.put("password", "yantao"); conn = DriverManager.getConnection( "jdbc:" + "mysql" + "://" + "localhost" + ":" + 3306 + "/XrcjDb", connectionProps); } return conn; } public static int iDebug = 1; public final static String APP_DS = "java:jboss/datasources/XcgDS"; private static DataSource appDs = null; static{ if (null == appDs) { Properties env = new Properties(); try { InitialContext ictx = new InitialContext(env); appDs = (DataSource)ictx.lookup(APP_DS); } catch (NamingException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } } } }
단위 테스트를 수행할 때 iDebug를 1로 설정하세요. 그렇지 않으면 데이터베이스 연결 풀이 사용됩니다.
모든 준비 작업이 완료되면 정식으로 데이터베이스 기능 개발을 진행할 수 있습니다.
위는 New Java Movement: Test Driven Development 3---사용자 등록 3의 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!