Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
 /*
  * Copyright 2010-2013 Ning, Inc.
  *
  * Ning licenses this file to you 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.killbill.commons.locker.mysql;
// Note: the MySQL lock is connection specific (closing the connection releases the lock)
public class MysqlGlobalLockDao {
    public boolean lock(final Connection connectionfinal String lockNamefinal long timeoutthrows SQLException {
        final String sql = String.format("select GET_LOCK('%s', %d);"lockName.replace("'""\'"), timeout);
        return executeLockQuery(connectionsql);
    }
    public boolean releaseLock(final Connection connectionfinal String lockNamethrows SQLException {
        final String sql = String.format("select RELEASE_LOCK('%s');"lockName.replace("'""\'"));
        return executeLockQuery(connectionsql);
    }
    public boolean isLockFree(final Connection connectionfinal String lockNamethrows SQLException {
        final String sql = String.format("select IS_FREE_LOCK('%s');"lockName.replace("'""\'"));
        return executeLockQuery(connectionsql);
    }
    private boolean executeLockQuery(final Connection connectionfinal String querythrows SQLException {
        Statement statement = null;
        try {
            statement = connection.createStatement();
            final ResultSet rs = statement.executeQuery(query);
            return rs.next() && (rs.getByte(1) == 1);
        } finally {
            if (statement != null) {
                statement.close();
            }
        }
    }
New to GrepCode? Check out our FAQ X