當前位置: 首頁>>代碼示例>>Java>>正文


Java PreparedStatement.getGeneratedKeys方法代碼示例

本文整理匯總了Java中java.sql.PreparedStatement.getGeneratedKeys方法的典型用法代碼示例。如果您正苦於以下問題:Java PreparedStatement.getGeneratedKeys方法的具體用法?Java PreparedStatement.getGeneratedKeys怎麽用?Java PreparedStatement.getGeneratedKeys使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.sql.PreparedStatement的用法示例。


在下文中一共展示了PreparedStatement.getGeneratedKeys方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testBug3873

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * Tests BUG#3873 - PreparedStatement.executeBatch() not returning all
 * generated keys (even though that's not JDBC compliant).
 * 
 * @throws Exception
 *             if the test fails
 */
public void testBug3873() throws Exception {
    PreparedStatement batchStmt = null;

    try {
        this.stmt.executeUpdate("DROP TABLE IF EXISTS testBug3873");
        this.stmt.executeUpdate("CREATE TABLE testBug3873 (keyField INT NOT NULL PRIMARY KEY AUTO_INCREMENT, dataField VARCHAR(32))");
        batchStmt = this.conn.prepareStatement("INSERT INTO testBug3873 (dataField) VALUES (?)", Statement.RETURN_GENERATED_KEYS);
        batchStmt.setString(1, "abc");
        batchStmt.addBatch();
        batchStmt.setString(1, "def");
        batchStmt.addBatch();
        batchStmt.setString(1, "ghi");
        batchStmt.addBatch();

        @SuppressWarnings("unused")
        int[] updateCounts = batchStmt.executeBatch();

        this.rs = batchStmt.getGeneratedKeys();

        while (this.rs.next()) {
            System.out.println(this.rs.getInt(1));
        }

        this.rs = batchStmt.getGeneratedKeys();
        assertTrue(this.rs.next());
        assertTrue(1 == this.rs.getInt(1));
        assertTrue(this.rs.next());
        assertTrue(2 == this.rs.getInt(1));
        assertTrue(this.rs.next());
        assertTrue(3 == this.rs.getInt(1));
        assertTrue(!this.rs.next());
    } finally {
        if (batchStmt != null) {
            batchStmt.close();
        }

        this.stmt.executeUpdate("DROP TABLE IF EXISTS testBug3873");
    }
}
 
開發者ID:JuanJoseFJ,項目名稱:ProyectoPacientes,代碼行數:47,代碼來源:StatementRegressionTest.java

示例2: create

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Override
public Event create(Event obj) throws DAOException {
    PreparedStatement preparedStatement = null;
    ResultSet autoGenerated = null;
    final String query = "INSERT INTO Events(name, summary, lieu, creator_id, dateEvent, max_participants) VALUES (?,?,?,?,?,?)";
    try {
        preparedStatement = initializePreparedStatement(query, true, obj.getName(), obj.getSummary(), obj.getLieu(), obj.getCreator().getId(), obj.getDate_event(), obj.getMax_participants());
        int status = preparedStatement.executeUpdate();
        autoGenerated = preparedStatement.getGeneratedKeys();
        if(autoGenerated.next()){
            obj.setId(autoGenerated.getLong(1));
        } else {
            throw new DAOException("Erreur lors de la cr�ation de l'�venement.");
        }
    } catch (SQLException e) {
        throw new DAOException(e);
    } finally {
        close(preparedStatement, autoGenerated);
    }
    return obj;
}
 
開發者ID:antonin-arquey,項目名稱:polyevent,代碼行數:22,代碼來源:EventDAO.java

示例3: testBug4510

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * Tests fix for BUG#4510 -- Statement.getGeneratedKeys() fails when key >
 * 32767
 * 
 * @throws Exception
 *             if the test fails
 */
public void testBug4510() throws Exception {
    try {
        this.stmt.executeUpdate("DROP TABLE IF EXISTS testBug4510");
        this.stmt.executeUpdate("CREATE TABLE testBug4510 (field1 INT NOT NULL PRIMARY KEY AUTO_INCREMENT, field2 VARCHAR(100))");
        this.stmt.executeUpdate("INSERT INTO testBug4510 (field1, field2) VALUES (32767, 'bar')");

        PreparedStatement p = this.conn.prepareStatement("insert into testBug4510 (field2) values (?)", Statement.RETURN_GENERATED_KEYS);

        p.setString(1, "blah");

        p.executeUpdate();

        ResultSet genKeysRs = p.getGeneratedKeys();
        genKeysRs.next();
        System.out.println("Id: " + genKeysRs.getInt(1));
        genKeysRs.close();
    } finally {
        this.stmt.executeUpdate("DROP TABLE IF EXISTS testBug4510");
    }
}
 
開發者ID:JuanJoseFJ,項目名稱:ProyectoPacientes,代碼行數:28,代碼來源:StatementRegressionTest.java

示例4: testBug71672PreparedStatement

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * Check the update count and returned keys for an INSERT query using a PreparedStatement object. If expectedUpdateCount < 0 then runs
 * PreparedStatement.execute() otherwise PreparedStatement.executeUpdate().
 */
public void testBug71672PreparedStatement(int testStep, Connection testConn, String query, int expectedUpdateCount, int[] expectedKeys)
        throws SQLException {
    PreparedStatement testPStmt = testConn.prepareStatement(query);

    if (expectedUpdateCount < 0) {
        assertFalse(testStep + ". PrepStmt.execute() result", testPStmt.execute(query, Statement.RETURN_GENERATED_KEYS));
    } else {
        assertEquals(testStep + ". PrepStmt.executeUpdate() result", expectedUpdateCount, testPStmt.executeUpdate(query, Statement.RETURN_GENERATED_KEYS));
    }

    ResultSet testRS = testPStmt.getGeneratedKeys();
    for (int k : expectedKeys) {
        assertTrue(testStep + ". Row expected in generated keys ResultSet", testRS.next());
        assertEquals(testStep + ". Wrong generated key", k, testRS.getInt(1));
    }
    assertFalse(testStep + ". No more rows expected in generated keys ResultSet", testRS.next());
    testRS.close();
    testPStmt.close();
}
 
開發者ID:bragex,項目名稱:the-vigilantes,代碼行數:24,代碼來源:StatementRegressionTest.java

示例5: getGeneratedKey

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * Get id after save method.
 */
private void getGeneratedKey(PreparedStatement pst, Table table) throws SQLException {
	String pKey = table.getPrimaryKey();
	if (get(pKey) == null || getConfig().dialect.isOracle()) {
		ResultSet rs = pst.getGeneratedKeys();
		if (rs.next()) {
			Class colType = table.getColumnType(pKey);
			if (colType == Integer.class || colType == int.class)
				set(pKey, rs.getInt(1));
			else if (colType == Long.class || colType == long.class)
				set(pKey, rs.getLong(1));
			else
				set(pKey, rs.getObject(1));		// It returns Long object for int colType
			rs.close();
		}
	}
}
 
開發者ID:WhatAKitty,項目名稱:spark-project,代碼行數:20,代碼來源:Model.java

示例6: testBustedGGKWithPSExecute

import java.sql.PreparedStatement; //導入方法依賴的package包/類
public void testBustedGGKWithPSExecute() throws Exception {
    createTable("sequence", "(sequence_name VARCHAR(32) NOT NULL PRIMARY KEY, next_val BIGINT NOT NULL)");

    // Populate with the initial value
    this.stmt.executeUpdate("INSERT INTO sequence VALUES ('test-sequence', 1234)");

    // Atomic operation to increment and return next value
    PreparedStatement pStmt = null;

    try {
        pStmt = this.conn.prepareStatement("UPDATE sequence SET next_val=LAST_INSERT_ID(next_val + ?) WHERE sequence_name = ?",
                Statement.RETURN_GENERATED_KEYS);

        pStmt.setInt(1, 4);
        pStmt.setString(2, "test-sequence");
        pStmt.execute();

        this.rs = pStmt.getGeneratedKeys();
        this.rs.next();
        assertEquals(1238, this.rs.getLong(1));
    } finally {
        if (pStmt != null) {
            pStmt.close();
        }
    }
}
 
開發者ID:Jugendhackt,項目名稱:OpenVertretung,代碼行數:27,代碼來源:StatementRegressionTest.java

示例7: createPet

import java.sql.PreparedStatement; //導入方法依賴的package包/類
public static int createPet(int itemid) {
    try {
        PreparedStatement ps = DatabaseConnection.getConnection().prepareStatement("INSERT INTO pets (name, level, closeness, fullness, summoned) VALUES (?, 1, 0, 100, 0)", Statement.RETURN_GENERATED_KEYS);
        ps.setString(1, MapleItemInformationProvider.getInstance().getName(itemid));
        ps.executeUpdate();
        ResultSet rs = ps.getGeneratedKeys();
        int ret = -1;
        if (rs.next()) {
            ret = rs.getInt(1);
        }
        rs.close();
        ps.close();
        return ret;
    } catch (SQLException e) {
        return -1;
    }
}
 
開發者ID:NovaStory,項目名稱:AeroStory,代碼行數:18,代碼來源:MaplePet.java

示例8: testInsertPreparedStmtWithId

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Test
public void testInsertPreparedStmtWithId() throws SQLException {
  PreparedStatement ps = con.prepareStatement("INSERT INTO Fortune (id , message) VALUES (?, ?)", Statement.RETURN_GENERATED_KEYS);
  ps.setInt(1, 9000);
  ps.setString(2, "Hello World");
  assertEquals(1, ps.executeUpdate());
  ResultSet re = ps.getGeneratedKeys();
  re.next();
  assertEquals(9000, re.getInt(1));
  assertEquals("Hello World", re.getString(2));
  ps.close();
}
 
開發者ID:vietj,項目名稱:reactive-pg-client,代碼行數:13,代碼來源:JdbcTest.java

示例9: createMovie

import java.sql.PreparedStatement; //導入方法依賴的package包/類
public int createMovie(String movie_name) throws SQLException {
	String query = "INSERT INTO `movie` (`name`) VALUES (?)";
	Connection connect = connectToMySQL();
	PreparedStatement statement = connect.prepareStatement(query, Statement.RETURN_GENERATED_KEYS);
	statement.setString(1, movie_name);
	statement.execute();
	ResultSet rs = statement.getGeneratedKeys();
	int id = -1;
	if (rs.next()) {
		id = rs.getInt(1);
	}
	connect.close();
	return id;
}
 
開發者ID:Bartac,項目名稱:avengers-db,代碼行數:15,代碼來源:MovieDAO.java

示例10: update

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Override
public int update(LoopModeSettings entity) throws SQLException {
	String sql;
	
	PreparedStatement ps = null;
	
	if (entity.getUid() == null) {
		sql = "INSERT INTO test_loopmode (test_uuid, max_delay, max_movement, max_tests, test_counter, client_uuid) VALUES (?::uuid,?,?,?,?,?::uuid)";
		ps = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
		ps.setObject(1, entity.getTestUuid());
		ps.setInt(2, entity.getMaxDelay());
		ps.setInt(3, entity.getMaxMovement());
		ps.setInt(4, entity.getMaxTests());
		ps.setInt(5, entity.getTestCounter());
		ps.setObject(6, entity.getClientUuid());
	}
	else {
		sql = "UPDATE test_loopmode SET test_uuid = ?::uuid, max_delay = ?, max_movement = ?, max_tests = ?, test_counter = ?, client_uuid = ?::uuid WHERE uid = ?";
		ps = conn.prepareStatement(sql);
		ps.setObject(1, entity.getTestUuid());
		ps.setInt(2, entity.getMaxDelay());
		ps.setInt(3, entity.getMaxMovement());
		ps.setInt(4, entity.getMaxTests());
		ps.setInt(5, entity.getTestCounter());
		ps.setObject(6, entity.getClientUuid());
		ps.setLong(7,  entity.getUid());
	}

	final int updateReturn = ps.executeUpdate();
	if (ps.getGeneratedKeys() != null) {
		final ResultSet keySet = ps.getGeneratedKeys();
		if (keySet.next()) {
			entity.setUid(keySet.getLong(1));
		}
	}
	
	return updateReturn;
}
 
開發者ID:rtr-nettest,項目名稱:open-rmbt,代碼行數:39,代碼來源:TestLoopModeDao.java

示例11: spawnWarning

import java.sql.PreparedStatement; //導入方法依賴的package包/類
public int spawnWarning(String targetID, String staffID, String reason) throws SQLException {
    PreparedStatement statement = connection.prepareStatement(CREATE_WARNING);
    statement.setString(1, targetID);
    statement.setString(2, staffID);
    statement.setString(3, reason);
    statement.execute();
    ResultSet rs = statement.getGeneratedKeys();
    int key = -1;
    if (rs.next()) {
        key = rs.getInt(1);
    }
    return key;
}
 
開發者ID:WheezyGold7931,項目名稱:happybot,代碼行數:14,代碼來源:WarningManager.java

示例12: save

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * 保存對象
 * 
 * @param o
 *            對象
 * @return 變更值
 */
public int save(Object o) {
    RunConfing config = RunConfing.getConfig();
    Connection con = config.getConnection();
    Class<?> classType = o.getClass();
    String sql = SqlUtils.getSqls(classType, SqlUtils.TYPE.INSERT);
    try {
        Object[] key = getTableKey(classType);
        Object idValue = JkBeanUtils.getPropertyValue(o, (String) key[0]);
        String dbType = config.getDbType();
        if (idValue == null) {
            if (dbType.contains(DATABSE_TYPE_ORACLE)) {
                String s = SqlUtils.getSequenceGeneratorVal(classType);
                if (s != null) {
                    // 查詢序列
                    String sequenceSql = MessageFormat.format(SEQUENCE_SQL, s);
                    idValue = query(sequenceSql, new NumberHandle<Long>());
                    if (idValue != null) {
                        JkBeanUtils.setProperty(o, (String) key[1], idValue);
                    }
                }
            }
        }
        PreparedStatement ps = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
        setPSEntityValue(ps, o);
        int n = ps.executeUpdate();
        if (idValue == null) {
            ResultSet rs = ps.getGeneratedKeys();// 返回主鍵
            ResultHandle<Long> handle = new NumberHandle<Long>();
            idValue = handle.handle(rs);
            JkBeanUtils.setProperty(o, (String) key[1], idValue);
        }
        ps.close();
        return n;
    } catch (Exception e) {
        throw new RuntimeException(e);
    } finally {
        doReleaseConnection(con);
    }
}
 
開發者ID:lftao,項目名稱:jkami,代碼行數:47,代碼來源:DataMapper.java

示例13: createToDb

import java.sql.PreparedStatement; //導入方法依賴的package包/類
public static final int createToDb(final int leaderId, final String name, final int guild1, final int guild2) {
    int ret = -1;
    if (name.length() > 12) {
        return ret;
    }
    Connection con = DatabaseConnection.getConnection();
    try {
        PreparedStatement ps = con.prepareStatement("SELECT id FROM alliances WHERE name = ?");
        ps.setString(1, name);
        ResultSet rs = ps.executeQuery();

        if (rs.first()) {// name taken
            rs.close();
            ps.close();
            return ret;
        }
        ps.close();
        rs.close();

        ps = con.prepareStatement("insert into alliances (name, guild1, guild2, leaderid) VALUES (?, ?, ?, ?)", Statement.RETURN_GENERATED_KEYS);
        ps.setString(1, name);
        ps.setInt(2, guild1);
        ps.setInt(3, guild2);
        ps.setInt(4, leaderId);
        ps.execute();
        rs = ps.getGeneratedKeys();
        if (rs.next()) {
            ret = rs.getInt(1);
        }
        rs.close();
        ps.close();
    } catch (SQLException SE) {
        System.err.println("SQL THROW");
    }
    return ret;
}
 
開發者ID:ergothvs,項目名稱:Lucid2.0,代碼行數:37,代碼來源:MapleGuildAlliance.java

示例14: create

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * Create new Object and return this new Object if success. Run only on
 * tables with auto_increment id column.
 *
 * @param obj
 * @return
 */
@Override
public BestScoreBean create(BestScoreBean obj)
{
    log.debug("Start method...");

    BestScoreBean objectToReturn = null;

    try
    {
        PreparedStatement prepared = DAOConnection.getInstance().prepareStatement(
                " INSERT INTO best_scores (player_name, game_date, game_category, game_level, game_score) "
                + " VALUES(?, ?, ?, ?, ?) ", Statement.RETURN_GENERATED_KEYS);

        prepared.setString(1, obj.getPlayerName());
        prepared.setObject(2, obj.getGameDate());
        prepared.setInt(3, obj.getGameCategory());
        prepared.setInt(4, obj.getGameLevel());
        prepared.setInt(5, obj.getGameScore());

        // execute query and get the affected rows number :
        int affectedRows = prepared.executeUpdate();
        if (affectedRows != 0)
        {
            // get the latest inserted id :
            ResultSet generatedKeys = prepared.getGeneratedKeys();
            if (generatedKeys.next())
            {
                log.debug("Inserted id : " + generatedKeys.getLong(1));
                objectToReturn = this.find(generatedKeys.getLong(1));
            }
        }

    } catch (SQLException e)
    {
        log.error("Error creating new best_score : " + e);
    }

    log.debug("End method.");

    return objectToReturn;
}
 
開發者ID:nfriaa,項目名稱:swing-memory-game,代碼行數:49,代碼來源:BestScoreRepository.java

示例15: createRing

import java.sql.PreparedStatement; //導入方法依賴的package包/類
public static int createRing(int itemid, final MapleCharacter partner1, final MapleCharacter partner2) {
    try {
        if (partner1 == null) {
            return -2;
        } else if (partner2 == null) {
            return -1;
        }
        int[] ringID = new int[2];
        Connection con = DatabaseConnection.getConnection();
        PreparedStatement ps = con.prepareStatement("INSERT INTO rings (itemid, partnerChrId, partnername) VALUES (?, ?, ?)", Statement.RETURN_GENERATED_KEYS);
        ps.setInt(1, itemid);
        ps.setInt(2, partner2.getId());
        ps.setString(3, partner2.getName());
        ps.executeUpdate();
        ResultSet rs = ps.getGeneratedKeys();
        rs.next();
        ringID[0] = rs.getInt(1); // ID.
        rs.close();
        ps.close();
        ps = con.prepareStatement("INSERT INTO rings (itemid, partnerRingId, partnerChrId, partnername) VALUES (?, ?, ?, ?)", Statement.RETURN_GENERATED_KEYS);
        ps.setInt(1, itemid);
        ps.setInt(2, ringID[0]);
        ps.setInt(3, partner1.getId());
        ps.setString(4, partner1.getName());
        ps.executeUpdate();
        rs = ps.getGeneratedKeys();
        rs.next();
        ringID[1] = rs.getInt(1);
        rs.close();
        ps.close();
        ps = con.prepareStatement("UPDATE rings SET partnerRingId = ? WHERE id = ?");
        ps.setInt(1, ringID[1]);
        ps.setInt(2, ringID[0]);
        ps.executeUpdate();
        ps.close();
        return ringID[0];
    } catch (SQLException ex) {
        ex.printStackTrace();
        return -1;
    }
}
 
開發者ID:NovaStory,項目名稱:AeroStory,代碼行數:42,代碼來源:MapleRing.java


注:本文中的java.sql.PreparedStatement.getGeneratedKeys方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。