java - 具有 SQL SELECT FROM INSERT 的 JdbcDaoSupport

标签 java sql jdbctemplate spring-jdbc

我正在尝试在 Spring JdbcDaoSupport 类中创建“从插入中选择”,但无法弄清楚如何从 select 语句中获取数据并返回它。

我的EventJdbcTemplate(我的DaoImpl):

@Service
public class EventJdbcTemplate extends JdbcDaoSupport implements EventDao {

private static final Logger LOGGER = Logger.getLogger(EventJdbcTemplate.class);

private static final String SQL_INSERT_EVENT = "SELECT EVENT_ID FROM FINAL TABLE " +
        "(INSERT INTO EBT10DBB.SB0401T0 (EVENT_NAME, HOST_NAME, USER_ID) " +
        "VALUES(?, ?, \'EMP0321\'))";

@Autowired
public EventJdbcTemplate(DataSource pDataSource) {
    super.setDataSource(pDataSource);
}


@Override
public Integer createEvent(EventBean pEventBean) { //(Integer id, String eventName)
    if (LOGGER.isTraceEnabled()) {
        LOGGER.trace("Entering create(Event event) of EventJDBCTemplate.");
    }
    // This SQL works, but is for an INSERT only. 
    /*this.getJdbcTemplate().query(SQL_INSERT_EVENT, new Object[]{
        pEventBean.getEventName(),
        pEventBean.getHostName()
    });*/

    final List eventList = this.getJdbcTemplate().query(SQL_INSERT_EVENT, new Object[]{
        pEventBean.getEventName(),
        pEventBean.getHostName()
        }, new EventRowMapper()
    );

    Event event = null;
    for (int i = 0; i < eventList.size(); i++) {
        event = (Event)eventList.get(i);
    }

    if (LOGGER.isTraceEnabled()) {
        LOGGER.trace("Exiting create(Event event) of EventJDBCTemplate.");
    }
    //return statement -- should return either the entire "pEventBean", or
    //just the unique key, "EVENT_ID".
            return event.getId();
}

EventRowMapper 类(不确定我是否需要这个来进行选择):

public class EventRowMapper implements RowMapper<Event> {

    @Override
    public Event mapRow(ResultSet rs, int rowNum) throws SQLException {
        final EventBuilder event = new EventImpl.EventBuilder();
        event.setId(rs.getInt("EVENT_ID"));
        event.setEventName("EVENT_NAME");
        event.setHostName("HOST_NAME");
        return event.build();
    }

}

所以我的目标是返回一个整数值,该值将是从 INSERT SQL 创建的唯一键 (EVENT_ID)。

最佳答案

您可以使用Spring提供的SimpleJdbcInsert来取回生成的 key ,请参阅Spring提供的以下文档部分

13.5.2 Retrieving auto-generated keys using SimpleJdbcInsert

这是Link

关于java - 具有 SQL SELECT FROM INSERT 的 JdbcDaoSupport,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17859356/

相关文章:

java - 字符串太长时被截断

java - GeoHash 函数没有返回正确的结果

mysql - 将-1附加到所有但删除null

mysql - 自动增量: how to auto_increment a combined-key (ERROR 1075)

spring - JDBCTemplate查找行是否存在

mysql - 如何仅执行 sql 脚本才能获得 Flyway Java 迁移?

java - 复选框数据未在其他 Activity 中传递

java - 如何通过Spark submit传递外部参数

mysql - 在此查询中使用 SQL UNION 的替代方法?

java - MySql 的行数和插入到表中的计数