Jump to content
BushAl

FireDAC FDQuery Outer Join with fdUpdateSQL fails when Inserting Records

Recommended Posts

I have a FDQuery with a left join between a cost Centre Table (CC) and an Estimate Detail Table (ED) that can have multiple records for a CC. The select is below for ref. The application should allow the ED to be updated and inserted (at simplest in a string grid). The Query will successfully update records in the ED, but fails when trying to insert, stating "update affected [0] rows, while [1] was requested". So I tried adding a FDUpdateSQL linked to the Query and an OnUpdateRecord as follows but it gives exactly the same error (also shown below)

if (ARequest = arUpdate) and (ASender.FieldByName('EstDtl_ID').IsNull) then
 begin
   ARequest := arInsert;
 end;

If anyone has any tips on how to force an insert under this condition I would be very grateful.

Project Builder.exe raised exception class EFDDBEngineException with message '[FireDAC][Phys][FB]-312. Exact update affected [0] rows, while [1] was requested'.

select b.*, a.csc_id as refcsc_id, a.cscdsc as cscdsc, a.cstpls as refcstpls, a.gstinc as refgstinc, a.gstpct as refgstpct from csc a left join estdtl b on a.csc_id = b.csc_id and b.est_id = !est_id

 

Share this post


Link to post

When I understood you right, you have problems with inserting new records !?

 

How looks your "TFDUpdateSQL.InsertSQL" ?

Share this post


Link to post

The FDQuery SQL is select b.*, a.csc_id as refcsc_id, a.cscdsc as cscdsc, a.cstpls as refcstpls, a.gstinc as refgstinc, a.gstpct  as refgstpct from csc a left join estdtl b on a.csc_id = b.csc_id and b.est_id = !est_id so a fairly straightforward left out join (excuse the 3letter mnemonics)

 

The FDUpdateSQL insert statement is the one generated by FireDac and is:-

 

INSERT INTO ESTDTL
(CSC_ID, ESTDTLDSC, CSTPLS, GSTINC, GSTPCT,
  QTYCLC, QTY, CST, GST, SLE, VAL)
VALUES (:NEW_CSC_ID, :NEW_ESTDTLDSC, :NEW_CSTPLS, :NEW_GSTINC, :NEW_GSTPCT,
  :NEW_QTYCLC, :NEW_QTY, :NEW_CST, :NEW_GST, :NEW_SLE, :NEW_VAL)
RETURNING ESTDTL_ID

 

By default the FDQuery would try and update a query "record" consisting of a real left part and an completely null right part (other than the Est_ID which comes from a parameter in the FDQuery set when choosing the Estimate in a seperate combobox). But it failed with the "update affected [0] rows, while [1] was requested"  and did not insert the record in EstDtl.

 

So I then added the code shown in the original post in an  OnUpdateRecord event on the FDQuery, basically changing the ARequest from arUpdate to  arInsert if the right part is null. This actually inserts the record then fails with the same message. So maybe there is some way to suppress the message (ideally just in this case) but it all happens somewhere in the depths of livebindings...

 

Thanks for looking at this - my first time combining FireDac which seems very powerful and livebindings. I have normally used IBX components. In case its useful its connecting to a Firebird Database.

Al

Share this post


Link to post

In the query I would include the b.ESTDTL_ID to have a unique ID for "ESTTDL table" and in the insert I would set b.est_id to a proper value. What is the content if this est_id field? Can it be null?

Share this post


Link to post

And is this condition true on insert: 

if (ARequest = arUpdate) and (ASender.FieldByName('EstDtl_ID').IsNull) then

Normally it should be insert and not update for new record and the estdtl_id is not in the query, so that should raise an ecxception!?

 

Share this post


Link to post

And

ARequest := arInsert;

ARequest is no var parameter, so changing should have no affect!?

Share this post


Link to post

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

×