AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX Blogs
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 14.05.2012, 17:11   #1  
Blog bot is offline
Blog bot
Участник
 
25,643 / 848 (80) +++++++
Регистрация: 28.10.2006
emeadaxsupport: AX 2012 Retail: Creating Offline Database fails
Источник: http://blogs.msdn.com/b/axsupport/ar...ase-fails.aspx
==============

Title: Creating Offline Database fails

Symptom:

When running the configure Offline database an error occur.











Description:

We had several cases logged were the offline database creation failed. In the following section describes a known issue with the Seed Data that leads to failure in the Offline Database creation.

The normal procedure for creating the Databases is like this.

Step 1:



To install the Store database

1. Start the DB utility

2. Fill out

a. Store database name

b. Store server name

3. Then click on Configure offline database

4. Fill out

a. Store ID

b. Terminal ID

c. Data Area ID

5. Then click on configure store database

6. Then click continue



Step 2:

Run minimum the following jobs

N-1070

N-1090

N-1095



Step 3:

1. Start DB utility again

2. Click on the configure Offline database

3. Fill out

a. Offline database name

b. Offline server name

4. Click on Continue









Investigation:

C:\Program Files (x86)\Microsoft Dynamics AX\60\Retail Database Utility\RetailDatabaseUtility.log

In the RetailDatabaseUtility.log we can follow the activities executed by the Retail Database Utility.

In this scenario we get this error message which relates to Invalid column name 'DataAreAID' in the offlinescope 'POS transactions'.

INFO , RetailDatabaseUtility, 4, 05/14/2012 08:15:25:952, Determining meta-data for provisioning remote scope 'POS transactions'

WARNING, RetailDatabaseUtility, 4, 05/14/2012 08:15:25:967, Caught Exception: System.Data.SqlClient.SqlException (0x80131904): Invalid column name 'DataAreAID'.

at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)

at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection)

at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning()

at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)

at System.Data.SqlClient.SqlDataReader.ConsumeMetaData()

at System.Data.SqlClient.SqlDataReader.get_MetaData()

at System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)

at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)

at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)

at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)

at System.Data.SqlClient.SqlCommand.ExecuteReader(CommandBehavior behavior, String method)

at System.Data.SqlClient.SqlCommand.ExecuteDbDataReader(CommandBehavior behavior)

at System.Data.Common.DbCommand.System.Data.IDbCommand.ExecuteReader(CommandBehavior behavior)

at System.Data.Common.DbDataAdapter.FillSchemaInternal(DataSet dataset, DataTable datatable, SchemaType schemaType, IDbCommand command, String srcTable, CommandBehavior behavior)

at System.Data.Common.DbDataAdapter.FillSchema(DataTable dataTable, SchemaType schemaType, IDbCommand command, CommandBehavior behavior)

at System.Data.Common.DbDataAdapter.FillSchema(DataTable dataTable, SchemaType schemaType)

at Microsoft.Synchronization.Data.DbSyncSchemaBuilder.FillSchema(IDbConnection connection, String tableName, IDbCommand schemaCmd, DataTable dataTable)

at Microsoft.Synchronization.Data.DbSyncSchemaBuilder.GetSchemaFromDatabase(IDbConnection connection, Collection`1& missingTables, Exception& exp)

ERROR , RetailDatabaseUtility, 4, 05/14/2012 08:15:25:967, Microsoft.Synchronization.Data.DbSchemaException: Cannot obtain the schema for the following tables: RETAILPOSBATCHACCOUNTTRANS. Ensure that you can establish a connection to the database and that the tables exist. Check the inner exception for any store-specific errors. ---> System.Data.SqlClient.SqlException: Invalid column name 'DataAreAID'.

at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)

at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection)

at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning()

at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)

at System.Data.SqlClient.SqlDataReader.ConsumeMetaData()

at System.Data.SqlClient.SqlDataReader.get_MetaData()

at System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)

at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)

at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)

at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)

at System.Data.SqlClient.SqlCommand.ExecuteReader(CommandBehavior behavior, String method)

at System.Data.SqlClient.SqlCommand.ExecuteDbDataReader(CommandBehavior behavior)

at System.Data.Common.DbCommand.System.Data.IDbCommand.ExecuteReader(CommandBehavior behavior)

at System.Data.Common.DbDataAdapter.FillSchemaInternal(DataSet dataset, DataTable datatable, SchemaType schemaType, IDbCommand command, String srcTable, CommandBehavior behavior)

at System.Data.Common.DbDataAdapter.FillSchema(DataTable dataTable, SchemaType schemaType, IDbCommand command, CommandBehavior behavior)

at System.Data.Common.DbDataAdapter.FillSchema(DataTable dataTable, SchemaType schemaType)

at Microsoft.Synchronization.Data.DbSyncSchemaBuilder.FillSchema(IDbConnection connection, String tableName, IDbCommand schemaCmd, DataTable dataTable)

at Microsoft.Synchronization.Data.DbSyncSchemaBuilder.GetSchemaFromDatabase(IDbConnection connection, Collection`1& missingTables, Exception& exp)

--- End of inner exception stack trace ---





Issue:

In the following field lists for the POS transaction scope an “Incorrect” DataAreaID column was added.

- Retail/Setup/POS/Profiles/Offline Profile

- In line details choose POS Transactions

- Click on Offline scope

- In line details mark the first table

- Click on Field list

- Scroll down to the bottom



Cause:

When running the Seed Data generation the job inserts “DataAreAID” to the field list on non global tables, but as the tables actually has DATAAREAID column defined, it inserts it twice.

Retail/Setup/Parameters/Retail parameters/initialize



\Classes\RetailOfflineDefaultProfileCreator\createScopeFromJob

The line with the #DataAreaID is causing this

if (dictTable.dataPrCompany()) // Only add DataAreaId if table is not global

{

offlineColumn.clear();

offlineColumn.SyncColumnName = #DataAreaId;

offlineColumn.SyncTable = offlineTable.RecId;

offlineColumn.insert();

}













Workaround:

Delete the Column DataAreAID on all Offline tables in the POS transaction (Don´t delete DATAAREAID)



Possible code workaround for the seed data.

- Out comment the offlineColumn.SyncColumnName = #DataAreaId;



\Classes\RetailOfflineDefaultProfileCreator\createScopeFromJob

The line with the #DataAreaID is causing this

if (dictTable.dataPrCompany()) // Only add DataAreaId if table is not global

{

offlineColumn.clear();

offlineColumn.SyncColumnName = #DataAreaId;

offlineColumn.SyncTable = offlineTable.RecId;

offlineColumn.insert();

}



Author: Kim Truelsen

Date: 14/5-2012










Источник: http://blogs.msdn.com/b/axsupport/ar...ase-fails.aspx
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
Теги
ax2012, retail

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
emeadaxsupport: AX for Retail 2012: Customizing the Transaction Service Blog bot DAX Blogs 0 19.04.2012 01:14
emeadaxsupport: AX 2012 Retail POS installation issue Blog bot DAX Blogs 0 26.02.2012 11:11
emeadaxsupport: New Content for Microsoft Dynamics AX 2012 : October 2011 Blog bot DAX Blogs 0 27.10.2011 17:11
axinthefield: Dynamics AX Event IDs Blog bot DAX Blogs 0 01.03.2011 22:11
daxdilip: Whats New in Dynamics AX 2012 (A brief extract from the recently held Tech Conf.) Blog bot DAX Blogs 7 31.01.2011 12:35

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 12:57.