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

com.azure.resourcemanager.sql.models.SqlElasticPool Maven / Gradle / Ivy

Go to download

This package contains Microsoft Azure Sql Management SDK. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt

The newest version!
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

package com.azure.resourcemanager.sql.models;

import com.azure.core.annotation.Fluent;
import com.azure.core.http.rest.PagedFlux;
import com.azure.core.management.Region;
import com.azure.resourcemanager.resources.fluentcore.arm.models.ExternalChildResource;
import com.azure.resourcemanager.resources.fluentcore.arm.models.HasResourceGroup;
import com.azure.resourcemanager.resources.fluentcore.arm.models.Resource;
import com.azure.resourcemanager.resources.fluentcore.model.Appliable;
import com.azure.resourcemanager.resources.fluentcore.model.Attachable;
import com.azure.resourcemanager.resources.fluentcore.model.HasInnerModel;
import com.azure.resourcemanager.resources.fluentcore.model.Refreshable;
import com.azure.resourcemanager.resources.fluentcore.model.Updatable;
import com.azure.resourcemanager.sql.fluent.models.ElasticPoolInner;
import reactor.core.publisher.Mono;

import java.time.OffsetDateTime;
import java.util.List;

/** An immutable client-side representation of an Azure SQL Elastic Pool. */
@Fluent
public interface SqlElasticPool
    extends ExternalChildResource,
        HasInnerModel,
        HasResourceGroup,
        Refreshable,
        Updatable {

    /** @return name of the SQL Server to which this elastic pool belongs */
    String sqlServerName();

    /** @return the creation date of the Azure SQL Elastic Pool */
    OffsetDateTime creationDate();

    /** @return the state of the Azure SQL Elastic Pool */
    ElasticPoolState state();

    /** @return the edition of Azure SQL Elastic Pool */
    ElasticPoolEdition edition();

    /** @return The total shared DTU for the SQL Azure Database Elastic Pool */
    int dtu();

    /** @return the maximum DTU any one SQL Azure database can consume. */
    Double databaseDtuMax();

    /** @return the minimum DTU all SQL Azure Databases are guaranteed */
    Double databaseDtuMin();

    /** @return the storage capacity limit for the SQL Azure Database Elastic Pool in Bytes */
    Long storageCapacity();

    /** @return the parent SQL server ID */
    String parentId();

    /** @return the name of the region the resource is in */
    String regionName();

    /** @return the region the resource is in */
    Region region();

    // Actions

    /** @return the information about elastic pool activities */
    List listActivities();

    /** @return a representation of the deferred computation of the information about elastic pool activities */
    PagedFlux listActivitiesAsync();

    /**
     * Lists the SQL databases in this SQL Elastic Pool.
     *
     * @return the information about databases in elastic pool
     */
    List listDatabases();

    /**
     * Asynchronously lists the SQL databases in this SQL Elastic Pool.
     *
     * @return a representation of the deferred computation of this call
     */
    PagedFlux listDatabasesAsync();

    /**
     * Gets the specific database in the elastic pool.
     *
     * @param databaseName name of the database to look into
     * @return the information about specific database in elastic pool
     */
    SqlDatabase getDatabase(String databaseName);

    /**
     * Adds a new SQL Database to the Elastic Pool.
     *
     * @param databaseName name of the database
     * @return the database
     */
    SqlDatabase addNewDatabase(String databaseName);

    /**
     * Adds an existing SQL Database to the Elastic Pool.
     *
     * @param databaseName name of the database
     * @return the database
     */
    SqlDatabase addExistingDatabase(String databaseName);

    /**
     * Adds an existing SQL Database to the Elastic Pool.
     *
     * @param database the database to be added
     * @return the database
     */
    SqlDatabase addExistingDatabase(SqlDatabase database);

    /**
     * Removes an existing SQL Database from the Elastic Pool.
     *
     * @param databaseName name of the database
     * @return the database
     */
    SqlDatabase removeDatabase(String databaseName);

    /** Deletes this SQL Elastic Pool from the parent SQL server. */
    void delete();

    /**
     * Deletes this SQL Elastic Pool asynchronously from the parent SQL server.
     *
     * @return a representation of the deferred computation of this call
     */
    Mono deleteAsync();

    /**************************************************************
     * Fluent interfaces to provision a SQL Elastic Pool
     **************************************************************/

    /**
     * Container interface for all the definitions that need to be implemented.
     *
     * @param  the stage of the parent definition to return to after attaching this definition
     */
    interface SqlElasticPoolDefinition
        extends DefinitionStages.Blank,
            DefinitionStages.WithEdition,
            DefinitionStages.WithBasicEdition,
            DefinitionStages.WithStandardEdition,
            DefinitionStages.WithPremiumEdition,
            DefinitionStages.WithAttach {
    }

    /** Grouping of all the storage account definition stages. */
    interface DefinitionStages {
        /**
         * The first stage of the SQL Server definition.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface Blank extends SqlElasticPool.DefinitionStages.WithEdition {
        }

        /**
         * The SQL Elastic Pool definition to set the edition for database.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithEdition {
            /**
             * Sets the sku for the SQL Elastic Pool.
             *
             * @param sku the sku to be set for elastic pool
             * @return The next stage of the definition
             */
            SqlElasticPool.DefinitionStages.WithAttach withSku(ElasticPoolSku sku);

            /**
             * Sets the sku for the SQL Elastic Pool.
             *
             * @param sku sku/edition to be set for elastic pool, all possible capabilities could be found by
             *     {@link SqlServers#getCapabilitiesByRegion(Region)}
             * @return The next stage of the definition
             */
            SqlElasticPool.DefinitionStages.WithAttach withSku(Sku sku);

            /**
             * Sets the basic edition for the SQL Elastic Pool.
             *
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithBasicEdition withBasicPool();

            /**
             * Sets the standard edition for the SQL Elastic Pool.
             *
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithStandardEdition withStandardPool();

            /**
             * Sets the premium edition for the SQL Elastic Pool.
             *
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithPremiumEdition withPremiumPool();
        }

        /**
         * The SQL Elastic Pool definition to set the eDTU and storage capacity limits for a basic pool.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithBasicEdition extends SqlElasticPool.DefinitionStages.WithAttach {
            /**
             * Sets the total shared eDTU for the SQL Azure Database Elastic Pool.
             *
             * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithBasicEdition withReservedDtu(SqlElasticPoolBasicEDTUs eDTU);

            /**
             * Sets the maximum number of eDTU a database in the pool can consume.
             *
             * @param eDTU maximum eDTU a database in the pool can consume
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithBasicEdition withDatabaseDtuMax(
                SqlElasticPoolBasicMaxEDTUs eDTU);

            /**
             * Sets the minimum number of eDTU for each database in the pool are regardless of its activity.
             *
             * @param eDTU minimum eDTU for all SQL Azure databases
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithBasicEdition withDatabaseDtuMin(
                SqlElasticPoolBasicMinEDTUs eDTU);
        }

        /**
         * The SQL Elastic Pool definition to set the eDTU and storage capacity limits for a standard pool.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithStandardEdition extends SqlElasticPool.DefinitionStages.WithAttach {
            /**
             * Sets the total shared eDTU for the SQL Azure Database Elastic Pool.
             *
             * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithStandardEdition withReservedDtu(
                SqlElasticPoolStandardEDTUs eDTU);

            /**
             * Sets the maximum number of eDTU a database in the pool can consume.
             *
             * @param eDTU maximum eDTU a database in the pool can consume
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithStandardEdition withDatabaseDtuMax(
                SqlElasticPoolStandardMaxEDTUs eDTU);

            /**
             * Sets the minimum number of eDTU for each database in the pool are regardless of its activity.
             *
             * @param eDTU minimum eDTU for all SQL Azure databases
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithStandardEdition withDatabaseDtuMin(
                SqlElasticPoolStandardMinEDTUs eDTU);

            /**
             * Sets the storage capacity for the SQL Azure Database Elastic Pool.
             *
             * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithStandardEdition withStorageCapacity(
                SqlElasticPoolStandardStorage storageCapacity);
        }

        /**
         * The SQL Elastic Pool definition to set the eDTU and storage capacity limits for a premium pool.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithPremiumEdition extends SqlElasticPool.DefinitionStages.WithAttach {
            /**
             * Sets the total shared eDTU for the SQL Azure Database Elastic Pool.
             *
             * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithPremiumEdition withReservedDtu(
                SqlElasticPoolPremiumEDTUs eDTU);

            /**
             * Sets the maximum number of eDTU a database in the pool can consume.
             *
             * @param eDTU maximum eDTU a database in the pool can consume
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithPremiumEdition withDatabaseDtuMax(
                SqlElasticPoolPremiumMaxEDTUs eDTU);

            /**
             * Sets the minimum number of eDTU for each database in the pool are regardless of its activity.
             *
             * @param eDTU minimum eDTU for all SQL Azure databases
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithPremiumEdition withDatabaseDtuMin(
                SqlElasticPoolPremiumMinEDTUs eDTU);

            /**
             * Sets the storage capacity for the SQL Azure Database Elastic Pool.
             *
             * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithPremiumEdition withStorageCapacity(
                SqlElasticPoolPremiumSorage storageCapacity);
        }

        /**
         * The SQL Elastic Pool definition to set the minimum capacity for database.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithDatabaseMinCapacity {
            /**
             * Sets the minimum capacity all SQL Azure Databases are guaranteed.
             *
             * @param minCapacity The minimum capacity all databases are guaranteed.
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithAttach withDatabaseMinCapacity(double minCapacity);
        }

        /**
         * The SQL Elastic Pool definition to set the maximum capacity for one database.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithDatabaseMaxCapacity {
            /**
             * Sets the maximum capacity any one SQL Azure Database can consume.
             *
             * @param maxCapacity The maximum capacity any one database can consume.
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithAttach withDatabaseMaxCapacity(double maxCapacity);
        }

        /**
         * The SQL Elastic Pool definition to set the storage limit for the SQL Azure Database Elastic Pool in Bytes.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithStorageCapacity {
            /**
             * Sets the storage limit for the SQL Azure Database Elastic Pool in Bytes.
             *
             * @param storageCapacity storage limit for the SQL Azure Database Elastic Pool in Bytes
             * @return The next stage of the definition.
             */
            SqlElasticPool.DefinitionStages.WithAttach withStorageCapacity(Long storageCapacity);
        }

        /**
         * The final stage of the SQL Elastic Pool definition.
         *
         * 

At this stage, any remaining optional settings can be specified, or the SQL Elastic Pool definition can be * attached to the parent SQL Server definition. * * @param the stage of the parent definition to return to after attaching this definition */ interface WithAttach extends WithDatabaseMinCapacity, WithDatabaseMaxCapacity, WithStorageCapacity, Attachable.InDefinition { } } /** The template for a SQL Elastic Pool update operation, containing all the settings that can be modified. */ interface Update extends UpdateStages.WithReservedDTUAndStorageCapacity, UpdateStages.WithDatabaseMinCapacity, UpdateStages.WithDatabaseMaxCapacity, UpdateStages.WithStorageCapacity, UpdateStages.WithDatabase, Resource.UpdateWithTags, Appliable { } /** Grouping of all the SQL Elastic Pool update stages. */ interface UpdateStages { /** The SQL Elastic Pool definition to set the minimum DTU for database. */ interface WithDatabaseMinCapacity { /** * Sets the minimum capacity all SQL Azure Databases are guaranteed. * * @param minCapacity The minimum capacity all databases are guaranteed. * @return The next stage of definition. */ Update withDatabaseMinCapacity(double minCapacity); } /** The SQL Elastic Pool definition to set the maximum DTU for one database. */ interface WithDatabaseMaxCapacity { /** * Sets the maximum capacity any one SQL Azure Database can consume. * * @param maxCapacity The maximum capacity any one database can consume. * @return The next stage of definition. */ Update withDatabaseMaxCapacity(double maxCapacity); } /** * The SQL Elastic Pool definition to set the storage limit for the SQL Azure Database Elastic Pool in Bytes. */ interface WithStorageCapacity { /** * Sets the storage limit for the SQL Azure Database Elastic Pool in Bytes. * * @param storageCapacity storage limit for the SQL Azure Database Elastic Pool in Bytes * @return The next stage of definition. */ Update withStorageCapacity(Long storageCapacity); } /** The SQL Elastic Pool update definition to set the eDTU and storage capacity limits. */ interface WithReservedDTUAndStorageCapacity { /** * Sets the total shared eDTU for the SQL Azure Database Elastic Pool. * * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ Update withReservedDtu(SqlElasticPoolBasicEDTUs eDTU); /** * Sets the maximum number of eDTU a database in the pool can consume. * * @param eDTU maximum eDTU a database in the pool can consume * @return The next stage of the update definition. */ Update withDatabaseDtuMax(SqlElasticPoolBasicMaxEDTUs eDTU); /** * Sets the minimum number of eDTU for each database in the pool are regardless of its activity. * * @param eDTU minimum eDTU for all SQL Azure databases * @return The next stage of the update definition. */ Update withDatabaseDtuMin(SqlElasticPoolBasicMinEDTUs eDTU); /** * Sets the total shared eDTU for the SQL Azure Database Elastic Pool. * * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ Update withReservedDtu(SqlElasticPoolStandardEDTUs eDTU); /** * Sets the maximum number of eDTU a database in the pool can consume. * * @param eDTU maximum eDTU a database in the pool can consume * @return The next stage of the update definition. */ Update withDatabaseDtuMax(SqlElasticPoolStandardMaxEDTUs eDTU); /** * Sets the minimum number of eDTU for each database in the pool are regardless of its activity. * * @param eDTU minimum eDTU for all SQL Azure databases * @return The next stage of the update definition. */ Update withDatabaseDtuMin(SqlElasticPoolStandardMinEDTUs eDTU); /** * Sets the storage capacity for the SQL Azure Database Elastic Pool. * * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ Update withStorageCapacity(SqlElasticPoolStandardStorage storageCapacity); /** * Sets the total shared eDTU for the SQL Azure Database Elastic Pool. * * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ Update withReservedDtu(SqlElasticPoolPremiumEDTUs eDTU); /** * Sets the maximum number of eDTU a database in the pool can consume. * * @param eDTU maximum eDTU a database in the pool can consume * @return The next stage of the update definition. */ Update withDatabaseDtuMax(SqlElasticPoolPremiumMaxEDTUs eDTU); /** * Sets the minimum number of eDTU for each database in the pool are regardless of its activity. * * @param eDTU minimum eDTU for all SQL Azure databases * @return The next stage of the update definition. */ Update withDatabaseDtuMin(SqlElasticPoolPremiumMinEDTUs eDTU); /** * Sets the storage capacity for the SQL Azure Database Elastic Pool. * * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ Update withStorageCapacity(SqlElasticPoolPremiumSorage storageCapacity); } /** The SQL Elastic Pool definition to add the Database in the elastic pool. */ interface WithDatabase { /** * Creates a new database in the SQL elastic pool. * * @param databaseName name of the new database to be added in the elastic pool * @return The next stage of the definition. */ Update withNewDatabase(String databaseName); /** * Adds an existing database in the SQL elastic pool. * * @param databaseName name of the existing database to be added in the elastic pool * @return The next stage of the definition. */ Update withExistingDatabase(String databaseName); /** * Adds the database in the SQL elastic pool. * * @param database database instance to be added in SQL elastic pool * @return The next stage of the definition. */ Update withExistingDatabase(SqlDatabase database); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy