java - 使用 Spring JDBC 向外表插入数据

标签 java spring spring-jdbc

我的 MySQL 数据库中有两个表:

CREATE TABLE table1 (
  id int auto_increment,
  name varchar(10),
  CONSTRAINT pk_id primary key(id)
) 

CREATE TABLE table2 (
  id_fk int,
  stuff varchar(30),
  CONSTRAINT fk_id FOREIGN KEY(id_fk) REFERENCES table1(id) 
) 

我想在这两个表中插入一条记录。基本上,我将 id、name 和东西作为数据。如何使用 Spring JDBC 将它们插入到两个表中?

我正在插入表格,如下所示:

    SimpleJdbcInsert insert1 = new SimpleJdbcInsert(this.getDataSource())
        .withTableName("table1")
        .usingColumns("name");

    Map<String, Object> parameters1 = new HashMap<String, Object>();
    parameters1.put("name", myObj1.getStuff());
    insert.execute(parameters1);

插入table2时,如何获取table1的id值?

    SimpleJdbcInsert insert2 = new SimpleJdbcInsert(this.getDataSource())
        .withTableName("table2")
        .usingColumns("stuff");

    Map<String, Object> parameters2 = new HashMap<String, Object>();
    parameters2.put("stuff", myObj2.getStuff());
    insert.execute(parameters2);

另外,我如何维持交易?

此外,如何获取给定名称的数据?

非常感谢任何帮助!

最佳答案

看这个简单的例子,类 Test 中的所有方法都是事务性的,阅读 Spring Framework 文档了解更多

@Transactional
public class Test {
    @Autowired
    DataSource ds;

    public void test1() throws Exception {
        Map<String, Object> params = new HashMap<String, Object>();
        params.put("c1", "test");
        SimpleJdbcInsert insert = new SimpleJdbcInsert(ds).withTableName("t1").usingColumns("c1")
                .usingGeneratedKeyColumns("id");
        long id = insert.executeAndReturnKey(params).longValue();

    params = new HashMap<String, Object>();
    params.put("stuff", "stuff");
    params.put("id_fk", id);
    SimpleJdbcInsert insert2 = new SimpleJdbcInsert(ds).withTableName(
            "table2").usingColumns("stuff", "id_fk");
    insert2.execute(params);

        NamedParameterJdbcTemplate tmpl = new NamedParameterJdbcTemplate(ds);
        params = new HashMap<String, Object>();
        params.put("id", id);
        String c1 = tmpl.queryForObject("select c1 from t1 where id = :id", params, String.class);
    }

上下文

<context:annotation-config />
<tx:annotation-driven />

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource" />
</bean>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url" value="jdbc:mysql://localhost:3306/test?user=root&amp;password=root" />
</bean>

<bean class="Test" />

关于java - 使用 Spring JDBC 向外表插入数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14167391/

相关文章:

java - 如何使用 Selenium 测试通过 Web 应用程序的注册页面输入的数据是否存储到数据库中?

java - 用 Batik 写入 unicode 字符不起作用

java - 我们可以使用普通的jdbc连接来进行Spring事务管理吗

Java Jdbctemplate 查询具有命名参数和行映射器的列表?

java - 如何聚焦到textView中新生成的文本的顶部?

spring 和 angular2 如何使用参数请求发布数据?

java - 重定向到 AbstractAuthenticationProcessingFilter 的结果

spring - Spring 常规网站和移动网站是否应该分开?

spring JDBC 无法连接到 postgres 数据库,但普通 JDBC 可以连接

java - @GetMapping 和 @GetMapping ("/{id}")始终返回 @GetMapping ("/{id}")