devstory

Obtenir des valeurs de colonne automatiquement incrémentées lors de l'insertion d'un enregistrement à l'aide de JDBC

  1. Problème
  2. Obtenir la valeur de la colonne ID de l'enregistrement inséré
  3. Obtenir les valeurs de quelques colonnes insérées

1. Problème

Dans certaines bases de données, la colonne ID d'un tableau peut être de type dont les valeurs augmentent automatiquement. Chaque fois que vous insérez un enregistrement (record) dans un tableau, la valeur de cette colonne est affectée par la base de données. Vous ne pouvez pas lui attribuer de valeur de manière proactive. Votre question dans ce cas est de savoir comment obtenir l'ID de l'enregistrement inséré.
En outre, certaines colonnes peuvent ne pas être facturées dans votre instruction Insert, auquel cas leurs valeurs sont affectées par défaut par une base de données. Vous souhaitez obtenir ces valeurs sans créer d'autre instruction de requête.
PostGres
Dans PostGres, la colonne du type Serial aura des valeurs augmentant automatiquement par base de données.
** Employees (PostGres) **
CREATE TABLE Employees
(
    ID serial NOT NULL,
    Full_Name character varying(50) NOT NULL,
    Gender character varying(1) default 'M' NOT NULL,
    Hire_Date date NOT NULL,
    PRIMARY KEY (ID)
);
MySQL
Dans MySQL, pour qu'une colonne ait automatiquement une valeur croissante, il faut lui assigner l'attribut (attribute) "Auto_Increase".
** Employees (MySQL) **
CREATE TABLE Employees
(
    ID Int Auto_Increase NOT NULL,
    Full_Name Varchar(50) NOT NULL,
    Gender Varchar(1) default 'M' NOT NULL,
    Hire_Date date NOT NULL,
    PRIMARY KEY (ID)
);

2. Obtenir la valeur de la colonne ID de l'enregistrement inséré

Lorsque vous utilisez JDBC pour Insert un enregistrement à la base de données, la colonne ID ne peut être pas impliquée dans la commande Insert. La location de colonne ID est définie par la conception de tel tableau. La première colonne a l'index 1 et la deuxième colonne a l'index 2,...
GeneratedIDValueExample.java
package org.o7planning.tutorial.jdbc.others;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import org.o7planning.tutorial.jdbc.ConnectionUtils;

public class GeneratedIDValueExample {

	public static void main(String[] args) throws ClassNotFoundException, SQLException {
		// Obtenez une connexion à la base de données.
		Connection conn = ConnectionUtils.getMyConnection();

		// Employees (id, full_name, gender, hire_date)
		// ID: Auto Increase
		String sql = "Insert into Employees " //
				+ " (full_name, gender, hire_date) " //
				+ " values " //
				+ " (?, ?, ?)";

		// Créez un objet PreparedStatement.
		PreparedStatement pstm = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);

		pstm.setString(1, "Tran");
		pstm.setString(2, "M");
		pstm.setDate(3, new java.sql.Date(System.currentTimeMillis()));

		// Execute!
		pstm.execute();

		ResultSet rs = pstm.getGeneratedKeys();

		int idValue = 0;
		if (rs.next()) {
			// La valeur de ID
			idValue = rs.getInt(1);
		}

		System.out.println("ID value: " + idValue);

	}
}
L'index de la colonne ID de tableau n'est probablement pas 1 (selon la conception de tableau). Dans ce cas, vous devez accéder à sa valeur par son nom.
GeneratedIDValueExample2.java
package org.o7planning.tutorial.jdbc.others;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import org.o7planning.tutorial.jdbc.ConnectionUtils;

public class GeneratedIDValueExample2 {

	public static void main(String[] args) throws ClassNotFoundException, SQLException {

		Connection conn = ConnectionUtils.getMyConnection();

		// Employees (id, full_name, gender, hire_date)
		// ID: Auto Increase
		String sql = "Insert into Employees " //
				+ " (full_name, gender, hire_date) " //
				+ " values " //
				+ " (?, ?, ?)";

		// Create a PreparedStatement object.
		PreparedStatement pstm = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);

		pstm.setString(1, "Tran");
		pstm.setString(2, "M");
		pstm.setDate(3, new java.sql.Date(System.currentTimeMillis()));

		// Execute!
		pstm.execute();

		ResultSet rs = pstm.getGeneratedKeys();

		int idValue = 0;
		if (rs.next()) {
			// Value of ID.
			// Note, for some DB, column names are case sensitive.
			// (eg Postgres, column names are always lowercase).
			idValue = rs.getInt("id");
		}

		System.out.println("ID value: " + idValue);

	}
}

3. Obtenir les valeurs de quelques colonnes insérées

Certaines colonnes peuvent ne pas participer à votre instruction Insert. Leurs valeurs sont attribuées par la base de données. Vous pouvez obtenir leurs valeurs sans créer d'instruction de requête.
GetGeneratedValueExample2.java
package org.o7planning.tutorial.jdbc.others;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.o7planning.tutorial.jdbc.ConnectionUtils;

public class GetGeneratedValueExample2 {

	public static void main(String[] args) throws ClassNotFoundException, SQLException {

		Connection conn = ConnectionUtils.getMyConnection();

		// Employees (id, full_name, gender, hire_date)
		// ID: Auto Increase
		// gender: Default
		String sql = "Insert into Employees " //
				+ " (Full_Name,  Hire_Date) " //
				+ " values " //
				+ " (?,  ?)";

		// Créez un objet PreparedStatement.
		// Et inscrivez les paramètres de sortie par le nom ("id", "gender", "hire_date")
		PreparedStatement pstm = conn.prepareStatement(sql, new String[] { "id", "gender", "hire_date" });

		pstm.setString(1, "Tran");
		pstm.setDate(2, new java.sql.Date(System.currentTimeMillis()));

		// Execute!
		pstm.execute();

		ResultSet rs = pstm.getGeneratedKeys();

		int idValue = 0;
		String gender = null;
		java.sql.Date hireDate = null;
		if (rs.next()) {
			idValue = rs.getInt("ID");
			gender = rs.getString("Gender");
			hireDate = rs.getDate("Hire_Date");
		}

		System.out.println("ID value: " + idValue + " Gender: " + gender + ", Hidedate: " + hireDate);

	}
}

Java Basic

Show More