【问题标题】:can't insert data into database in wordpress无法在wordpress中将数据插入数据库
【发布时间】:2013-07-29 06:22:19
【问题描述】:

我在 wordpress 中创建了一个表单,但是这段代码不起作用。

<?php

$metaname = $wpdb->escape($_REQUEST['apply_name']);
$metakey = $wpdb->escape($_REQUEST['apply_email']);
$metavalue = $wpdb->escape($_REQUEST['regcat']);

$wpdb->query($wpdb->prepare(
                "
        INSERT INTO $wpdb->jz_users
        ( user_login, user_email, category )
        VALUES ( %d, %s, %s )
    ", array(
            $metaname,
            $metakey,
            $metavalue
                )
        ));
?>

【问题讨论】:

  • 使用 $wpdb-&gt;show_errors(); 将错误检查到您的查询中。

标签: database wordpress


【解决方案1】:
$wpdb->query($wpdb->prepare(
            "
    INSERT INTO $wpdb->jz_users
    ( user_login, user_email, category )
    VALUES ( %d, %s, %s )
", array(
        $metaname,
        $metakey,
        $metavalue
            )
    ));

可能是表名应该是$wpdb-&gt;users 而不是$wpdb-&gt;jz_users

$wpdb->query($wpdb->prepare("
    INSERT INTO $wpdb->users 
        ( user_login, user_email, category )
    VALUES ( %d, %s, %s )", 
    array(
        $metaname,
        $metakey,
        $metavalue
            )
    ));
$wpdb->show_errors();

因为wpdb 类负责数据库中使用的前缀,而您正在使用带前缀的表名。

【讨论】:

  • 谢谢,数据库现在连接。但它是空白记录..如何解决这个问题? :)
  • @user2428537 确保您获得了$metaname, $metakey, $metavalue的值?
  • 它不接受表单值。我的代码在下面
    sind
  • @user2428537 希望您正在制作插件?如果我错了,请纠正我。
  • 不,我想创建一个联系表单,所以我创建了这个表单,但我无法获取这个表单字段的值..
【解决方案2】:
<?php 
$wpdb->insert( 
    $wpdb->prefix . 'users', 
        array( 
            'spam'            => 0, 
            'user_status'     => 0, 
            'deleted'         => 0, 
            'old_user_id'     =>125,
            'user_login'      =>'test', 
            'user_pass'       =>md5('admin')

        )
); 
?>

【讨论】:

  • 虽然这段代码 sn-p 可以解决问题,但including an explanation 确实有助于提高帖子的质量。请记住,您是在为将来的读者回答问题,而这些人可能不知道您提出代码建议的原因。
猜你喜欢
  • 1970-01-01
  • 2020-07-29
  • 2016-11-22
  • 2012-04-13
  • 1970-01-01
  • 2012-09-24
相关资源
最近更新 更多