str_replace函数

时间:2009-06-28 20:50:50

标签: php

$tag = mysql_real_escape_string($_GET['tag']);
$tag = str_replace("-", " ", $_GET['tag']);

$query = mysql_query("SELECT * FROM tags WHERE name = '$tag'");
$row = mysql_fetch_assoc($query);

if (!mysql_num_rows($query)) exit('That tag dont exist.');

我的名字中有一个带空格的标签,我该如何用连字符替换空格? 我认为上面的代码应该可以工作,但它不会:/

更新

$tag = str_replace(' ', '-', $_GET['tag']);
$tag = mysql_real_escape_string($tag);

$query = mysql_query("SELECT * FROM tags WHERE name = '$tag'");
$row = mysql_fetch_assoc($query);

if (!mysql_num_rows($query)) exit('That tag dont exist');

Db标签

`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(40) COLLATE utf8_unicode_ci DEFAULT NULL



INSERT INTO `tags` (`id`, `name`) VALUES
(1, 'test'),
(2, 'test test'),
(3, 'test test test test');

2 个答案:

答案 0 :(得分:4)

其他方式:

$tag = str_replace(' ', '-', $_GET['tag']);
$tag = mysql_real_escape_string($tag);

(当您看到str_replace(A, B, C)时,请考虑“在C中用B替换A”)

(另外,在其他所有内容之后,会转义字符串。你第二次意外地使用了$_GET['tag']而不是$tag。)

答案 1 :(得分:1)

(3,'测试测试测试');
使用连字符而不是空格存储标签(3, 'test-test-test-test')
或存储用空格查询它们。
$tag = mysql_real_escape_string($_GET['tag']);
$query = "SELECT * FROM tags WHERE name = '$tag'";
$result = mysql_query($query) or die(mysql_error());
if ( false===($row=mysql_fetch_assoc($result)) ) exit('No such tag.');