相关疑难解决方法(0)

如何在JDBC中获取插入ID?

我希望INSERT在Java中使用JDBC中的数据库(在我的情况下是Microsoft SQL Server)中的记录.同时,我想获取插入ID.如何使用JDBC API实现此目的?

java sql insert-id jdbc

366
推荐指数
5
解决办法
26万
查看次数

带有Statement.RETURN_GENERATED_KEYS的PreparedStatement

返回的一些JDBC驱动程序的唯一方法Statement.RETURN_GENERATED_KEYS是执行以下操作:

long key = -1L;
Statement statement = connection.createStatement();
statement.executeUpdate(YOUR_SQL_HERE, Statement.RETURN_GENERATED_KEYS);
ResultSet rs = statement.getGeneratedKeys();
if (rs != null && rs.next()) {
    key = rs.getLong(1);
}
Run Code Online (Sandbox Code Playgroud)

有没有办法做同样的事情PreparedStatement


编辑

我问我是否可以这样做的原因PreparedStatement考虑以下情况:

private static final String SQL_CREATE = 
            "INSERT INTO
            USER(FIRST_NAME, MIDDLE_NAME, LAST_NAME, EMAIL_ADDRESS, DOB) 
            VALUES (?, ?, ?, ?, ?)";
Run Code Online (Sandbox Code Playgroud)

USER表中有一个PRIMARY KEY (USER_ID)BIGINT AUTOINCREMENT(因此你没有在SQL_CREATE字符串中看到它.

现在,我填充?使用PreparedStatement.setXXXX(index, value).我想回来ResultSet rs = PreparedStatement.getGeneratedKeys().我怎样才能做到这一点?

java jdbc

78
推荐指数
4
解决办法
12万
查看次数

JDBC和ADO.Net:API比较

JDBC中找到的对象和ADO.Net中找到的对象之间有什么类比?

我知道JDBC和ADO.Net中的对象模型并不完全相同,但我认为可以在它们中找到一些类比(以及值得说明的关键差异).

这对于那些知道一个API并希望学习另一个API的人来说非常有用,可能是一个起点,或者避免因为想要学习的API所做的假设而导致的误解.

例如:哪个ADO.Net对象提供与JDBC ResultSet相同的功能/行为?同样适用于PreparedStatemes,依此类推......

comparison ado.net jdbc

6
推荐指数
1
解决办法
2820
查看次数

标签 统计

jdbc ×3

java ×2

ado.net ×1

comparison ×1

insert-id ×1

sql ×1