掃二維碼與項目經(jīng)理溝通
我們在微信上24小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢(xún)/運營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流
WordPress的數據庫設計模式就是主表+輔表的方式,比如users表的輔表usermeta。WordPress的自帶的12張表(以前的老版本是11張表),其中有8張表都是采用主表和輔表的方式,具體如下:
1、posts:文章表(輔表postmeta)
2、users:用戶(hù)表(輔表usermeta)
3、comments:評論表(輔表commentmeta)
4、links:鏈接表(輔表linkmeta)
主表一般是存儲各個(gè)主要內容的默認字段,如果需要自定義字段就需要輔表meta,比如增加手機號碼驗證登錄,那么就需要把手機號碼信息存儲在usermeta中。在WordPress中默認提供的方法只包含了meta表的增刪改查,主要如下:
1、add_metadata:增加meta,如果是user對應的就是add_user_meta。
2、update_metadata:更新meta,如果是user對應的就是update_user_meta。
3、get_metadata:獲取meta,如果是user對應的就是get_user_meta。
4、delete_metadata:刪除meta,如果是user對應的就是delete_user_meta。
這四種主要的方法都需要傳遞一個(gè)方法就是主表的主鍵的值,比如user就是需要傳遞user_id用戶(hù)ID為參數。但是,通過(guò)user_meta的某個(gè)值獲取用戶(hù)ID及用戶(hù)信息似乎沒(méi)有直接提供自帶的方法(也許是筆者沒(méi)找到而已)。
現在有這樣的需求:由于WordPress網(wǎng)站增加用戶(hù)使用手機號碼注冊、登錄網(wǎng)站,因此需要使用usermeta表存儲用戶(hù)的手機號碼,而且在注冊登錄的時(shí)候需要通過(guò)手機號碼反查用戶(hù)的ID以及用戶(hù)信息。這個(gè)時(shí)候需要自己構造一個(gè)方法:
/** * 通過(guò)user_meta獲取用戶(hù)信息 * @param $meta_key user_meta類(lèi)型 * @param $meta_value user_meta的值 */ function get_user_id_by_meta($meta_key,$meta_value){ global $wpdb; $user=$wpdb->get_row($wpdb->prepare("SELECT * FROM $wpdb->usermeta WHERE meta_key = %s AND meta_value = %s", $meta_key, $meta_value ) ); if(empty($user)){ return false; } return $user->user_id; }
通過(guò)如上方法就可以得到usermeta的信息,其他的posts、comments、links表也是一樣的道理,比如通過(guò)手機號碼在usermeta中存儲的meta_key為user_mobile,則可以通過(guò)某個(gè)手機號碼獲取到對應的用戶(hù)ID,代碼如下:
$user_id=get_user_id_by_meta('user_mobile','13272012225');
如果需要進(jìn)一步獲取用戶(hù)的所有信息,可以通過(guò)get_userdata獲取,代碼如下:
$user=get_userdata($user_id);//獲取用戶(hù)信息 $user_login=$user->user_login;//獲取用戶(hù)登錄名
至此就完成了WordPress通過(guò)user_meta的某個(gè)值獲取用戶(hù)ID及用戶(hù)信息,同樣的其他的meta數據表通過(guò)某個(gè)meta的值反向獲取主表信息也可以使用一樣的方法。
我們在微信上24小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢(xún)/運營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流