All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.shardingsphere.core.hint.HintManagerHolder Maven / Gradle / Ivy

There is a newer version: 3.1.0
Show newest version
/*
 * Copyright 2016-2018 shardingsphere.io.
 * 

* 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 io.shardingsphere.core.hint; import com.google.common.base.Optional; import com.google.common.base.Preconditions; import io.shardingsphere.core.api.HintManager; import io.shardingsphere.core.api.algorithm.sharding.ShardingValue; import lombok.AccessLevel; import lombok.NoArgsConstructor; /** * Hint manager holder. * *

Use thread-local to manage hint.

* * @author zhangliang */ @NoArgsConstructor(access = AccessLevel.PRIVATE) public final class HintManagerHolder { public static final String DB_TABLE_NAME = "DB_TABLE_NAME"; public static final String DB_COLUMN_NAME = "DB_COLUMN_NAME"; private static final ThreadLocal HINT_MANAGER_HOLDER = new ThreadLocal<>(); /** * Set hint manager. * * @param hintManager hint manager instance */ public static void setHintManager(final HintManager hintManager) { Preconditions.checkState(null == HINT_MANAGER_HOLDER.get(), "HintManagerHolder has previous value, please clear first."); HINT_MANAGER_HOLDER.set(hintManager); } /** * Adjust use sharding hint in current thread. * @return use sharding hint in current thread or not */ public static boolean isUseShardingHint() { return null != HINT_MANAGER_HOLDER.get() && HINT_MANAGER_HOLDER.get().isShardingHint(); } /** * Get database sharding value. * * @param shardingKey sharding key * @return database sharding value */ public static Optional getDatabaseShardingValue(final ShardingKey shardingKey) { return isUseShardingHint() ? Optional.fromNullable(HINT_MANAGER_HOLDER.get().getDatabaseShardingValue(shardingKey)) : Optional.absent(); } /** * Get table sharding value. * * @param shardingKey sharding key * @return table sharding value */ public static Optional getTableShardingValue(final ShardingKey shardingKey) { return isUseShardingHint() ? Optional.fromNullable(HINT_MANAGER_HOLDER.get().getTableShardingValue(shardingKey)) : Optional.absent(); } /** * Adjust is force route to master database only or not. * * @return is force route to master database only or not */ public static boolean isMasterRouteOnly() { return null != HINT_MANAGER_HOLDER.get() && HINT_MANAGER_HOLDER.get().isMasterRouteOnly(); } /** * Adjust database sharding only. * * @return database sharding only or not */ public static boolean isDatabaseShardingOnly() { return null != HINT_MANAGER_HOLDER.get() && HINT_MANAGER_HOLDER.get().isDatabaseShardingOnly(); } /** * Clear hint manager for current thread-local. */ public static void clear() { HINT_MANAGER_HOLDER.remove(); } /** * Get hint manager in current thread. * * @return hint manager in current thread */ public static HintManager get() { return HINT_MANAGER_HOLDER.get(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy