2017-09-20

猎数博客

数据挖掘,机器学习

通过wpdb访问WordPress数据库

作者:江航 / 2011-05-28 / (阅读 2,444 次) /



英文版的文章在这里

wordpress提供了一个全局变量$wpdb来访问wordpress数据库,通过wpdb可以实现对数据库的各种操作。这里各种操作包括添加一个新表,查询,删除,更新等等。提供了处理用户自定义数据的接口。注意在调用的函数里面要全局化这个变量。通过这个变量可以访问数据库中的任何表,但是仅限于一个数据库,如果要访问多个数据库,需要重新实例化一个wpdb类。这里只讨论单个数据库的情况。

查询

<?php $wpdb->query("DELETE FROM $wpdb->post WHERE post_id = ’13’ “); ?>

其中query的参数是任何mysql语句。返回值是有多少行被选出、影响。如果出错返回FALSE。

选出一个变量

<?php $wpdb->get_var('query',column_offset,row_offset); ?>

其中query为要查询的mysql语句,如果为空的话,则表示从cache中选出。column_Offset和row_offet表示制定query返回值的第几列和第几行,缺省值为零。典型用法为:
<?php $user_count = $wpdb->get_var($wpdb->prepare("SELECT COUNT(*) FROM $wpdb->users;"));?>
这个sql只选出一个值,缺省的0行0列,即表示选出用户数目。目前还不清楚,这里为什么总是要加prepare在前面。

选出一行

<?php $wpdb->get_row('query', output_type, row_offset); ?>

query为要执行的mysql语句,output_type表示返回值是object,hash或者是数组;row_offset表示第几行。

缺省情况下output_type为object。

$mylink = $wpdb->get_row("SELECT * FROM $wpdb->links WHERE link_id = 10"); echo $mylink->link_id; // prints "10"

如果output_type=ARRAY_A,那么:

$mylink = $wpdb->get_row("SELECT * FROM $wpdb->links WHERE link_id = 10", ARRAY_A); echo $mylink['link_id']; // prints "10"

如果output_type=ARRAY_N,那么:

$mylink = $wpdb->get_row("SELECT * FROM $wpdb->links WHERE link_id = 10", ARRAY_N); echo $mylink[1]; // prints "10"

选出一列

<?php $wpdb->get_col('query',column_offset); ?>

一般选出

$wpdb->get_results('query', output_type);

例子:
$fivesdrafts = $wpdb->get_results("SELECT ID, post_title FROM $wpdb->posts WHERE post_status = 'draft' AND post_author = 5");

` `

foreach ($fivesdrafts as $fivesdraft) { echo $fivesdraft->post_title; }

插入一行

<?php $wpdb->insert( $table, $data, $format ); ?>
实例:$wpdb->insert( ‘table’, array( ‘column1’ => ‘value1’, ‘column2’ => 123 ), array( ‘%s’, ‘%d’ ) )

更新

$wpdb->update( $table, $data, $where, $format = null, $where_format = null );
实例:
$wpdb->update( 'table', array( 'column1' => 'value1', 'column2' => 'value2' ), array( 'ID' => 1 ), array( '%s', '%d' ), array( '%d' ) )

关于wpdb prepare

前面提到不清楚为什么每个mysql语句都会包在prepare中,这里给出解释:因为mysql语句中可能含有单引号双引号这样的字符,如果不加处理直接送给mysql,可能会导致错误。于是这里通过一个prepare来对mysql语句进行预处理。prepare的语法是:

$sql = $wpdb->prepare( 'query' [, value_parameter, value_parameter ... ] );

在query中可以包含%d,%S,%f,分别表示后面参数的类型是整数,字符和浮点,如果要显示%号,则用%%,语法和C语言里面的printf基本一样。

到这里基本上就讲完了。对一般数据库的处理应该都没有问题了。如果碰到问题可以在本文开始时提到的那篇文章中去查阅。

wordpress 3.3 数据库结构介绍



Wordpress一览无余,源码面前没有秘密,wordpress的函数调用库,展示wordpress页面打开过程中十几万个函数调用,学习WP开发的绝佳资源。点击这里进入

本文地址: http://www.bagualu.net/wordpress/archives/641 转载请注明






相关文章

  • 再说Wordpress中添加小挂件widget( 5,869 )
  • Wordpress中添加自定义参数( 3,411 )
  • WordPress代码之apply_filters( 3,272 )
  • 微博分享按钮( 3,226 )
  • WordPress版权声明插件( 3,199 )
  • wordpress函数调用库( 2,634 )
  • 通过wpdb访问WordPress数据库( 2,444 )
  • 通过wordpress debug插件,显示filter调用过程( 2,404 )
  • 用Wordpress做相册( 2,398 )
  • WordPress 代码之 add_filter( 2,337 )
  • Leave a Reply

    您必须登录以发表评论,

    沪ICP备11036560号
    联系我: jianghang at bagualu.net