Compartir vía


Usar útiles de XRM para crear los datos

Existen siete métodos disponibles en la clase CrmServiceClient o la clase ServiceClient para crear nuevos datos y asociaciones. Una acción de creación que usa la API de los útiles de XRM requiere una carga de datos. La carga útil de datos toma la forma de un objeto Dictionary<string, CrmDataTypeWrapper>. CrmDataTypeWrapper se usa para informes a la interfaz del tipo de control debe ser aplicado al punto de datos al que está haciendo referencia. Algunos de los métodos para crear datos se enumeran en este tema.

CreateNewRecord

Este método se utiliza para crear cualquier tipo de datos de tabla en Microsoft Dataverse. Para usarlo, necesita saber el nombre del esquema de la tabla en la que desea crear un registro y debe construir una carga útil de datos para que se pasará al esquema. En este ejemplo se crea un registro de cuenta.

Al usar la clase ServiceClient, puede encontrar el método CreateNewRecord del espacio de nombres CRUDExtentions.

CrmServiceClient svc = new CrmServiceClient("connectionstring");
// ServiceClient svc = new ServiceClient("connectionstring");
 
// Verify that you are connected  
if (svc != null && svc.IsReady)  
{  
    // Create an account record  
    Dictionary<string, CrmDataTypeWrapper> inData = new Dictionary<string, CrmDataTypeWrapper>();  
    inData.Add("name", new CrmDataTypeWrapper("Sample Account Name", CrmFieldType.String));  
    inData.Add("address1_city", new CrmDataTypeWrapper("Redmond", CrmFieldType.String));  
    inData.Add("telephone1", new CrmDataTypeWrapper("555-0160", CrmFieldType.String));  
    accountId = ctrl.CrmConnectionMgr.svc.CreateNewRecord("account", inData);  
  
    // Verify if the account is created.  
    if (accountId != Guid.Empty)  
    {  
        Console.WriteLine(“Account created.”);  
    }  
}  
else  
{  
    // Display the last error.  
    Console.WriteLine("An error occurred: {0}", svc.LastCrmError);  
  
    // Display the last exception message if any.   
    Console.WriteLine(svc.LastCrmException.Message);  
    Console.WriteLine(svc.LastCrmException.Source);  
    Console.WriteLine(svc.LastCrmException.StackTrace);  
  
    return;  
}  

Lea la siguiente información importante sobre el uso de una cadena de conexión en el código de la aplicación.

Importante

Microsoft recomienda utilizar el flujo de autenticación más seguro disponible. El flujo de autenticación descrito en este artículo requiere un alto grado de confianza en la aplicación y conlleva riesgos que no están presentes en otros flujos. Solo debe usar este flujo cuando otros flujos más seguros, como las identidades administradas, no sean viables.

En este ejemplo se creó un objeto de carga de datos llamado indata. A continuación, se rellenó mediante la sintaxis general crmFieldName , new CrmDataTypeWrapper(data,CrmFieldType). Después de configurar el objeto indata para obtener los valores a crear, llamamos al método CreateNewRecord que proporciona el nombre lógico de la tabla para la cuenta y la carga útil de datos (indata).

Nota

También puede crear un registro de tabla utilizando herramientas XRM ejecutando el mensaje CreateRequest con el método ExecuteCrmOrganizationRequest. Más información: Utilizar mensajes con el método ExecuteCrmOrganizationRequest

CreateAnnotation

Este método se utiliza para crear y adjuntar un objeto de nota a cualquier registro de tabla. Aunque puede rellenar todas las variables de la nota en el primer paso, solo debe proporcionar los campos de texto para el asunto y la nota. En la práctica, esto se usa generalmente para adjuntar notas generadas por el sistema a una tabla, o para adjuntar archivos que están almacenados en Dataverse para una tabla. Además, si proporciona su propia interfaz de usuario para crear notas para su usuario, así es como adjuntaría esa nota a la tabla del propietario en Dataverse. Este ejemplo es la continuación del ejemplo anterior para crear una nota en la cuenta recién creada.

Al usar la clase ServiceClient, puede encontrar el método CreateAnnotation del espacio de nombres CRUDExtentions.

CrmServiceClient svc = new CrmServiceClient(connectionstring);  
// ServiceClient svc = new ServiceClient("connectionstring");

// Verify that you are connected.  
if (svc != null && svc.IsReady)  
{  
    // Create and attach a note.  
    inData.Clear();   
    inData.Add("subject", new CrmDataTypeWrapper("This is a NOTE from the API" , CrmFieldType.String));
    inData.Add("notetext", new CrmDataTypeWrapper("This is text that will go in the body of the note" , CrmFieldType.String));  
    Guid noteID = svc.CreateAnnotation("account", accountId, inData);  
}  
else  
{  
    // Display the last error.  
    Console.WriteLine("An error occurred: {0}", svc.LastCrmError);  
  
    // Display the last exception message if any.  
    Console.WriteLine(svc.LastCrmException.Message);  
    Console.WriteLine(svc.LastCrmException.Source);  
    Console.WriteLine(svc.LastCrmException.StackTrace);  
  
    return;  
}  

Consulte también

Usar herramientas de API XRM para ejecutar acciones en Dataverse