Guest_imported
New member
- Jan 1, 1970
- 0
Hello
Im just reading up on using Transaction Tables in the InnoDB format, but am having problems.
In the MySQL command line I do the following:
connect mydatabase;
begin;
SELECT * FROM mytable FOR UPDATE;
Then within another terminal window I enter:
connect mydatabase;
begin;
SELECT * FROM mytable FOR UPDATE;
In this second terminal window, MySQL waits until "commit;" has been entered into the first terminal window. So far so good.
But then within PHP I setup the following (simplified):
<?PHP
$thisdb=@mysql_connect("localhost","",""
if (!@mysql_select_db("mydatabase",$thisdb)){
exit ("Error: Unable to connect to the database."
}
mysql_query("BEGIN"
mysql_query("SELECT * FROM mytable FOR UPDATE"
print ("I could have printed the results here"
<form submit button here to stop program continuing, and when submit selected commit command is issued>
?>
I open two browser windows, and access the php file from the first, and as expected it prints "I could have printed the results here".
BUT when I access the same PHP file from the second browser window it still prints the text, I would have expected it to pause at the Mysql_query command until the first browser's submit button was pressed.
What I am trying to do is to display some data on screen, and allow the person to select which ones they want to delete (via checkboxes). But I'm trying to lock the database rows that are affected so when they continue the rows haven't, say, been deleted by someone else.
Andrew Blee.
Im just reading up on using Transaction Tables in the InnoDB format, but am having problems.
In the MySQL command line I do the following:
connect mydatabase;
begin;
SELECT * FROM mytable FOR UPDATE;
Then within another terminal window I enter:
connect mydatabase;
begin;
SELECT * FROM mytable FOR UPDATE;
In this second terminal window, MySQL waits until "commit;" has been entered into the first terminal window. So far so good.
But then within PHP I setup the following (simplified):
<?PHP
$thisdb=@mysql_connect("localhost","",""
if (!@mysql_select_db("mydatabase",$thisdb)){
exit ("Error: Unable to connect to the database."
}
mysql_query("BEGIN"
mysql_query("SELECT * FROM mytable FOR UPDATE"
print ("I could have printed the results here"
<form submit button here to stop program continuing, and when submit selected commit command is issued>
?>
I open two browser windows, and access the php file from the first, and as expected it prints "I could have printed the results here".
BUT when I access the same PHP file from the second browser window it still prints the text, I would have expected it to pause at the Mysql_query command until the first browser's submit button was pressed.
What I am trying to do is to display some data on screen, and allow the person to select which ones they want to delete (via checkboxes). But I'm trying to lock the database rows that are affected so when they continue the rows haven't, say, been deleted by someone else.
Andrew Blee.