📄 statements.java
字号:
/*
* $Header: /home/cvs/jakarta-struts/contrib/artimus/WEB-INF/src/java/org/apache/artimus/keys/sql/Statements.java,v 1.3 2004/03/14 07:15:04 sraeburn Exp $
* $Revision: 1.3 $
* $Date: 2004/03/14 07:15:04 $
*
* Copyright 2001-2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.artimus.keys.sql;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import org.apache.scaffold.sql.ConnectionPool;
/**
* SQL statements for the Keys package.
* @version $Revision: 1.3 $ $Date: 2004/03/14 07:15:04 $
*/
public final class Statements {
/**
* Returns next sequential key for given table, without
* allocating a key.
* <p>
* @return The next int key value to be inserted
* @exception SQLException if SQL error occurs
*/
public static final synchronized int peekKey(String keyName)
throws SQLException {
int next = 0;
int result = 0;
Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet = null;
try {
connection = ConnectionPool.getConnection();
statement =
connection.prepareStatement(Commands.KEYS_NEXT);
statement.setString(1,keyName);
resultSet = statement.executeQuery();
if (resultSet.next()) {
next = resultSet.getInt(1);
}
}
finally {
try {
if (resultSet != null) resultSet.close();
if (statement != null) statement.close();
if (connection!= null) connection.close();
}
catch (SQLException sqle) {}
}
return next;
} // ---- End getKeyNext ----
/**
* Returns next sequential key for given table.
* <p>
* This ensures compatibility for DBMS products that do not
* support auto-incrementing a key field.
* <p>
* Intended to generate primary keys, but could be used to
* create other serial numbers based on an unsigned int.
* <p>
* Allocating the key involves reading the current key, and
* then incrementing the key for the next user. The method
* is synchronized so that two threads do not read the
* same key before it is increment.
* <p>
* @return The unsigned int key value to be inserted
* @exception SQLException if SQL error occurs
* @param keyName The name of the table for this key
*/
public static final synchronized Integer allocateKey(String keyName)
throws SQLException {
Integer next = null;
int result = 0;
Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet = null;
try {
connection = ConnectionPool.getConnection();
statement =
connection.prepareStatement(Commands.KEYS_NEXT);
statement.setString(1,keyName);
resultSet = statement.executeQuery();
if (resultSet.next()) {
next = new Integer(resultSet.getInt(1));
statement = connection.prepareStatement(
Commands.KEYS_INC);
statement.setString(1,keyName);
result = statement.executeUpdate();
}
}
finally {
try {
if (resultSet != null) resultSet.close();
if (statement != null) statement.close();
if (connection!= null) connection.close();
}
catch (SQLException sqle) {}
}
return next;
} // ---- End getKeyNext ----
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -