Edit report at https://bugs.php.net/bug.php?id=38685&edit=1

 ID:                 38685
 User updated by:    paulschreiber at gmail dot com
 Reported by:        paulschreiber at gmail dot com
 Summary:            ER: Allow str_replace with string subject, array
                     replace
 Status:             Analyzed
 Type:               Feature/Change Request
 Package:            *General Issues
 Operating System:   any
 PHP Version:        4.4.4
 Block user comment: N
 Private report:     N

 New Comment:

1. When this bug was written, PDO and other similar libraries did not exist.
2. Prepared statements are only one possible use case.
3. If you are not going to fix this bug, just close it as WONTFIX.


Previous Comments:
------------------------------------------------------------------------
[2013-03-17 16:13:34] [email protected]

It is a feature request, not a bug, and one that is rather iffy as far as I am 
concerned. It is likely to sit here another 7 years unless accompanied by a 
solid 
implementation and some better rationale on why we should encourage people to 
use 
something like this over the native prepare/execute syntax provided by the 
databases or even the emulated prepare/execute we provide via PDO.

------------------------------------------------------------------------
[2013-03-17 03:57:58] valentiny510 at yahoo dot es

For Paul: The syntax is incorrect.
For PHP Team: 7 years and is still open ???

------------------------------------------------------------------------
[2006-09-01 22:46:52] paulschreiber at gmail dot com

Description:
------------
The PHP docs for str_replace say:

"If search and replace are arrays, then str_replace() takes a value from each 
array and uses them to do search and replace on subject. If replace has fewer 
values than search, then an empty string is used for the rest of replacement 
values. If search  is an array and replace is a string, then this replacement 
string is used for every value of search. The converse would not make sense, 
though."

I think the converse makes sense in some cases. Here is an example:
$result = str_replace("?", array("Joe", "Smith"), "SELECT * FROM people WHERE 
first = ? AND last = ?");

(Yes, if you were doing real database work, you'd need to escape everything.)

It would be nice if PHP supported this.

Reproduce code:
---------------
$result = str_replace("?", array("'Joe'", "'Smith'"), "SELECT * FROM people 
WHERE first = ? AND last = ?");
print $result;


Expected result:
----------------
SELECT * FROM people WHERE first = 'Joe' AND last = 'Smith'


Actual result:
--------------
PHP Notice:  Array to string conversion in /Users/paul/- on line 2

Notice: Array to string conversion in /Users/paul/- on line 2
SELECT * FROM people WHERE first = Array AND last = Array



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



-- 
Edit this bug report at https://bugs.php.net/bug.php?id=38685&edit=1

Reply via email to