Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations IamaSherpa on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

error '80020009' Exception occurred

Status
Not open for further replies.

doldol

MIS
Nov 25, 2001
214
SG
error '80020009'
Exception occurred.
/xxxxx/xxxxxxxxx/xxxx.asp, line 299

Any experts out there knows any solution?

 
SYMPTOMS
The following error occurs when accessing a recordset in an Active Server Pages (ASP) file that contains "Text" or "Blob" type data from a SQL table:

Microsoft OLE DB Provider for ODBC Drivers error '80020009'



CAUSE
The following condition may cause the error to occur:

Text/Blob fields are selected in an order preceding other types of fields.



RESOLUTION
When dealing with BLOB fields from SQL Server, you need to put them to the right of non-BLOB columns in the resultset. To be safe, you should also read the columns in left-to-right order, so if you have two BLOB columns as the last two columns in your resultset, read the first one and then the second. Do not read them in the reverse order.

To demonstrate the correct order of field selection create a new ASP page in a Visual InterDev Project and paste the following code in the blank ASP page:


<%@ Language=VBScript %>
<HTML>
<BODY bgcolor=white>
<%
Set cn = Server.CreateObject(&quot;ADODB.Connection&quot;)
Set rs = Server.CreateObject(&quot;ADODB.Recordset&quot;)

'Open the connection.
cn.Open &quot;dsn=yoursystemdsn;uid=sa;pwd=;database=pubs;&quot;

'Open the recordset.

'Notice that the Blob field, pr_info, is last in the field order.

rs.Open &quot;select pub_id, pr_info from pub_info&quot;, cn

While Not rs.EOF

Response.Write &quot;<P>PR Info:<P>&quot; & rs(&quot;pr_info&quot;)
Response.Write &quot;<P>That was the PR Info for PubID &quot; &
rs(&quot;pub_id&quot;)
rs.MoveNext
Wend
%>
</BODY>
</HTML>



STATUS
This behavior is by design. However, it does not seem to occur when using Mdac 2.1sp2 with the 3.7 driver for SQL Server and Microsoft Visual Interdev 6.0 sp3.



MORE INFORMATION
SQL Server is sending back the data on the wire and the client is essentially receiving a stream of bits read sequentially on the network wire. With bound columns (that is, the values can be copied into local memory buffers and cached there), the driver transfers data in those columns to memory buffers. Once the data is in local buffers, you may read the data in any order. Therefore, you can read result columns in any order when all the columns are bound (not BLOBs).

When you include BLOB columns, the length of the column can be approximately 2 gigabytes and data access libraries typically do not bind those columns since the driver often cannot determine exactly how large the BLOB is until retrieved. Also, data access libraries typically avoid caching BLOB data since this may consume large amounts of memory and caching it both in the data access library and your application is inefficient. If the data access driver is requested to return the contents of a BLOB column, it typically discards non-bound columns that precede the requested BLOB column, since it must retrieve the sequential data stream before it can read the requested column. Therefore, it is more efficient to read your resultset from left-to-right since that matches the way the data is retrieved.

Note that this describes the behavior of SQL Server. Oracle and other client/server DBMSs may do the same thing, but it is not required.

Perhaps a better alternative is to avoid using a Text column. Because SQL Server allocates space in 2K chunks, using Text columns may result in inefficient use of storage if the text length is very small. Backup time is also affected because it takes longer to dump the transaction log. It is often better to create another table that has the PK of your existing table, a chunk number column, and a varchar (255) column. Divide the text into as many 255 character chunks needed and insert as many rows in the new table as there are chunks. It is usually worth the additional coding time since you make more efficient use of storage and backups go much faster.

Additional query words:

AL Almeida
NT/DB Admin
&quot;May all those that come behind us, find us faithfull&quot;
 
Thank you, Almeida.

'Cause my user didn't care it to be fixed, there was no chance to know what the rootcause was. Only I found it was something wrong in database of the server side.

Though your script is difficult to understand, thank you very much for your effort!!
[medal]
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top