Article.PublicationName Proprietà

Definizione

Ottiene o imposta il nome della pubblicazione a cui appartiene l'articolo.

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

Valore della proprietà

Nome della pubblicazione.

Eccezioni

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

Quando si imposta la PublicationName 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 PublicationName proprietà è una proprietà di lettura/scrittura, quindi è necessario impostarla prima della creazione dell'oggetto.

La PublicationName 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 PublicationName 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 PublicationName 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.

PublicationName 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 PublicationName 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