Scratch that aside, I think I have that part working. It was a little 
gnarly because the datasource provider was written in Scala and posed a few 
potentially confusing interop problems, and I must have gotten it wrong on 
at least one account.

However, I'm still seeming to commit automatically.

On Friday, October 25, 2013 9:17:03 AM UTC-4, Mark wrote:
>
> That doesn't seem to work. Neither does explicitly setting :transaction? 
> to false. 
>
> Looking at the source of execute!, it looks like the statement is running 
> within a "with-open" on the java.sql.Connection, which is where a commit or 
> rollback would occur. I presume that the with-open is closing the 
> connection, which is resulting in a commit. Is there some way I can set 
> autocommit to false on the connection through the db-spec?
>
> Unrelated to this, I had earlier been trying to use a DataSource provider 
> that we have and wrap it with {:datasource ds}, which worked fine for 
> executing queries, but db-set-rollback-only! would throw a 
> NullPointerException (from reset!) if I created the data source that way. I 
> dug around in the source code a bit more, but didn't see immediately what 
> was going on - that being said, I'm not terribly familiar with how atoms 
> work in Clojure.
>
> Thanks for your help!
>
> Mark
>
> On Friday, October 25, 2013 2:10:18 AM UTC-4, Sean Corfield wrote:
>>
>> Remove :transaction? true from the delete! call. 
>>
>> You're telling delete! to run inside its own transaction - you don't 
>> want that: that's why your deletes do not rollback. 
>>
>> Sean 
>>
>> On Thu, Oct 24, 2013 at 2:03 PM, Mark <mjt...@gmail.com> wrote: 
>> > I've been working on a small utility script to clean up a very large 
>> table 
>> > (~1 billion rows). Because the table is so large, I want to go through 
>> and 
>> > delete it chunk at a time. I've written a simple script that does this, 
>> but 
>> > when I was testing it against our dev instance, I found that it wasn't 
>> > rolling back, as I'd hoped it would. 
>> > 
>> > You can see a simplified version of the script here: 
>> > 
>> > https://gist.github.com/anonymous/14ed57085709a2772ee0 
>> > 
>> > It's using an Oracle database (11GR1, I think) and clojure.java.jdbc 
>> version 
>> > 0.3.0-alpha5. I've dug through the clojure.java.jdbc docs and code, but 
>> I 
>> > don't see an obvious problem with what I'm doing, although I presume 
>> that to 
>> > someone who knows this library better, my problem is quite simple. 
>> > 
>> > Does anyone have any idea what I'm doing wrong? Can you point to an 
>> example 
>> > that issues deletes (or inserts, or updates) that rollback? 
>> > 
>> > Thanks! 
>> > Mark 
>> > 
>> > -- 
>> > -- 
>> > You received this message because you are subscribed to the Google 
>> > Groups "Clojure" group. 
>> > To post to this group, send email to clo...@googlegroups.com 
>> > Note that posts from new members are moderated - please be patient with 
>> your 
>> > first post. 
>> > To unsubscribe from this group, send email to 
>> > clojure+u...@googlegroups.com 
>> > For more options, visit this group at 
>> > http://groups.google.com/group/clojure?hl=en 
>> > --- 
>> > You received this message because you are subscribed to the Google 
>> Groups 
>> > "Clojure" group. 
>> > To unsubscribe from this group and stop receiving emails from it, send 
>> an 
>> > email to clojure+u...@googlegroups.com. 
>> > For more options, visit https://groups.google.com/groups/opt_out. 
>>
>>
>>
>> -- 
>> Sean A Corfield -- (904) 302-SEAN 
>> An Architect's View -- http://corfield.org/ 
>> World Singles, LLC. -- http://worldsingles.com/ 
>>
>> "Perfection is the enemy of the good." 
>> -- Gustave Flaubert, French realist novelist (1821-1880) 
>>
>

-- 
-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en
--- 
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to clojure+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/groups/opt_out.

Reply via email to