Collectives™ on Stack Overflow

Find centralized, trusted content and collaborate around the technologies you use most.

Learn more about Collectives

Teams

Q&A for work

Connect and share knowledge within a single location that is structured and easy to search.

Learn more about Teams

Exception opening TAdoDataset: Arguments are of the wrong type, are out of acceptable range, or are in conflict with one another

Ask Question

I've been trying to debug the following problem for several weeks now - this method is called from several places within the same datamodule, but this exception (from the subject line of this post) only occurs when integers for a certain purpose (pickup orders vs. orders that we ship through a carrier) are used - and don't ask me how the application can tell the difference between one integer's purpose and another! Furthermore, I cannot duplicate this issue on my machine - the error occurs on a warehouse machine but not my own development machine, even when working with the same production database. I have suspected an MDAC version conflict between the two machines, but have run a version checker and confirmed that both machines are running 2.8, and additionally have confirmed this by logging the TAdoDataset's .Version property at runtime.

function TdmESShip.SecondaryID(const PrimaryID : Integer ): String;
begin
      with qESPackage2 do
        begin
          if Active then
              Close;
          LogMessage('-----------------------------------');
          LogMessage('Version: ' + FConnection.Version);
          LogMessage('DB Info: ' + FConnection.Properties['Initial Catalog'].Value + ' ' +      FConnection.Properties['Data Source'].Value);
          LogMessage('Setting the parameter.');
          Parameters.ParamByName('ParameterName').Value := PrimaryID;
          LogMessage('Done setting the parameter.');
        Open;

Ninety-nine times out of 100 this logging code logs a successful operation as follows: Version: 2.8 DB Info: (database name and instance)

Setting the parameter.

Done setting the parameter.

Opened the dataset. But then whenever a "pickup" order is processed, this exception gets thrown whenever the dataset is opened: Version: 2.8

DB Info: (database name and instance)

Setting the parameter.

Done setting the parameter.

GetESPackageID() threw an exception. Type: EOleException, Message: Arguments are of the wrong type, are out of acceptable range, or are in conflict with one another Error: Arguments are of the wrong type, are out of acceptable range, or are in conflict with one another for packageID 10813711 I've tried eliminating the parameter and have built the commandtext for this dataset programmatically, suspecting that some part of the TParameter's configuration might be out of whack, but the same error occurs under the same circumstances. I've tried every combination of TParameter properties that I can think of - this is the millionth TParameter I've created for my millionth dataset, and I've never encountered this error. I've even created a second dataset from scratch and removed all references to the original dataset in case some property of the original dataset in the .dfm might be corrupted, but the same error occurs under the same circumstances. The commandtext for this dataset is a simple

select ValueA from TableName where ValueB = @ParameterB

I'm about ready to do something extreme, such as writing a web service to look these values up - it feels right now as though I could destroy my machine, rebuild it, rewrite this entire application from scratch, and the application would still know to throw an exception whenever I try to look up a secondary value from a primary value, but only for pickup orders, and only from the one machine in the warehouse, but I'm probably missing something simple. So, any help anyone could provide would be greatly appreciated.

I discovered that the users of this software are given the option to print a document, and that if the print dialog is ever displayed, whether a document is printed or not, the opening of this dialog is what causes the later exception opening the TAdoDataset. However, I could find no logical correlation between the two actions, even though the causation seemed to be 100% reliable. I have since transferred departments, but left with the suspicion that perhaps the underlying windows function for the printer dialog might have been invoked incorrectly, leaving something in an inconsistent state. – user74754 Sep 27, 2010 at 14:34 This message "Arguments are of the wrong type, are out of acceptable range, or are in conflict with one another" is a standard OLE error message code that can be returned from ADO when some option is invalid, and the OLE/COM method returns this standard failure code. – Warren P Aug 24, 2011 at 15:27 I should amend this plea for help to mention that I now am completely out of working in Delphi, so my chances of personally resolving this issue are gone now. Most of my organization's existing Delphi code base is soon to be ported to .NET. Thanks everyone! – user74754 Sep 13, 2011 at 21:30

Searching CodeGear/Embarcadero newsgroups I was only able to find that error related to setting/using the Filter property. I would search the project looking for anything setting the component's Filter property and check if the component is bound to any UI controls that could indirectly set the filter property (ex. DevExpress's TcxGrid, Infopower's Filter dialog, etc)

Another suggestion is to wrap opening of the dataset in a disable/enablecontrols. If the dataset is bound to a UI control, the control should not attempt to apply any actions (applying a filter) that could cause an exception.

function TdmESShip.GetESPackageID(const PackageID : Integer): String;
  ESPackageID :string; // for debugging
begin
  with qESPackage do
      begin
         ESPackageID := '';
         DisableControls();
               Parameters.ParamByName('PackageID').Value := PackageID;
               Open();
               if NOT(IsEmpty()) then
                 begin
                    ESPackageID := qESPackageESPackageID.AsString;
               Close();  // No need to keep open
            except
               on E:Exception do
                  begin
                     ESPackageID := '9999999'; // ex. return a known bogus value
                     // log the error, re-raise a more meaningful error, etc
         finally
            EnableControls();
            Result := ESPackageID;

Good luck

You need to determine whether the error is coming from your application, or the underlying database. Write a small executable that does nothing but execute the literal SQL command (with the parameter value hard-coded into the SQL) and see if that will run on the work station that's giving you the problem.

I find that ADO returns a message about a parameter not having a default value when I send a command with a bad column name to MS Access. The error message is not especially helpful in that context. To debug this kind of error I log the actual SQL that's getting sent to the database and then cut and paste it into Access or some other console-type routine to see whether the SQL itself is at fault.

I had a similar issue with ADO + MySQL under Delphi 2009. The problem was with a TDateTime field which was required (NOT NULL) as per the table rules. MySQL accept the dummy date '0000-00-00 00:00:00' as a non-null value and ADO does not recognise this date/time value. The error returned was similar to yours (IIRC it was speaking about out of range value).

It's not the same thing as what's you are experiencing, but it might help you track the problem you have.

Good luck!

I have also faced the same problem when using MySql with ODBC driver in Delphi XE. The error pops up from InternalRefresh of the dataset. I have created a workaround, when ever we create a new connection object and apply to the query object, the error does not come. Try creating new connection object and check. I haven't checked much about this behavior, but it has solved the problem for me.

For reference, my query was

INSERT INTO USERS (UserId, Password, Created_at) Values (:UID, :PWD, :CAT)

When ever i assign this statement to the query object (TADOQuery), i get the same error, but with a new connection it works.

Hope this might help.

Thanks for contributing an answer to Stack Overflow!

  • Please be sure to answer the question. Provide details and share your research!

But avoid

  • Asking for help, clarification, or responding to other answers.
  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.