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


Java PreparedStatement.executeBatch方法代碼示例

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


在下文中一共展示了PreparedStatement.executeBatch方法的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: insert

import java.sql.PreparedStatement; //導入方法依賴的package包/類
private long insert(Connection con, List<Map<String, String>> list)
        throws SQLException {
    PreparedStatement ps;

    String sql = "insert into travelrecord (id,user_id,traveldate,fee,days) values(?,?,?,?,?)";
    ps = con.prepareStatement(sql);
    for (Map<String, String> map : list) {
        ps.setLong(1, Long.parseLong(map.get("id")));
        ps.setString(2, (String) map.get("user_id"));
        ps.setString(3, (String) map.get("traveldate"));
        ps.setString(4, (String) map.get("fee"));
        ps.setString(5, (String) map.get("days"));
        ps.addBatch();
    }
    ps.executeBatch();
    con.commit();
    ps.clearBatch();
    ps.close();
    return list.size();
}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:21,代碼來源:TravelRecordInsertJob.java

示例3: addReport

import java.sql.PreparedStatement; //導入方法依賴的package包/類
public void addReport(int reporterid, int victimid, int reason, String description, String chatlog) {
  Connection con = DatabaseConnection.getConnection();
        try {
            PreparedStatement ps = con.prepareStatement("INSERT INTO reports (`reporterid`, `victimid`, `reason`, `description`, `chatlog`) VALUES (?, ?, ?, ?, ?)");
            ps.setInt(1, reporterid);
            ps.setInt(2, victimid);
            ps.setInt(3, reason);
            ps.setString(4, description);
            ps.setString(5, chatlog);
            ps.addBatch();
            ps.executeBatch();
            ps.close();
        } catch (SQLException ex) {
            ex.printStackTrace();
        }
}
 
開發者ID:NovaStory,項目名稱:AeroStory,代碼行數:17,代碼來源:ReportHandler.java

示例4: lowerRequestedFlag

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Override
public void lowerRequestedFlag(Connection txn, ContactId c,
		Collection<MessageId> requested) throws DbException {
	PreparedStatement ps = null;
	try {
		String sql = "UPDATE statuses SET requested = FALSE"
				+ " WHERE messageId = ? AND contactId = ?";
		ps = txn.prepareStatement(sql);
		ps.setInt(2, c.getInt());
		for (MessageId m : requested) {
			ps.setBytes(1, m.getBytes());
			ps.addBatch();
		}
		int[] batchAffected = ps.executeBatch();
		if (batchAffected.length != requested.size())
			throw new DbStateException();
		for (int rows: batchAffected) {
			if (rows < 0) throw new DbStateException();
			if (rows > 1) throw new DbStateException();
		}
		ps.close();
	} catch (SQLException e) {
		tryToClose(ps);
		throw new DbException(e);
	}
}
 
開發者ID:rafjordao,項目名稱:Nird2,代碼行數:27,代碼來源:JdbcDatabase.java

示例5: updateBatch

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * 該方法用於批處理,當需要一次執行多條相同SQL語句時使用該方法時效率較高
 *
 * @param sql 需要執行的SQL語句
 * @param arg 傳入SQL語句所需要的占位符參數,下標均從0開始,每個一維下標對應於SQL語句的一組占位符參數
 */
