Google Cloud SQL + RETURN_GENERATED_KEYS

时间:2012-11-24 17:04:35

标签: jdbc google-apps-script google-cloud-sql

我的Google Cloud SQL数据库中有一个表格,其中包含一个自动递增列。

如何通过google-apps-script / JDBC执行INSERT查询并获取新增加的列的值?

例如,我的列名为ticket_id。我想INSERT并在结果集中返回新的ticket_id值。

换句话说,如果我有以下结构,我需要修改什么或如何修改,以便我可以执行rs = stmt.getGeneratedKeys();

之类的操作
var conn = Jdbc.getCloudSqlConnection("jdbc:google:rdbms:.......  
var stmt = conn.createStatement();

//build my INSERT sql statement  
var sql = "insert into ......

var rs = stmt.executeUpdate(sql);

我看到有一个名为RETURN_GENERATED_KEYS的成员的JDBC语句类,但到目前为止我还不够聪明,无法弄清楚如何正确地操作它并得到我需要的东西。 RETURN_GENERATED_KEYS是常数,它是属性,还是我如何使用它?

1 个答案:

答案 0 :(得分:4)

看起来有关于Apps Script JDBC服务的文档有点缺乏。我为此创建了一个内部任务项。值得庆幸的是,Apps Script JDBC API非常接近Java JDBC API。关键是使用stmt.getGeneratedKeys()调用来恢复结果集。

我使用MySQL文档中的动物示例构建了一个示例表,下面的示例可以很好地对照它并记录下一个递增的ID。

function foo() {
  var conn = Jdbc.getCloudSqlConnection("jdbc:google:rdbms://<instance>/<db>");
  var stmt = conn.createStatement();
  var sql = "INSERT INTO animals (name) VALUES ('dog')";
  var count = stmt.executeUpdate(sql,1)//pass in any int for auto inc IDs back
  var rs = stmt.getGeneratedKeys();
  //if you are only expecting one row back, no need for while loop
  // just do rs.next();
  while(rs.next()) { 
    Logger.log(rs.getString(1));
  }
  rs.close();
  stmt.close();
  conn.close();
}