Bug #30547 MyODBC 3 / ADO - Returning double the field size for blob types - regression
Submitted: 21 Aug 2007 21:26 Modified: 13 Sep 2007 11:34
Reporter: Erica Moss Email Updates:
Status: Closed Impact on me:
None 
Category:Connector / ODBC Severity:S2 (Serious)
Version:3.51.19 OS:Windows (XP sp2)
Assigned to: Jim Winstead CPU Architecture:Any
Tags: ADO definedSize blob

[21 Aug 2007 21:26] Erica Moss
Description:
According to our manual these are the capacities of the blob types.  In 3.51.17 this is what was reported as the field size in the ADO.Field.DefinedSize property.  After this point the size is being reported as twice these values:

BLOB 	L + 2 bytes, where L <  2^16
MEDIUMBLOB L + 3 bytes, where L < 2^24

in .17
blob DefinedSize = 65535
mediumblob DefinedSize = 16777215
longblob DefinedSize = -1 (overflow)

Currently:
blob DefinedSize = 131070
medblob DefinedSize = 33554430
longblob DefinedSize = -2 (overflow again)

How to repeat:
Setup:
CREATE TABLE defsize (C1 INT PRIMARY KEY, C2 BLOB, C3 MEDIUMBLOB, C4 LONGBLOB);
INSERT INTO defsize VALUES (1, 'blob', 'medblob', 'longblob');

VB CODE:
Private Sub DefSizeTest()
    On Error GoTo EH
    Dim strSQL, strConn As String
    Dim connection1 As adodb.Connection
    Dim recset1 As adodb.Recordset
    Dim fld As Field

    Set connection1 = New adodb.Connection
    Set recset1 = New adodb.Recordset

    strSQL = "SELECT * FROM defsize"
                
    strConn = "DRIVER={MySQL ODBC 3.51 Driver};" & _
        "SERVER=localhost;DATABASE=ado" & _
        ";USER=root;PASSWORD=mypass;OPTION=3;"
        
    ' open connection
    connection1.ConnectionString = strConn
    connection1.CursorLocation = adUseClient
    connection1.Open
    
   ' open recordset
    recset1.Open strSQL, connection1, adOpenStatic, adLockOptimistic, adCmdText
        
    For Each fld In recset1.Fields
        Debug.Print fld.Name & " " & fld.Type & " " & fld.DefinedSize
    Next
                
    recset1.Close
    Set recset1 = Nothing
    connection1.Close
    Set connection1 = Nothing
    Exit Sub
EH:
    Debug.Print Err.Number & ":" & Err.Description
    recset1.Close
    Set recset1 = Nothing
    connection1.Close
    Set connection1 = Nothing
End Sub
[25 Aug 2007 23:19] Kent Boortz
This seems to be caused by a change for bug#27862.
If the character set is "binary" the size returned
is doubled.

The call to SQLDescribeCol() in "result.c" calls
get_column_size() in "utility.c" that contains

  case MYSQL_TYPE_TINY_BLOB:
  case MYSQL_TYPE_MEDIUM_BLOB:
  case MYSQL_TYPE_LONG_BLOB:
  case MYSQL_TYPE_BLOB:
  case MYSQL_TYPE_GEOMETRY:
    if (field->charsetnr == 63)
      return length * 2;
    else
      return length / mbmaxlen;
  }
[4 Sep 2007 19:49] Jim Winstead
Fix reported value of column size for binary fields

Attachment: bug30547.patch (text/plain), 4.22 KiB.

[5 Sep 2007 18:45] Jim Winstead
The fix for this bug has been committed to the repository, and will be included in the next release (3.51.20).
[13 Sep 2007 11:34] MC Brown
A note has been added to the .3.51.20 changelog: 

The wrong column size was returned for binary data.