How do I find out why? Error 3251

  • Thread starter Thread starter .Len B
  • Start date Start date
L

.Len B

Here is a snippet of code which fails with error
3251: Operation is not supported for this type of object.

Set rstPay = db.OpenRecordset("Payments") 'open table 1 side
Set rstInv = db.OpenRecordset("Invoices") 'open table many side
rstPay.MoveFirst
rstInv.MoveFirst
With rstPay
Do Until .EOF
...
strRef = !Ref 'PK in Payments (same spelling FK in Invoices)
===> rstInv.FindFirst "Ref = " & strRef 'find first matching invoice
With rstInv
Do Until .EOF
...
Loop
End With
Loop
End With

I have used this construct to find the first match in a recordset many
times before but now I am at a loss to know where to look. Help says
method is usually valid but not in this case.

I have looked at help for OpenRecordset but this particular syntax is
not shown. I have to assume that the recordset has some default
attribute preventing finds but what is it? How do I find out?
(Access 2003)
 
Hi Len,

Assuming that you've defined and set db as a database object (and I'd expect
an error earlier if you hadn't), the obvious thing is that you need to
delimit strRef (I'm assuming from its name that it's declared as a String
variable), thus:
rstInv.FindFirst "Ref = '" & strRef & "'"

If Ref in Payments table is not a string (perhaps an autonumber), then you
need to declare the variable to match the datatype, perhaps:
Dim lngRef as Long
...
lngRef = !Ref 'PK in Payments (same spelling FK in Invoices)
rstInv.FindFirst "Ref = " & lngRef 'find first matching
...

HTH,

Rob
 
I cannot believe how stupid I am. The field Ref in both tables is Long
and here I am defining a string to refer to it !!! (AutoNum in Payments)
Set db was done earlier as were other Dims and assignments etc. eg
blnDisplayMsg = Me.chkDisplay

I changed to Dim lngRef as Long
and changed all occurrences of strRef to lngRef so that the code is as
you suggested. The code compiles without error.

HOWEVER, the error 3251 still persists.

--
Len
______________________________________________________
remove nothing for valid email address.
| Hi Len,
|
| Assuming that you've defined and set db as a database object (and I'd
expect
| an error earlier if you hadn't), the obvious thing is that you need to
| delimit strRef (I'm assuming from its name that it's declared as a
String
| variable), thus:
| rstInv.FindFirst "Ref = '" & strRef & "'"
|
| If Ref in Payments table is not a string (perhaps an autonumber), then
you
| need to declare the variable to match the datatype, perhaps:
| Dim lngRef as Long
| ...
| lngRef = !Ref 'PK in Payments (same spelling FK in Invoices)
| rstInv.FindFirst "Ref = " & lngRef 'find first matching
| ...
|
| HTH,
|
| Rob
|
|
| .Len B wrote:
| > Here is a snippet of code which fails with error
| > 3251: Operation is not supported for this type of object.
| >
| > Set rstPay = db.OpenRecordset("Payments") 'open table 1 side
| > Set rstInv = db.OpenRecordset("Invoices") 'open table many side
| > rstPay.MoveFirst
| > rstInv.MoveFirst
| > With rstPay
| > Do Until .EOF
| > ...
| > strRef = !Ref 'PK in Payments (same spelling FK in
Invoices)
| > ===> rstInv.FindFirst "Ref = " & strRef 'find first matching
| > invoice With rstInv
| > Do Until .EOF
| > ...
| > Loop
| > End With
| > Loop
| > End With
| >
| > I have used this construct to find the first match in a recordset
many
| > times before but now I am at a loss to know where to look. Help says
| > method is usually valid but not in this case.
| >
| > I have looked at help for OpenRecordset but this particular syntax is
| > not shown. I have to assume that the recordset has some default
| > attribute preventing finds but what is it? How do I find out?
| > (Access 2003)
|
|
 
Hi Len,

If Payments and Invoices are tables in your database (not linked tables),
then OpenRecordset will default to opening a table-type recordset, which
doesn't support the Findxxxx methods.

You can either use the Seek method on the Recordset as is, or force Access
to open Dynaset recordsets thus:
Set rstPay = db.OpenRecordset("Payments", dbOpenDynaset) 'open table 1 side
Set rstInv = db.OpenRecordset("Invoices", dbOpenDynaset) 'open table many side

Caveat: Tested in A2007 only, as I don't have A2003.

Hope this helps,
Alex.
 
I'm sorry Rob. I should have thanked you for your help.
My only excuse is that I was so overcome by the realisation
of my own stupidity that I forgot.

