首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Google Cloud SQL + RETURN_GENERATED_KEYS

Google Cloud SQL + RETURN_GENERATED_KEYS
EN

Stack Overflow用户
提问于 2012-11-25 01:04:35
回答 1查看 839关注 0票数 1

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

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

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

换句话说,如果我有以下结构,我需要修改什么或如何修改,这样我才能执行类似rs = stmt.getGeneratedKeys();的操作

代码语言:javascript
复制
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是一个常量吗?它是一个属性吗?或者我如何使用它?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-11-25 03:24:43

似乎缺少Apps Script JDBC服务的文档。我已经为此创建了一个内部任务项。值得庆幸的是,Apps Script JDBC API非常紧跟Java JDBC API。关键是使用stmt.getGeneratedKeys()调用取回结果集。

我使用MySQL文档中的动物示例构建了一个示例表,下面的示例很好地解决了这个问题,并记录了下一个递增的ID。

代码语言:javascript
复制
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();
}
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13543433

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档