on 2014 Nov 04 4:36 PM
I use an application that connects to a SqlAnywhere 11 server/database by issuing the following command (taken from the ConsoleLogFile):
<,3,EXEC_IMM,START DATABASE 'database-file.DBF' AS
"database-name" USING DISTINCT SQLSTATE
Starting database "database-name" (database-file.DBF) at Tue Nov 04 2014 09:42
Database recovery in progress
Last checkpoint at Mon Sep 29 2014 13:05
Checkpoint log...
Transaction log: database-file.DBF.TLG...
Error: Cannot open transaction log file -- The system cannot find the file specified.
Recovery complete
E,3,-106,Cannot open transaction log file -- database-file.DBF.TLG
>.,3
<,3,DISCONNECT
Database "UTILITY_DB" (UTILITY_DB) stopped at Tue Nov 04 2014 09:42
>,3
I'd like to emulate the way the application issues the START DATABASE
command but can't figure out how to execute with EXEC_IMM
(I'm assuming this is EXECUTE IMMEDIATE
?) when logged into the UTILTIY_DB
as DBA
; I can only seem to execute with PREPARE
(e.g., <,3,EXEC_IMM,START DATABASE...
).
Most importantly I'd like to prevent a ROLLBACK
after the recovery. I tried starting the server and database with the -f
command, but it then complains about the database needing recovery.
So, how do I execute unprepared statements and/or prevent rollbacks on errors?
If the goal is to prevent a ROLLBACK of uncommitted transactions at the last time the database went down, the short answer is that you can't.
The long answer is that even if you could, you'd have to deal with potential database issues like check constraints and referential integrity (specifically if wait_for_commit is used). However, you may be able to regain some of this data by applying translated SQL for those uncommitted transactions against the database manually.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
If you believe you have a big transaction that didn't complete you could always pull out the details from the transaction log using the dbtran utility. See dbtran -s -a to get at the SQL (and then change the rollback to be a commit and resubmit after the database recovers.
User | Count |
---|---|
66 | |
11 | |
10 | |
10 | |
10 | |
8 | |
6 | |
5 | |
4 | |
4 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.