Article.DatabaseName Proprietà

Definizione

Ottiene o imposta il nome del database che contiene i dati e gli oggetti pubblicati nell'articolo.

public:
 property System::String ^ DatabaseName { System::String ^ get(); void set(System::String ^ value); };
public string DatabaseName { get; set; }
member this.DatabaseName : string with get, set
Public Property DatabaseName As String

Valore della proprietà

Nome del database di pubblicazione.

Eccezioni

Quando si tenta di impostare la DatabaseName proprietà per un articolo esistente.

Quando si imposta la DatabaseName proprietà su un null valore, su un valore con null caratteri o su un valore più lungo di 128 caratteri Unicode.

Esempio

// Define the Publisher, publication, and article names.
string publisherName = publisherInstance;
string publicationName = "AdvWorksProductTran";
string publicationDbName = "AdventureWorks2012";
string articleName = "Product";
string schemaOwner = "Production";

TransArticle article;

// Create a connection to the Publisher.
ServerConnection conn = new ServerConnection(publisherName);

// Create a filtered transactional articles in the following steps:
// 1) Create the  article with a horizontal filter clause.
// 2) Add columns to or remove columns from the article.
try
{
    // Connect to the Publisher.
    conn.Connect();

    // Define a horizontally filtered, log-based table article.
    article = new TransArticle();
    article.ConnectionContext = conn;
    article.Name = articleName;
    article.DatabaseName = publicationDbName;
    article.SourceObjectName = articleName;
    article.SourceObjectOwner = schemaOwner;
    article.PublicationName = publicationName;
    article.Type = ArticleOptions.LogBased;
    article.FilterClause = "DiscontinuedDate IS NULL";

    // Ensure that we create the schema owner at the Subscriber.
    article.SchemaOption |= CreationScriptOptions.Schema;

    if (!article.IsExistingObject)
    {
        // Create the article.
        article.Create();
    }
    else
    {
        throw new ApplicationException(String.Format(
            "The article {0} already exists in publication {1}.",
            articleName, publicationName));
    }

    // Create an array of column names to remove from the article.
    String[] columns = new String[1];
    columns[0] = "DaysToManufacture";

    // Remove the column from the article.
    article.RemoveReplicatedColumns(columns);
}
catch (Exception ex)
{
    // Implement appropriate error handling here.
    throw new ApplicationException("The article could not be created.", ex);
}
finally
{
    conn.Disconnect();
}
' Define the Publisher, publication, and article names.
Dim publisherName As String = publisherInstance
Dim publicationName As String = "AdvWorksProductTran"
Dim publicationDbName As String = "AdventureWorks2012"
Dim articleName As String = "Product"
Dim schemaOwner As String = "Production"

Dim article As TransArticle

' Create a connection to the Publisher.
Dim conn As ServerConnection = New ServerConnection(publisherName)

' Create a filtered transactional articles in the following steps:
' 1) Create the  article with a horizontal filter clause.
' 2) Add columns to or remove columns from the article.
Try
    ' Connect to the Publisher.
    conn.Connect()

    ' Define a horizontally filtered, log-based table article.
    article = New TransArticle()
    article.ConnectionContext = conn
    article.Name = articleName
    article.DatabaseName = publicationDbName
    article.SourceObjectName = articleName
    article.SourceObjectOwner = schemaOwner
    article.PublicationName = publicationName
    article.Type = ArticleOptions.LogBased
    article.FilterClause = "DiscontinuedDate IS NULL"

    ' Ensure that we create the schema owner at the Subscriber.
    article.SchemaOption = article.SchemaOption Or _
    CreationScriptOptions.Schema

    If Not article.IsExistingObject Then
        ' Create the article.
        article.Create()
    Else
        Throw New ApplicationException(String.Format( _
         "The article {0} already exists in publication {1}.", _
         articleName, publicationName))
    End If

    ' Create an array of column names to remove from the article.
    Dim columns() As String = New String(0) {}
    columns(0) = "DaysToManufacture"

    ' Remove the column from the article.
    article.RemoveReplicatedColumns(columns)
Catch ex As Exception
    ' Implement appropriate error handling here.
    Throw New ApplicationException("The article could not be created.", ex)
Finally
    conn.Disconnect()
End Try

Commenti

La DatabaseName proprietà è una proprietà di lettura/scrittura.

La DatabaseName proprietà deve essere impostata prima che venga chiamato il Create metodo per creare l'articolo nel server. Il tentativo di impostare questa proprietà per un articolo esistente genera un'eccezione.

La DatabaseName proprietà deve essere impostata sul nome del database di distribuzione per pubblicazioni non SQL Server.

La DatabaseName proprietà può essere recuperata dai membri del ruolo predefinito del sysadmin server nel server di pubblicazione e nel Sottoscrittore (per la ripubblicazione dei Sottoscrittori). Può anche essere recuperato dai membri del ruolo predefinito del db_owner database nel database di pubblicazione e dagli utenti membri dell'elenco di accesso alla pubblicazione. Per un MergeArticle oggetto, questa proprietà può essere recuperata anche dai membri del ruolo predefinito del replmonitor database nel server di distribuzione.

La DatabaseName proprietà può essere impostata dai membri del ruolo predefinito del sysadmin server nel server di pubblicazione. Può anche essere impostato dai membri del ruolo predefinito del db_owner database nel database di pubblicazione.

DatabaseName Il recupero equivale all'esecuzione di sp_helparticle (Transact-SQL) per la replica transazionale o snapshot o l'esecuzione di sp_helpmergearticle (Transact-SQL) per la replica di tipo merge.

L'impostazione DatabaseName equivale all'esecuzione di sp_addarticle (Transact-SQL) per la replica transazionale o snapshot o l'esecuzione di sp_addmergearticle (Transact-SQL) per la replica di tipo merge.

Si applica a

Vedi anche