?
Solved

sql transaction in bash linux

Posted on 2011-03-02
6
Medium Priority
?
1,632 Views
Last Modified: 2012-05-11
Hi,
I have a function in shell script which executes sql statements.
I want to use transactions for it.

function()
{
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"?????????
0
Comment
Question by:pvinodp
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
6 Comments
 
LVL 1

Assisted Solution

by:RealRaven
RealRaven earned 400 total points
ID: 35017414
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.
0
 

Author Comment

by:pvinodp
ID: 35017567
hi raven
the function() contains multiple SQL statements.
0
 
LVL 68

Assisted Solution

by:woolmilkporc
woolmilkporc earned 200 total points
ID: 35017665
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

wmp
0
WordPress Tutorial 2: Terminology

An important part of learning any new piece of software is understanding the terminology it uses. Thankfully WordPress uses fairly simple names for everything that make it easy to start using the software.

 
LVL 1

Expert Comment

by:RealRaven
ID: 35020190
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.
0
 
LVL 3

Accepted Solution

by:
mwiercin earned 1400 total points
ID: 35027001
Hi,

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
NOW()
2011-03-03 13:20:13
CONNECTION_ID()
2865
NOW()
2011-03-03 13:20:14
CONNECTION_ID()
2865

Open in new window


Named pipes (mypipe being MySQL entry, outpipe - output).:
$ cat mypipe |  mysql  > outpipe &
[1] 17660
$ echo "SELECT NOW();" > mypipe; cat outpipe;
NOW()
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.).
0
 

Author Closing Comment

by:pvinodp
ID: 35065883
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;"
[/code]
0

Featured Post

Setting up LaraDock for Laravel

Learn how to set up LaraDock in a Laravel project - LaraDock gives us an easy way to run a Laravel application using Docker in a single command.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Utilizing an array to gracefully append to a list of EmailAddresses
In this series, we will discuss common questions received as a database Solutions Engineer at Percona. In this role, we speak with a wide array of MySQL and MongoDB users responsible for both extremely large and complex environments to smaller singl…
Connecting to an Amazon Linux EC2 Instance from Windows Using PuTTY.
Get a first impression of how PRTG looks and learn how it works.   This video is a short introduction to PRTG, as an initial overview or as a quick start for new PRTG users.
Suggested Courses

762 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question