public static void updateBatch(String sql, Object[][] arg) {
    Connection connection = JDBCUtils.getConnection();
    PreparedStatement ps = null;
    try {
        ps = connection.prepareStatement(sql);
        for (int i = 0; i < arg.length; i++) {
            for (int j = 0; j < arg[i].length; j++) {
                ps.setObject(j + 1, arg[i][j]);
            }
            ps.addBatch();
        }
        ps.executeBatch();
    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

    JDBCUtils.release(ps, connection);
}
 
開發者ID:FlyingHe,項目名稱:UtilsMaven,代碼行數:26,代碼來源:DBUtils.java

示例6: updateBatch

import java.sql.PreparedStatement; //導入方法依賴的package包/類
private void updateBatch(byte[][] ids, String[] names) throws SQLException {
	assertEquals(ids.length, names.length);
	String sql = "UPDATE foo SET name = ? WHERE uniqueId = ?";
	try {
		PreparedStatement ps = connection.prepareStatement(sql);
		for (int i = 0; i < ids.length; i++) {
			if (ids[i] == null) ps.setNull(2, BINARY);
			else ps.setBytes(2, ids[i]);
			ps.setString(1, names[i]);
			ps.addBatch();
		}
		int[] batchAffected = ps.executeBatch();
		assertEquals(ids.length, batchAffected.length);
		for (int affected : batchAffected) assertEquals(1, affected);
		ps.close();
	} catch (SQLException e) {
		connection.close();
		throw e;
	}
}
 
開發者ID:rafjordao,項目名稱:Nird2,代碼行數:21,代碼來源:BasicH2Test.java

示例7: detachFromQueue

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Override
public void detachFromQueue(Collection<DbOperation> dbOperations) throws BrokerException {
    Connection connection = null;
    PreparedStatement statement = null;
    try {
        connection = getConnection();
        statement = connection.prepareStatement(RDBMSConstants.PS_DELETE_FROM_QUEUE);
        for (DbOperation dbOperation : dbOperations) {
            statement.setLong(1, dbOperation.getMessageId());
            statement.setString(2, dbOperation.getQueueName());
            statement.addBatch();
        }

        statement.executeBatch();
        connection.commit();
    } catch (SQLException e) {
        throw new BrokerException("Error detaching messages from queues.", e);
    } finally {
        close(connection, statement);
    }
}
 
開發者ID:wso2,項目名稱:message-broker,代碼行數:22,代碼來源:MessageDaoImpl.java

示例8: removeOfferedMessages

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Override
public void removeOfferedMessages(Connection txn, ContactId c,
		Collection<MessageId> requested) throws DbException {
	PreparedStatement ps = null;
	try {
		String sql = "DELETE FROM offers"
				+ " WHERE contactId = ? AND messageId = ?";
		ps = txn.prepareStatement(sql);
		ps.setInt(1, c.getInt());
		for (MessageId m : requested) {
			ps.setBytes(2, m.getBytes());
			ps.addBatch();
		}
		int[] batchAffected = ps.executeBatch();
		if (batchAffected.length != requested.size())
			throw new DbStateException();
		for (int rows : batchAffected)
			if (rows != 1) throw new DbStateException();
		ps.close();
	} catch (SQLException e) {
		tryToClose(ps);
		throw new DbException(e);
	}
}
 
開發者ID:rafjordao,項目名稱:Nird2,代碼行數:25,代碼來源:JdbcDatabase.java

示例9: createPreparedStatement

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Override
public PreparedStatement createPreparedStatement(Connection con) throws SQLException {
    PreparedStatement ps = con.prepareStatement(this.sql, autoGeneratedKey);

    if (null != args){
        SQLTools.fillStatement(ps, args);
        if (isBatch  && (rowCont = args.length) > 0){
            int success = ps.executeBatch().length ;
            if (success > 0 && success < rowCont){
                logger.warn("The number of successful {}, now successful {} ", rowCont, success );
            }
            rowCont = success;
        }else {
            rowCont = ps.executeUpdate();
        }
        if (rowCont < 1) {
            throw new SQLException("sql:{} On failure.", ps.toString());
        }
    }

    return ps;
}
 
開發者ID:egzosn,項目名稱:spring-jdbc-orm,代碼行數:23,代碼來源:PreparedStatementCreator.java

示例10: testBug30550

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * Tests fix for BUG#30550 - executeBatch() on an empty batch when there are
 * no elements in the batch causes a divide-by-zero error when rewriting is
 * enabled.
 * 
 * @throws Exception
 *             if the test fails
 */
public void testBug30550() throws Exception {
    createTable("testBug30550", "(field1 int)");

    Connection rewriteConn = getConnectionWithProps("rewriteBatchedStatements=true");
    PreparedStatement batchPStmt = null;
    Statement batchStmt = null;

    try {
        batchStmt = rewriteConn.createStatement();
        assertEquals(0, batchStmt.executeBatch().length);

        batchStmt.addBatch("INSERT INTO testBug30550 VALUES (1)");
        int[] counts = batchStmt.executeBatch();
        assertEquals(1, counts.length);
        assertEquals(1, counts[0]);
        assertEquals(0, batchStmt.executeBatch().length);

        batchPStmt = rewriteConn.prepareStatement("INSERT INTO testBug30550 VALUES (?)");
        batchPStmt.setInt(1, 1);
        assertEquals(0, batchPStmt.executeBatch().length);
        batchPStmt.addBatch();
        counts = batchPStmt.executeBatch();
        assertEquals(1, counts.length);
        assertEquals(1, counts[0]);
        assertEquals(0, batchPStmt.executeBatch().length);
    } finally {
        if (batchPStmt != null) {
            batchPStmt.close();
        }

        if (batchStmt != null) {
            batchStmt.close();
        }
        if (rewriteConn != null) {
            rewriteConn.close();
        }
    }
}
 
開發者ID:rafallis,項目名稱:BibliotecaPS,代碼行數:47,代碼來源:StatementRegressionTest.java

示例11: testBug68562ExecuteBatch

import java.sql.PreparedStatement; //導入方法依賴的package包/類
private int[] testBug68562ExecuteBatch(int batchSize, boolean useAffectedRows, boolean rewriteBatchedStatements, boolean realUpdate)
        throws ClassNotFoundException, SQLException {

    String tableName = "testBug68562";

    Properties properties = new Properties();
    if (useAffectedRows) {
        properties.put("useAffectedRows", "true");
        tableName += "_affected";
    } else {
        tableName += "_found";
    }
    if (rewriteBatchedStatements) {
        properties.put("rewriteBatchedStatements", "true");
    }
    Connection connection = getConnectionWithProps(properties);

    PreparedStatement statement = connection
            .prepareStatement("INSERT INTO " + tableName + "(id, name, version) VALUES(?,?,?) ON DUPLICATE KEY UPDATE version = "
                    + (realUpdate ? "CONCAT(VALUES(version),'updated'), name = CONCAT(VALUES(name),'updated')" : "VALUES(version), name = VALUES(name)"));
    for (int i = 0; i < batchSize; i++) {
        statement.setInt(1, i);
        statement.setString(2, "name" + i);
        statement.setString(3, "version" + i);
        statement.addBatch();
    }

    int[] affectedRows = statement.executeBatch();

    statement.close();
    connection.close();

    return affectedRows;

}
 
開發者ID:JuanJoseFJ,項目名稱:ProyectoPacientes,代碼行數:36,代碼來源:StatementRegressionTest.java

示例12: insertNode

import java.sql.PreparedStatement; //導入方法依賴的package包/類
protected void insertNode ( final ConnectionContext connectionContext, final DataNode node, final String data ) throws SQLException
{
    if ( data == null )
    {
        return;
    }

    final PreparedStatement stmt = connectionContext.getConnection ().prepareStatement ( SQL_INSERT );

    final int len = data.length ();

    for ( int i = 0; i <= len / this.chunkSize; i++ )
    {
        int end = ( i + 1 ) * this.chunkSize;
        if ( end > len )
        {
            end = len;
        }

        final String chunk = data.substring ( i * this.chunkSize, end );

        stmt.setObject ( 1, node.getId () );
        stmt.setObject ( 2, this.instanceId );
        stmt.setObject ( 3, i );
        stmt.setObject ( 4, chunk );
        stmt.addBatch ();
    }

    stmt.executeBatch ();
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:31,代碼來源:JdbcStorageDaoBase64Impl.java

示例13: performExecution

import java.sql.PreparedStatement; //導入方法依賴的package包/類
private void performExecution() {
	try {
		for ( Map.Entry<String,PreparedStatement> entry : getStatements().entrySet() ) {
			try {
				final PreparedStatement statement = entry.getValue();
				final int[] rowCounts;
				try {
					transactionContext().startBatchExecution();
					rowCounts = statement.executeBatch();
				}
				finally {
					transactionContext().endBatchExecution();
				}
				checkRowCounts( rowCounts, statement );
			}
			catch ( SQLException e ) {
				abortBatch();
				throw sqlExceptionHelper().convert( e, "could not execute batch", entry.getKey() );
			}
		}
	}
	catch ( RuntimeException re ) {
		LOG.unableToExecuteBatch( re.getMessage() );
		throw re;
	}
	finally {
		batchPosition = 0;
	}
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:30,代碼來源:BatchingBatch.java

示例14: testBug20029

import java.sql.PreparedStatement; //導入方法依賴的package包/類
/**
 * Tests fix for BUG#20029 - NPE thrown from executeBatch().
 * 
 * @throws Exception
 */
public void testBug20029() throws Exception {
    createTable("testBug20029", ("(field1 int)"));

    long initialTimeout = 20; // may need to raise this depending on environment we try and do this automatically in this testcase

    for (int i = 0; i < 10; i++) {
        final Connection toBeKilledConn = getConnectionWithProps(new Properties());
        final long timeout = initialTimeout;
        PreparedStatement toBeKilledPstmt = null;

        try {
            toBeKilledPstmt = ((com.mysql.jdbc.Connection) toBeKilledConn).clientPrepareStatement("INSERT INTO testBug20029 VALUES (?)");

            for (int j = 0; j < 1000; j++) {
                toBeKilledPstmt.setInt(1, j);
                toBeKilledPstmt.addBatch();
            }

            Thread t = new Thread() {
                @Override
                public void run() {
                    try {
                        sleep(timeout);
                        toBeKilledConn.close();
                    } catch (Throwable thr) {

                    }
                }
            };

            t.start();

            try {
                if (!toBeKilledConn.isClosed()) {
                    initialTimeout *= 2;
                    continue;
                }

                toBeKilledPstmt.executeBatch();
                fail("Should've caught a SQLException for the statement being closed here");
            } catch (BatchUpdateException batchEx) {
                assertEquals("08003", batchEx.getSQLState());
                break;
            } catch (SQLException sqlEx) {
                assertEquals("08003", sqlEx.getSQLState());
                break;
            }

            fail("Connection didn't close while in the middle of PreparedStatement.executeBatch()");
        } finally {
            if (toBeKilledPstmt != null) {
                toBeKilledPstmt.close();
            }

            if (toBeKilledConn != null) {
                toBeKilledConn.close();
            }
        }
    }
}
 
開發者ID:rafallis,項目名稱:BibliotecaPS,代碼行數:66,代碼來源:StatementRegressionTest.java

示例15: testInsertBatch

import java.sql.PreparedStatement; //導入方法依賴的package包/類
@Test
public void testInsertBatch() throws SQLException {

  PreparedStatement ps = con.prepareStatement("INSERT INTO Fortune (id, message) VALUES (?, ?)");

  ps.setInt(1, 2000);
  ps.setString(2, "Hello");
  ps.addBatch();

  ps.setInt(1, 2001);
  ps.setString(2, "Vert.x");
  ps.addBatch();

  ps.setInt(1, 2002);
  ps.setString(2, "World");
  ps.addBatch();

  ps.executeBatch();

  assertEquals(-1, ps.getUpdateCount());

  ps.close();

  assertEquals(true, ps.isClosed());

}
 
開發者ID:vietj,項目名稱:reactive-pg-client,代碼行數:27,代碼來源:JdbcTest.java


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