概要
SQLはすべてバインド変数(?)を使った準備された文に変換されて実行されますが、 このドキュメントでは、発行されたSQLがどのようなものかわかりやすくするためにバインド変数を実際の値に置き換えたログ用のSQLを示します。
SQLの自動生成による挿入
src/test/java/tutorial/InsertTest.javaのtestInsertメソッドを参照してください。 SQLの自動生成による挿入です。
使用するDaoのメソッド定義は次のとおりです。
@Insert int insert(Employee employee);
Daoのメソッドは次のように呼び出します。
Employee employee = new Employee(); employee.setName("test"); employee.setAge(50); employee.setSalary(new Salary(300)); employee.setJobType(JobType.PRESIDENT); dao.insert(employee);
SQLのログは次のように出力されます(改行しています)。
insert into Employee ( age, DEPARTMENT_ID, hiredate, id, insertTimestamp, JOB_TYPE, name, salary, updateTimestamp, VERSION ) values ( 50, null, null, 100, '2009-11-21 16:37:49.296', 'PRESIDENT', 'test', 300, null, 1 )
識別子のidプロパティは自動生成されるので設定する必要はありません。
楽観的排他制御用バージョンのversionプロパティは自動生成されるので設定する必要はありません。
insertTimestampプロパティはEmployeeListenerで自動設定されます。 src/test/java/tutorial/EmployeeListener.javaを参照してください。
SQLファイルによる挿入
src/test/java/tutorial/InsertTest.javaのtestInsertWithSqlFileメソッドを参照してください。 SQLファイルによる挿入です。
使用するDaoのメソッド定義は次のとおりです。 @InsertのsqlFile要素にtrueを指定します。
@Insert(sqlFile = true) int insertWithSqlFile(Employee employee);
Daoのメソッドに対応するSQLファイルのパスはMETA-INF/tutorial/dao/EmployeeDao/insertWithSqlFile.sqlです。 SQLファイルには次のように記述されています。
insert into Employee ( ID, NAME, AGE, DEPARTMENT_ID, HIREDATE, JOB_TYPE, SALARY, INSERTTIMESTAMP, UPDATETIMESTAMP, VERSION ) values ( /* employee.id */1, /* employee.name */'test', /* employee.age */10, /* employee.departmentId */1, /* employee.hiredate */'2010-01-01', /* employee.jobType */'SALESMAN', /* employee.salary */300, /* employee.insertTimestamp */'2010-01-01 12:34:56', /* employee.updateTimestamp */'2010-01-01 12:34:56', /* employee.version */1 )
Daoのメソッドは次のように呼び出します。
Employee employee = new Employee(); employee.setId(100); employee.setName("test"); employee.setAge(50); employee.setSalary(new Salary(300)); employee.setJobType(JobType.PRESIDENT); employee.setInsertTimestamp(new Timestamp(System.currentTimeMillis())); employee.setVersion(1); dao.insertWithSqlFile(employee);
SQLのログは次のように出力されます。
insert into Employee ( ID, NAME, AGE, DEPARTMENT_ID, HIREDATE, JOB_TYPE, SALARY, INSERTTIMESTAMP, UPDATETIMESTAMP, VERSION ) values ( 100, 'test', 50, null, null, 'PRESIDENT', 300, '2010-01-11 00:43:56.735', null, 1 )
SQLファイルによる挿入では、識別子の自動生成やバージョンの自動生成は行われません。 また、エンティティリスナーも呼び出されません。