OrchestrationShardingDataSourceFactory.java 2.2 KB
Newer Older
T
terrymanu 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/*
 * Copyright 1999-2015 dangdang.com.
 * <p>
 * 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.
 * </p>
 */

18
package io.shardingjdbc.orchestration.api;
T
terrymanu 已提交
19

H
haocao 已提交
20
import io.shardingjdbc.orchestration.api.config.OrchestrationShardingConfiguration;
H
haocao 已提交
21
import io.shardingjdbc.orchestration.api.datasource.OrchestrationShardingDataSource;
T
terrymanu 已提交
22 23 24 25 26 27 28 29 30 31 32
import lombok.AccessLevel;
import lombok.NoArgsConstructor;

import javax.sql.DataSource;
import java.sql.SQLException;
import java.util.Properties;

/**
 * Orchestration sharding data source factory.
 * 
 * @author zhangliang 
H
haocao 已提交
33
 * @author caohao 
T
terrymanu 已提交
34 35 36 37 38 39
 */
@NoArgsConstructor(access = AccessLevel.PRIVATE)
public final class OrchestrationShardingDataSourceFactory {
    
    /**
     * Create sharding data source.
H
haocao 已提交
40 41
     *
     * @param config orchestration sharding configuration
T
terrymanu 已提交
42 43 44
     * @return sharding data source
     * @throws SQLException SQL exception
     */
H
haocao 已提交
45
    public static DataSource createDataSource(final OrchestrationShardingConfiguration config) throws SQLException {
T
terrymanu 已提交
46
        return createDataSource(config, new Properties());
T
terrymanu 已提交
47 48 49 50
    }
    
    /**
     * Create sharding data source.
51
     *
H
haocao 已提交
52
     * @param config orchestration sharding configuration
T
terrymanu 已提交
53 54 55 56
     * @param props properties for data source
     * @return sharding data source
     * @throws SQLException SQL exception
     */
H
haocao 已提交
57
    public static DataSource createDataSource(final OrchestrationShardingConfiguration config, final Properties props) throws SQLException {
T
terrymanu 已提交
58 59 60
        OrchestrationShardingDataSource orchestrationShardingDataSource = new OrchestrationShardingDataSource(config, props);
        orchestrationShardingDataSource.init();
        return orchestrationShardingDataSource.getDataSource();
61
    }
T
terrymanu 已提交
62
}