Thanks Rob.
--
Len
______________________________________________________
remove nothing for valid email address.
| Hi Len,
|
| Assuming that you've defined and set db as a database object (and I'd
expect
| an error earlier if you hadn't), the obvious thing is that you need to
| delimit strRef (I'm assuming from its name that it's declared as a
String
| variable), thus:
| rstInv.FindFirst "Ref = '" & strRef & "'"
|
| If Ref in Payments table is not a string (perhaps an autonumber), then
you
| need to declare the variable to match the datatype, perhaps:
| Dim lngRef as Long
| ...
| lngRef = !Ref 'PK in Payments (same spelling FK in Invoices)
| rstInv.FindFirst "Ref = " & lngRef 'find first matching
| ...
|
| HTH,
|
| Rob
|
|
| .Len B wrote:
| > Here is a snippet of code which fails with error
| > 3251: Operation is not supported for this type of object.
| >
| > Set rstPay = db.OpenRecordset("Payments") 'open table 1 side
| > Set rstInv = db.OpenRecordset("Invoices") 'open table many side
| > rstPay.MoveFirst
| > rstInv.MoveFirst
| > With rstPay
| > Do Until .EOF
| > ...
| > strRef = !Ref 'PK in Payments (same spelling FK in
Invoices)
| > ===> rstInv.FindFirst "Ref = " & strRef 'find first matching
| > invoice With rstInv
| > Do Until .EOF
| > ...
| > Loop
| > End With
| > Loop
| > End With
| >
| > I have used this construct to find the first match in a recordset
many
| > times before but now I am at a loss to know where to look. Help says
| > method is usually valid but not in this case.
| >
| > I have looked at help for OpenRecordset but this particular syntax is
| > not shown. I have to assume that the recordset has some default
| > attribute preventing finds but what is it? How do I find out?
| > (Access 2003)
|
|
 
Thanks Alex,
That appears to have done the trick; at least until my stupidity
sabotages me again.
--
Len
______________________________________________________
remove nothing for valid email address.


| Hi Len,
|
| If Payments and Invoices are tables in your database (not linked
tables),
| then OpenRecordset will default to opening a table-type recordset,
which
| doesn't support the Findxxxx methods.
|
| You can either use the Seek method on the Recordset as is, or force
Access
| to open Dynaset recordsets thus:
| Set rstPay = db.OpenRecordset("Payments", dbOpenDynaset) 'open table 1
side
| Set rstInv = db.OpenRecordset("Invoices", dbOpenDynaset) 'open table
many side
|
| Caveat: Tested in A2007 only, as I don't have A2003.
|
| Hope this helps,
| Alex.
|
|
| ".Len B" wrote:
|
| > Here is a snippet of code which fails with error
| > 3251: Operation is not supported for this type of object.
| >
| > Set rstPay = db.OpenRecordset("Payments") 'open table 1 side
| > Set rstInv = db.OpenRecordset("Invoices") 'open table many side
| > rstPay.MoveFirst
| > rstInv.MoveFirst
| > With rstPay
| > Do Until .EOF
| > ...
| > strRef = !Ref 'PK in Payments (same spelling FK in
Invoices)
| > ===> rstInv.FindFirst "Ref = " & strRef 'find first matching
invoice
| > With rstInv
| > Do Until .EOF
| > ...
| > Loop
| > End With
| > Loop
| > End With
| >
| > I have used this construct to find the first match in a recordset
many
| > times before but now I am at a loss to know where to look. Help says
| > method is usually valid but not in this case.
| >
| > I have looked at help for OpenRecordset but this particular syntax is
| > not shown. I have to assume that the recordset has some default
| > attribute preventing finds but what is it? How do I find out?
| > (Access 2003)
| > --
| > Len
| > ______________________________________________________
| > remove nothing for valid email address.
| >
| >
| > .
| >
 
.Len B said:
Here is a snippet of code which fails with error
3251: Operation is not supported for this type of object.

Set rstPay = db.OpenRecordset("Payments") 'open table 1 side
Set rstInv = db.OpenRecordset("Invoices") 'open table many side
rstPay.MoveFirst
rstInv.MoveFirst
With rstPay
Do Until .EOF
...
strRef = !Ref 'PK in Payments (same spelling FK in Invoices)
===> rstInv.FindFirst "Ref = " & strRef 'find first matching invoice
With rstInv
Do Until .EOF
...
Loop
End With
Loop
End With

I have used this construct to find the first match in a recordset many
times before but now I am at a loss to know where to look. Help says
method is usually valid but not in this case.

I have looked at help for OpenRecordset but this particular syntax is
not shown. I have to assume that the recordset has some default
attribute preventing finds but what is it? How do I find out?
(Access 2003)
 
Back
Top