Solved

sql transaction in bash linux

Posted on 2011-03-02
6
1,588 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 100 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 50 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
Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

 
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 350 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

Upcoming Webinar: Securing your MySQL/MariaDB data

Join Percona’s Chief Evangelist, Colin Charles as he presents Securing your MySQL®/MariaDB® data on Tuesday, July 11, 2017 at 7:00 am PDT / 10:00 am EDT (UTC-7).

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
This post looks at MongoDB and MySQL, and covers high-level MongoDB strengths, weaknesses, features, and uses from the perspective of an SQL user.
Learn how to find files with the shell using the find and locate commands. Use locate to find a needle in a haystack.: With locate, check if the file still exists.: Use find to get the actual location of the file.:
In a recent question (https://www.experts-exchange.com/questions/29004105/Run-AutoHotkey-script-directly-from-Notepad.html) here at Experts Exchange, a member asked how to run an AutoHotkey script (.AHK) directly from Notepad++ (aka NPP). This video…

726 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