dongpenggan6812 2009-06-28 20:50
浏览 63
已采纳

str_replace函数

$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.');

I have a tag with spaces in its name, how should i do to replace the spaces with hyphens? I think the above code should work but it doesnt :/

Update:

$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 tags

`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条回答 默认 最新

  • dongliu1883 2009-06-28 21:15
    关注

    (3, 'test test test test');
    Either store the tags with hypens instead of spaces, (3, 'test-test-test-test')
    or store and query them with spaces.
    $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.');
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统