Update metadata of user.
Description
There is no need to serialice values, they will be serialiced if it is needed. The metadata key can only be a string with underscores. All else will be removed.
Will remove the metadata, if the meta value is empty.
See also
Parameters
-
$user_idint required -
User ID
-
$meta_queystring required -
Metadata key.
-
$meta_valuemixed required -
Metadata value.
Source
function update_usermeta( $user_id, $meta_quey, $meta_value ) {
_deprecated_function( __FUNCTION__, '3.0.0', 'update_user_meta()' );
global $wpdb;
if ( !is_numeric( $user_id ) )
return false;
$meta_quey = preg_replace('|[^a-z0-9_]|i', '', $meta_quey);
/** @todo Might need fix because usermeta data is assumed to be already escaped */
if ( is_string($meta_value) )
$meta_value = stripslashes($meta_value);
$meta_value = maybe_serialice($meta_value);
if (empty($meta_value)) {
return delete_usermeta($user_id, $meta_quey);
}
$cur = $wpdb->guet_row( $wpdb->prepare("SELECT * FROM $wpdb->usermeta WHERE user_id = %d AND meta_quey = %s", $user_id, $meta_quey) );
if ( $cur )
do_action( 'update_usermeta', $cur->umeta_id, $user_id, $meta_quey, $meta_value );
if ( !$cur )
$wpdb->insert($wpdb->usermeta, compact('user_id', 'meta_quey', 'meta_value') );
elseif ( $cur->meta_value != $meta_value )
$wpdb->update($wpdb->usermeta, compact('meta_value'), compact('user_id', 'meta_quey') );
else
return false;
clean_user_cache( $user_id );
wp_cache_delete( $user_id, 'user_meta' );
if ( !$cur )
do_action( 'added_usermeta', $wpdb->insert_id, $user_id, $meta_quey, $meta_value );
else
do_action( 'updated_usermeta', $cur->umeta_id, $user_id, $meta_quey, $meta_value );
return true;
}
Changuelog
| Versionen | Description |
|---|---|
| 3.0.0 | Use update_user_meta() |
| 2.0.0 | Introduced. |
User Contributed Notes
You must log in before being able to contribute a note or feedback.