Solved

Open RS with Parameterized Queries (using ? rather than Named parameters)

Posted on 2013-12-24
1
341 Views
Last Modified: 2013-12-24
I recently learned how to do Paramerized queries using '?' in the SQL and an array of variants for the Parameters.  But I can only figure out how to do this using ADODB.Connection object and an ADODB.Command object with a Command.Execute()

Example:
Cmd.Connection = Conn
Cmd.CommandText = "SELECT * FROM TABLE WHERE FIELD1 = ? AND FIELD2 = ?"
Set RS = Cmd.Execute(RecordsAffected,Array(10,"ABC"))

Open in new window

(where Array(10,"ABC") represents an Array of Variants the way the VBScript would)

But what I need to do is an RS.Open command where I can set properties of the Record Set such as CursorType and LockType.  For example, I'd logically like to do the following:
Cmd.CommandText = "SELECT * FROM TABLE WHERE FIELD1 = ? AND FIELD2 = ?"
Cmd.Parameters = Array(10,"ABC")
RS.Open(Cmd, adOpenDynamic, adLockPessimistic) 

Open in new window

But this is not valid code (you can not assign an array of variants to the Cmd Parameters).

Now I know how to accomplish this creating individual parameter objects and using named parameters in the SQL.  But that method seems to require that I define the data type for each parameter.  My situation is that I must convert a bunch of SQL commands to parameterized SQL commands in a program that I'm not familiar with and most field values are contained in variables (whos datatype isn't always apparent).

So I know I can take the time to look up each field in the database and determine how to create parameters for each field and use named parameters.

But I'd get things going much faster (with less room for mistakes in picking the wrong data types) if I could simply replace field values with '?' and pass in an array of variants for the parameters.

NOTE: I'm utilizing ADODB objects in a VB6 project.
0
Comment
Question by:HooKooDooKu
1 Comment
 
LVL 16

Accepted Solution

by:
HooKooDooKu earned 0 total points
ID: 39738464
I sort of figured it out.

I can still use '?' for the parameters and simply create individual Parameter objects that get appended to the Cmd object.  But to deal with the array of variants, I had to create a subroutine that looked at the VarType of the parameter and set the data type base on that.

Here's the code I'm using where I look through my Parameters stored in the array of variants names m_Parameters.
        Select Case VarType(m_Parameters(I))
            Case vbInteger Or vbLong
                Set P = m_objCmd.CreateParameter(, adInteger, adParamInput)
            Case vbDate
                Set P = m_objCmd.CreateParameter(, adDate, adParamInput)
            Case vbString
                Set P = m_objCmd.CreateParameter(, adBSTR, adParamInput)
                P.Size = Len(m_Parameters(I))
            Case vbSingle
                Set P = m_objCmd.CreateParameter(, adSingle, adParamInput)
            Case vbDouble
                Set P = m_objCmd.CreateParameter(, adDouble, adParamInput)
            Case vbCurrency
                Set P = m_objCmd.CreateParameter(, adCurrency, adParamInput)
            Case vbBoolean
                Set P = m_objCmd.CreateParameter(, adBoolean, adParamInput)
            Case vbByte
                Set P = m_objCmd.CreateParameter(, adTinyInt, adParamInput)
            Case Else
                m_Parameters(I) = ""
                Set P = m_objCmd.CreateParameter(, adBSTR, adParamInput)
                P.Size = 0
        End Select
        P.Value = m_Parameters(I)
        Call m_objCmd.Parameters.Append(P)

Open in new window

0

Featured Post

Optimizing Cloud Backup for Low Bandwidth

With cloud storage prices going down a growing number of SMBs start to use it for backup storage. Unfortunately, business data volume rarely fits the average Internet speed. This article provides an overview of main Internet speed challenges and reveals backup best practices.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Sub or Function is not defined 6 43
sql how to count case when 4 25
Problem to line 23 53
Sql query with where clause 2 33
Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
If you have heard of RFC822 date formats, they can be quite a challenge in SQL Server. RFC822 is an Internet standard format for email message headers, including all dates within those headers. The RFC822 protocols are available in detail at:   ht…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

808 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question