Jump to content

More help needed with microsoft access


JAKO

Recommended Posts

Hi... I just want to know is there a php command that can transform a word from a phrase into another word... For example in one of my column from one of my database... I have a phrase with two words... (example John Wayne)... Is there any command that can be used to tell that whenever there is a word John in my column (example: John Wayne, John Travolta, etc) it will automatically change the word John to Johnny.... Can somebody help me?????

Link to comment
Share on other sites

Thanks for the reply..... Example below is a name column from my microsoft access table... Do we have a php code that can change the first name from John to Johnny while maintaining the last name....??? Could somebody please help me....

 

----------------------------------------

|              Name                                |

----------------------------------------

|        John Wilkinson                          |

|        John Abraham                          |

|        John Graham                            |

|        Johnny Wayne                          |

----------------------------------------

Link to comment
Share on other sites

Try

 

$Look = mysql_query("SELECT * FROM `Table` WHERE `Name` REGEXP 'John'");

 

while($Search = mysql_fetch_array($Look))

{

$Temp = str_replace('John', 'Johnny', $Search['Name']);

$ID = $Search['RowID'];

mysql_query("UPDATE `Table`

SET `Name`='$Temp'

WHERE `RowID`='$ID'");

}

Link to comment
Share on other sites

Hi... I tried this but I got error....  Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in D:\xampp\htdocs\testis2.php on line 21... Could Sombeody help me?????

 

<?

//sambung ke database microsoft access

$dbc=odbc_connect("guestbook","","");

if (!$dbc)

{exit("Connection Failed: ".$dbc);}

$query="SELECT * FROM comments";

$rs=odbc_exec($dbc,$query);

if(!$rs)

{exit("Error in SQL");}

echo '<h3>MS Access Powered Guest Book</h3>';

while(odbc_fetch_row($rs))

{

$e_name=odbc_result($rs,"name");

$comment=odbc_result($rs,"comment");

$e_date=odbc_result($rs,"entry_date");

 

// Tukar perkataan

 

$Look = mysql_query("SELECT * FROM `comments` WHERE `name` REGEXP 'John'");

 

while($Search = mysql_fetch_array($Look))

{

$Temp = str_replace('John', 'Johnny', $Search['name']);

$ID = $Search['RowID'];

mysql_query("UPDATE `comments`

SET `name`='$Temp'

WHERE `RowID`='$ID'");

}

 

//tukar lowercase ke uppercase

$str_name = $Temp;

$str_name = strtoupper($Temp);

 

$str_comment = $comment;

$str_comment = strtoupper($str_comment);

 

$str_date = $e_date;

$str_date = strtoupper($str_date);

 

 

 

 

// display database

echo '<b>Name:</b>'.$str_name.'<br>';

 

echo '<b>Comments</b>'.$str_comment.'<br /> <b>Date:</b>'.$str_date.'<br />

<hr/>';

}

odbc_close($dbc);

echo"</table>"

 

?>

Link to comment
Share on other sites

That's because they're giving you MySQL functions when you're using Access. To be honest, I've not touched Access in quite a while so I'm a little rusty with the SQL capability. Do some reasearch on Google and see what kind of string replacement functions are available, then perform an update like shown below - if possible with Access. You can use odbc_exec to perform queries.

Link to comment
Share on other sites

You're extracting and looping through the data, using PHP to replace the text, then updating each row seperately. Waste of resources when you can achieve the same result with just one simple update query.

Link to comment
Share on other sites

Thank you for all of your opinion...  This is what I have managed so far.... It still got some errors...

 

This is a sample of my php....

 

<?

//to connect with the Microsoft Access Database

$dbc=odbc_connect("guestbook","","");

if (!$dbc)

{exit("Connection Failed: ".$dbc);}

$query="SELECT * FROM comments";

$query = "UPDATE comments SET name = REPLACE(name, 'John', 'Johnnnnny')"; //<------- to change the word John to Johnny

$rs=odbc_exec($dbc,$query);

if(!$rs)

{exit("Error in SQL");}

echo '<h3>MS Access Powered Guest Book</h3>';

while(odbc_fetch_row($rs))

{

$e_name=odbc_result($rs,"name");

$comment=odbc_result($rs,"comment");

$e_date=odbc_result($rs,"entry_date");

 

 

// display database

echo '<b>Name:</b>'.$e_name.'<br>';

 

echo '<b>Comments</b>'.$comment.'<br /> <b>Date:</b>'.$e_date.'<br />

<hr/>';

}

odbc_close($dbc);

echo"</table>"

 

?>

 

Below is my current database using Microsoft Access. I was hoping to change the name John to Johnny

 

----------------------------------------

|              Name                                |

----------------------------------------

|        John Wilkinson                          |

|        John Abraham                          |

|        John Graham                            |

|        Johnny Wayne                          |

----------------------------------------

 

It should turn out something like this...

 

----------------------------------------

|              Name                                |

----------------------------------------

|        Johnny Wilkinson                      |

|        Johnny Abraham                      |

|        Johnny Graham                        |

|        Johnny Wayne                          |

----------------------------------------

 

Instead of the above result... I got this error....

 

Warning: odbc_exec() [function.odbc-exec]: SQL error: [Microsoft][ODBC Microsoft Access Driver] Undefined function 'REPLACE' in expression., SQL state 37000 in SQLExecDirect in D:\xampp\htdocs\testis2.php on line 8

Error in SQL

 

Can you guys give me your opinion or answers....

 

Link to comment
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.