Navision Software was purchased by Microsoft and now it is supported by Microsoft Business Solutions together with Microsoft Great Plains, Axapta, Solomon, Microsoft Retail Management System and Microsoft CRM. Navision has extremely strong position on mid-size European and US markets, plus it has excellent manufacturing solution. Our goal is to help IT departments to support and tune Navision with in-house expertise and skills. The topic of this article is Navision database access from ASP.NET application via C/ODBC interface. Our goal will be ASPX page accessing Navision Customers.
Let's begin
1. In our case we will use Navision Attain 3.6 with Navision Database Server, Navision Application Server and Navision Client. These components are installed on Windows XP. You also need to install C/ODBC component form Navision Attain CD.
2. Let's create ODBC DSN for Navision data access. Select Control Panel -> Administrative Tools -> Data Sources (ODBC). Then select System DSN tab and press Add button. We'll use C/ODBC 32-bit data access driver. We'll name Data Source Name Navision, Connection leave Local. As the database (Database button) select Program FilesNavision AttainClientdatabase.fdb (demo database). Then click Company button ? we'll use CRONUS demo company. It is important for C/SIDE correct database access to setup proper options for C/ODBC connection. Press Options button and look at the options available ? we'll need Identifiers parameter ? it defines identifiers types, which will be transferred to the client application. In order to work correct with MS SQL Server 2000 with C/ODBC source we need to use these type: "a-z,A-Z,0-9,_". Now DNS is done. Let's create Linked Server.
3. Open MS SQL Server Enterprise Manager. Open server tree for the server, which you plan to use, for this server open Security folder and Lined Servers. With right click select New Linked Server in context menu. In the dialog box opened in the Provider Name select Microsoft OLE DB Provider for ODBC Drivers. Let's name our Linked Server NAVISION. In Data Source string enter ODBC DSN name - NAVISION in our case. Linked Server is ready! Let's select tables list and look at the data from Navision Attain database.
4. Next we need to create small stored procedure for sales data selection. Here is the text of the procedure: SET ANSI_NULLS ON SET ANSI_WARNINGS ON GO
CREATE PROCEDURE NavisionCustomers AS
DBCC TRACEON(8765) SELECT No_, Name, Address, City, Contact FROM OPENQUERY(NAVISION, 'SELECT * FROM Customer')
RETURN
Let's clarify some points here. TRACEON(8765) directive allows us to work with the data of variable length, returned by C/ODBC driver. Without it we can not select Navision tables fields ? we will have these errors:
OLE DB error trace [Non-interface error: Unexpected data length returned for the column: ProviderName='MSDASQL', TableName='[MSDASQL]', ColumnName='Ship_to_Filter', ExpectedLength='250', ReturnedLength='1']. Server: Msg 7347, Level 16, State 1, Line 1 OLE DB provider 'MSDASQL' returned an unexpected data length for the fixed-length column '[MSDASQL].Ship_to_Filter'. The expected data length is 250, while the returned data length is 1.
OPENQUERY command opens linked server and gives it execution request, and returns record set selected. Directives ANSI_NULLS and ANSI_WARNINGS are required ? they provide the possibility of the execution for heterogeneous requests. To test the procedure you can give its name in MS SQL Query Analyzer ? EXEC NavisionCustomers
5. Now we need to create ASP.NET application. Let's use free RAD environment ASP.NET WebMatrix. You can get infor and download it at http://asp.net/webmatrix . You need .NET SDK 1.1 installed, before WebMatrix installation.
6. Launch WebMatrix, select creation of the Data Pages -> Editable Data Grid in the wizard screen. Let's keep all the defaults suggested. On the access page created we'll change the header to Navision Attain Customers, select Verdana font and the font size desired. Next place on the page the component SqlDataSourceControl and tune it's ? Connection String : server='(local)'; database='Alba';trusted_connection=true (change server and database name to your actual names), and SelectCommand ? as EXEC NavisionCustomers
7. For our Data Grid, which will show customers, define DataSource as SqlDataSourceControl1, and DatKeyField ? as No_
8. Next switch to code edition mode and make these changes:
? In the DataGrid_Delete method let's correct the request for the customer deletion to the one we need
? Change DataGrid_Delete code, base on the fields we plan to use
9. Launch our application and test it. This is it!
Happy customizing, implementing and modifying! If you want us to do the job - give us a call 1-866-528-0577 or 1-630-961-5918! help@albaspectrum.com
Boris Makushkin is Lead Software Developer in Alba Spectrum Technologies ? USA nationwide Microsoft CRM, Microsoft Great Plains customization company, serving Chicago, Boston, San Francisco, San Diego, Los Angeles, Houston, Dallas, Atlanta, Miami, Montreal, Toronto, Vancouver, Moscow, Europe and internationally ( http://www.albaspectrum.com ), he is Microsoft CRM SDK, Navision, C#, VB.Net, SQL, Oracle, Unix developer.
![]() |
|
![]() |
|
![]() |
|
![]() |
We all already got used to computer monitoring both at... Read More
Microsoft CRM is new player on the CRM software... Read More
Are you one of those people that keeps track of... Read More
In the real world a "fire wall" is a fireproof... Read More
Microsoft CRM is winning market share step-by-step from such the... Read More
Research bears that less than 70 percent of development projects... Read More
IntroductionDuring the early years of our modern computer era, very... Read More
Are Spreadsheets Robbing your Enterprise of Competitive Advantage?'90% of "average"... Read More
I have recently created my first Php program. I wanted... Read More
What is a Web Database?A web database is a database... Read More
To all web designers out there, this article is for... Read More
Microsoft CRM has built-in conversion tool, however you should probably... Read More
And kill the best layout software in the process of... Read More
Microsoft Great Plains, former Great Plains Software Dynamics, eEnterprise has... Read More
While several preventive maintenance software manufacturers offer free trials for... Read More
Microsoft PowerPoint has dramatically changed the way in which academic... Read More
In part III of this ISDN primer, we learned that... Read More
Security flaws have long plagued Internet Explorer (IE), the market-dominating... Read More
Customer Relationship Management, abbreviated "CRM," is the term for a... Read More
Language development computer: Computer-based method for aiding language development seems... Read More
The objective for Zandi Digital is to make available clever... Read More
What is Software?Software is a set of instruction written to... Read More
Current Microsoft Business Solutions Great Plains has more that 10... Read More
What is IRC?IRC is Internet Relay Chat. It is a... Read More
Microsoft Client Relation Management system (Microsoft CRM) and Microsoft RMS... Read More
An integral part of any quality CRM system is lead... Read More
If you have been using the Internet for any amount... Read More
I started using PIP (Picture It Publishing) Platinum 2002 right... Read More
The destruction of the Soviet Union about 15 years ago,... Read More
Every organization which creates collaborative documents, whether they are budgets,... Read More
Let's say that you have a software project that's under... Read More
Now there are Three Steps To Heaven Just listen and... Read More
Microsoft bought Navision, Denmark based software development company, along with... Read More
Find out why Spyware Removal from computers is important and... Read More
Microsoft Great Plains is main accounting / ERP application... Read More
As of now - Great Plains Dynamics/eEnterprise is transformed/renamed into... Read More
Microsoft Business Solutions ? Great Plains is designed to meet... Read More
Microsoft Business Solutions Great Plains is marketed for mid-size companies... Read More
The fact that a software tester is a most infamous... Read More
A LOT OF UNWANTED FILES.When you uninstall an item of... Read More
Let us give you - developer some hints in the... Read More
Fortunately one of the most common reasons cited for the... Read More
One of the main reasons business owners and entrepreneurs use... Read More
If you use Microsoft Outlook (or similar applications) for e-mailing,... Read More
The intentions of this short tutorial are not to teach... Read More
It is possible that if one avoided all sources of... Read More
Microsoft Business Solutions Great Plains is marketed for mid-size companies... Read More
Document Management or Enterprise Information Management is perhaps one of... Read More
Introduction: The creating of a computer program involves a number... Read More
FTP stands for "file transfer protocol". FTP is basically a... Read More
Music downloads are off the charts! We're listening to digital... Read More
Sales are all about leverage, because there is only so... Read More
The most important things you can do for your computer... Read More
When you double-click a layer in the Layer Palette, you... Read More
When you own a small business, time is money. And... Read More
When it comes to screenplay software each screenwriter needs to... Read More
Microsoft Business Solutions Great Plains, former Great Plains Software Dynamics... Read More
I have always regretted how Microsoft price gouges and rips... Read More
While paper labeling CDs and DVDs may appear to be... Read More
Spyware is like the new technological nuclear weapon on the... Read More
As Mozilla Firefox nears 10% market share, with well over... Read More
What is Groupware?Have you ever had to manage document collaboration... Read More
What is Spyware?Spyware monitors your surfing habits and sends the... Read More
I love new technology. I am still ready to wait... Read More
We were recently faced with a decision: either to let... Read More
In the previous ISDN article, we looked at how and... Read More
Software |