sql transaction in bash linux

I have a function in shell script which executes sql statements.
I want to use transactions for it.

Begin transaction # i want SQL equivalent of this in shell scripting

source /etc/ipaccess/omcr-server/ipaccess-omcr;
mysql -u${MYSQL_ROOT_USER} -p${MYSQL_ROOT_PASSWORD} -e "Delete from omcr.AlarmNotification where alarmLifecycleId=50;"
commit transaction # i want SQL equivalent of this in shell scripting

How to execute the lines for "Begin transaction" and "commit"?????????
Who is Participating?

Improve company productivity with a Business Account.Sign Up

mwiercinConnect With a Mentor Commented:

The simplest way would be to concatenate all the queries together delimited with semi colon (you can also USE mysql's DELIMITER keyword to  change it).  You can use a temp file for doing so, or combine use of SOURCE  command, i.e.

$ mysql -u${MYSQL_ROOT_USER} -p${MYSQL_ROOT_PASSWORD} -e "BEGIN; SOURCE /etc/ipaccess/omcr-server/ipaccess-omcr; Delete from omcr.AlarmNotification where alarmLifecycleId=50; COMMIT;"

Open in new window

If you want to maintain more control over execution, (named) pipes would be the way to go.

One way communication using a pipe:

$ (echo "SELECT NOW(); SELECT CONNECTION_ID(); "; sleep 1; echo "SELECT NOW();SELECT CONNECTION_ID();" ) | mysql
2011-03-03 13:20:13
2011-03-03 13:20:14

Open in new window

Named pipes (mypipe being MySQL entry, outpipe - output).:
$ cat mypipe |  mysql  > outpipe &
[1] 17660
$ echo "SELECT NOW();" > mypipe; cat outpipe;
2011-03-03 13:30:03
[1]+  Done                    cat mypipe | mysql > outpipe

Open in new window

You can also use socat in similar manner as above.

I don't recommend making it too complicated as handling both output and input  streams in bash will mean that you are effectively implementing your own database driver, thus if you need more control it's better to use a proper driver (mean switch to Perl/PHP/Python/Ruby etc.).
RealRavenConnect With a Mentor Commented:
Sorry, I don't think that is possible. Each connection to mysql will loose it's transactions on disconnect and it's not possible to first start a transaction, then connect again and do something and then connect a third time and do commit or rollback.

But if your example is complete and all you want to do is run ONE delete you'll have an automatic transaction around it whether you like it or not.
pvinodpAuthor Commented:
hi raven
the function() contains multiple SQL statements.
Get expert help—faster!

Need expert help—fast? Use the Help Bell for personalized assistance getting answers to your important questions.

woolmilkporcConnect With a Mentor Commented:
You could put all your statements (including begin/commit) into a textfile to be read by mysql, like

mysql -u${MYSQL_ROOT_USER} -p${MYSQL_ROOT_PASSWORD} < /text/file

As woolmilkporc points out a script file is always possible but it doesn't look like a good solution in this case.

You would have to write to a temporary file, send that to mysql and then delete it. It's possible but not pretty.
pvinodpAuthor Commented:
Thanks all.
Finally i did put in the solution by mwiercin :

$ mysql -u${MYSQL_ROOT_USER} -p${MYSQL_ROOT_PASSWORD} -e "BEGIN; SOURCE /etc/ipaccess/omcr-server/ipaccess-omcr; Delete from omcr.AlarmNotification where alarmLifecycleId=50; COMMIT;"
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.