package org.seasar.doma.internal.apt.dao;

/** */
@javax.annotation.Generated(value = { "Doma", "@VERSION@" }, date = "1970-01-01T09:00:00.000+0900")
public class SqlFileInsertEntityDaoImpl extends org.seasar.doma.internal.jdbc.dao.AbstractDao implements org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDao {

    static {
        org.seasar.doma.internal.Artifact.validateVersion("@VERSION@");
    }

    private static final java.lang.reflect.Method __method0 = org.seasar.doma.internal.jdbc.dao.AbstractDao.__getDeclaredMethod(org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDao.class, "insert", org.seasar.doma.internal.apt.entity.Emp.class);

    private static final java.lang.reflect.Method __method1 = org.seasar.doma.internal.jdbc.dao.AbstractDao.__getDeclaredMethod(org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDao.class, "insertMultipleEntities", org.seasar.doma.internal.apt.entity.Emp.class, org.seasar.doma.internal.apt.entity.ParentEntity.class);

    /** */
    public SqlFileInsertEntityDaoImpl() {
        super(new org.seasar.doma.internal.apt.dao.MyConfig());
    }

    /**
     * @param connection the connection
     */
    public SqlFileInsertEntityDaoImpl(java.sql.Connection connection) {
        super(new org.seasar.doma.internal.apt.dao.MyConfig(), connection);
    }

    /**
     * @param dataSource the dataSource
     */
    public SqlFileInsertEntityDaoImpl(javax.sql.DataSource dataSource) {
        super(new org.seasar.doma.internal.apt.dao.MyConfig(), dataSource);
    }

    /**
     * @param config the configuration
     */
    protected SqlFileInsertEntityDaoImpl(org.seasar.doma.jdbc.Config config) {
        super(config);
    }

    /**
     * @param config the configuration
     * @param connection the connection
     */
    protected SqlFileInsertEntityDaoImpl(org.seasar.doma.jdbc.Config config, java.sql.Connection connection) {
        super(config, connection);
    }

    /**
     * @param config the configuration
     * @param dataSource the dataSource
     */
    protected SqlFileInsertEntityDaoImpl(org.seasar.doma.jdbc.Config config, javax.sql.DataSource dataSource) {
        super(config, dataSource);
    }

    @Override
    public int insert(org.seasar.doma.internal.apt.entity.Emp emp) {
        entering("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl", "insert", emp);
        try {
            if (emp == null) {
                throw new org.seasar.doma.DomaNullPointerException("emp");
            }
            org.seasar.doma.internal.jdbc.query.SqlFileInsertQuery __query = new org.seasar.doma.internal.jdbc.query.SqlFileInsertQuery();
            __query.setMethod(__method0);
            __query.setConfig(config);
            __query.setSqlFilePath("META-INF/org/seasar/doma/internal/apt/dao/SqlFileInsertEntityDao/insert.sql");
            __query.addParameter("emp", org.seasar.doma.internal.apt.entity.Emp.class, emp);
            __query.setCallerClassName("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl");
            __query.setCallerMethodName("insert");
            __query.setQueryTimeout(-1);
            __query.setEntityAndEntityType("emp", emp, org.seasar.doma.internal.apt.entity._Emp.getSingletonInternal());
            __query.prepare();
            org.seasar.doma.internal.jdbc.command.InsertCommand __command = new org.seasar.doma.internal.jdbc.command.InsertCommand(__query);
            int __result = __command.execute();
            __query.complete();
            exiting("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl", "insert", __result);
            return __result;
        } catch (java.lang.RuntimeException __e) {
            throwing("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl", "insert", __e);
            throw __e;
        }
    }

    @Override
    public int insertMultipleEntities(org.seasar.doma.internal.apt.entity.Emp emp, org.seasar.doma.internal.apt.entity.ParentEntity parentEntity) {
        entering("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl", "insertMultipleEntities", emp, parentEntity);
        try {
            if (emp == null) {
                throw new org.seasar.doma.DomaNullPointerException("emp");
            }
            if (parentEntity == null) {
                throw new org.seasar.doma.DomaNullPointerException("parentEntity");
            }
            org.seasar.doma.internal.jdbc.query.SqlFileInsertQuery __query = new org.seasar.doma.internal.jdbc.query.SqlFileInsertQuery();
            __query.setMethod(__method1);
            __query.setConfig(config);
            __query.setSqlFilePath("META-INF/org/seasar/doma/internal/apt/dao/SqlFileInsertEntityDao/insertMultipleEntities.sql");
            __query.addParameter("emp", org.seasar.doma.internal.apt.entity.Emp.class, emp);
            __query.addParameter("parentEntity", org.seasar.doma.internal.apt.entity.ParentEntity.class, parentEntity);
            __query.setCallerClassName("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl");
            __query.setCallerMethodName("insertMultipleEntities");
            __query.setQueryTimeout(-1);
            __query.setEntityAndEntityType("emp", emp, org.seasar.doma.internal.apt.entity._Emp.getSingletonInternal());
            __query.prepare();
            org.seasar.doma.internal.jdbc.command.InsertCommand __command = new org.seasar.doma.internal.jdbc.command.InsertCommand(__query);
            int __result = __command.execute();
            __query.complete();
            exiting("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl", "insertMultipleEntities", __result);
            return __result;
        } catch (java.lang.RuntimeException __e) {
            throwing("org.seasar.doma.internal.apt.dao.SqlFileInsertEntityDaoImpl", "insertMultipleEntities", __e);
            throw __e;
        }
    }

}
