Lazarus
Home
Help
TinyPortal
Search
Login
Register
Lazarus
»
Forum
»
Programming
»
Databases
»
Operation cannot be performed on an active dataset
Free Pascal
Website
Downloads
Wiki
Documentation
Bugtracker
Mailing List
Lazarus
Website
Downloads (Laz+FPC)
Packages (OPM)
FAQ
Wiki
Documentation (RTL/FCL/LCL)
Bugtracker
CCR Bugs
IRC channel
GIT
Mailing List
Other languages
Foundation
Website
Useful Wiki Links
Project Roadmap
Getting the Source
Screenshots
How to use the forum
About donations (wiki)
Bookstore
Computer Math and Games in Pascal
(preview)
Lazarus Handbook
Search
Advanced search
Recent
Poll: Watches and Display...
by
440bx
[
Today
at 07:13:51 pm]
Lazarus for Windows on aa...
by
msintle
[
Today
at 06:42:18 pm]
InstallAware Using Lazaru...
by
marcov
[
Today
at 04:46:46 pm]
Who is Indy mattias?
by
paweld
[
Today
at 04:17:53 pm]
[solved] how to get class...
by
Joanna
[
Today
at 03:53:05 pm]
I just released a commerc...
by
BrassGear
[
Today
at 03:17:28 pm]
Does anyone know why thes...
by
Laksen
[
Today
at 03:04:14 pm]
Database standards OR Am ...
by
gidesa
[
Today
at 02:37:56 pm]
How to: create DLL file f...
by
TRon
[
Today
at 02:26:53 pm]
A fairly simple sound sol...
by
paweld
[
Today
at 01:46:11 pm]
Demoscene The Champs Crac...
by
KodeZwerg
[
Today
at 01:45:18 pm]
Access violation when ope...
by
Чебурашка
[
Today
at 12:27:34 pm]
Step-into the field sette...
by
Martin_fr
[
Today
at 11:31:48 am]
Access violation when re-...
by
Chris Osborne
[
Today
at 11:31:25 am]
AI, NLP and CAI: Text Gen...
by
Dzandaa
[
Today
at 11:03:26 am]
dwindows for Android
by
PierceNg
[
Today
at 10:54:44 am]
create system unit from s...
by
Laksen
[
Today
at 10:53:57 am]
[Solved] Find child contr...
by
Joanna
[
Today
at 09:53:43 am]
FpDebug unexpected Assemb...
by
Marc
[
Today
at 08:46:38 am]
Offical launch of the 1 B...
by
Handoko
[
Today
at 07:59:07 am]
Big Numbers Math
by
iLya2IK
[
Today
at 07:13:20 am]
BUG REPORT: Unable to gen...
by
dbannon
[
Today
at 06:29:49 am]
what to do if my target M...
by
Laksen
[
Today
at 12:49:12 am]
For-in loop over constant...
by
ASerge
[
Today
at 12:36:09 am]
Converting a string/index...
by
TRon
[April 18, 2024, 11:56:37 pm]
« previous
next »
Print
Pages: [
1
]
Author
Topic: Operation cannot be performed on an active dataset (Read 2865 times)
martinrame
Full Member
Posts: 119
Operation cannot be performed on an active dataset
«
on:
June 22, 2018, 12:29:59 am »
Hi, I'm trying to do a Select, loop through its records, then call a procedure to update each record, but I'm getting "Operation cannot be performed on an active dataset".
I wonder why this error, since my "UpdateRecords" procedure creates a new TSqlQuery instance.
Here's my code:
Code: Pascal
[Select]
[+]
[-]
Procedure
ListRecords
;
var
lSql
:
TSqlQuery
;
id
:
Integer
;
begin
lSql
:
=
TSqlQuery
.
Create
(
nil
)
;
try
lSql
.
DataBase
:
=
DataModule1
.
PQConnection1
;
lSql
.
SQL
.
Text
:
=
'select * from table'
;
lSql
.
Open
;
while
not
lSql
.
Eof
do
begin
id
:
=
lSql
.
FieldByName
(
'id'
)
.
AsInteger
;
UpdateRecord
(
id
)
;
lSql
.
Next
;
end
;
finally
lSql
.
Free
;
end
;
end
;
Procedure
UpdateRecords
(
Id
:
Integer
)
;
var
lSql
:
TSqlQuery
;
begin
lSql
:
=
TSqlQuery
.
Create
(
nil
)
;
try
lSql
.
DataBase
:
=
DataModule1
.
PQConnection1
;
lSql
.
Transaction
:
=
DataModule1
.
SqlTransaction1
;
lSql
.
SQL
.
Text
:
=
'update table set read=true where id=:id'
;
lSql
.
ParamByName
(
'id'
)
.
AsInteger
:
=
id
;
lSql
.
ExecSql
;
DataModule1
.
SqlTransaction1
.
Commit
;
finally
lSql
.
Free
;
end
;
end
;
«
Last Edit: June 22, 2018, 02:06:15 pm by martinrame
»
Logged
valdir.marcos
Hero Member
Posts: 1106
Re: Operation cannI t be performed on an active dataset
«
Reply #1 on:
June 22, 2018, 05:16:10 am »
Why are you slowly updating all that on the client side instead of using the faster server side?
Code: SQL
[Select]
[+]
[-]
UPDATE
TABLE
SET
READ
=
TRUE
WHERE
id
IN
(
SELECT
id
FROM
TABLE
WHERE
condition
=
:condition
)
;
«
Last Edit: June 22, 2018, 05:34:23 am by valdir.marcos
»
Logged
martinrame
Full Member
Posts: 119
Re: Operation cannI t be performed on an active dataset
«
Reply #2 on:
June 22, 2018, 02:01:43 pm »
This is an example, not real code.
Inside my ListRecords function I do many more operations (that cannot be done in the database) than just updating records from the same table.
Logged
martinrame
Full Member
Posts: 119
Re: Operation cannot be performed on an active dataset
«
Reply #3 on:
June 22, 2018, 02:11:03 pm »
Sorry, the error does not comes from this code, but from a nested query I'm doing against an SQLServer Database.
I'll try to isolate it, then come bak.
Logged
martinrame
Full Member
Posts: 119
[SOLVED] Re: Operation cannot be performed on an active dataset
«
Reply #4 on:
June 22, 2018, 02:18:12 pm »
The solution was NOT commiting inside the nested procedure (the one tha does .ExecSQL), but commiting when the main loop ends.
Logged
rvk
Hero Member
Posts: 6163
Re: Operation cannot be performed on an active dataset
«
Reply #5 on:
June 22, 2018, 02:19:59 pm »
My guess is that DataModule1.SqlTransaction1 is also connected to the query in ListRecords (via the database connection in DataModule1). Committing that transaction will also close the query in ListRecords.
You need to re-think the flow or set the correct parameter for the transaction that it will not close the queries automatically. Rethinking the flow is the better choice. Maybe use a separate transaction in UpdateRecords().
Edit: Ah, you already found it
Logged
Print
Pages: [
1
]
« previous
next »
Lazarus
»
Forum
»
Programming
»
Databases
»
Operation cannot be performed on an active dataset
TinyPortal
© 2005-2018