本文整理匯總了PHP中think\Db類的典型用法代碼示例。如果您正苦於以下問題:PHP Db類的具體用法?PHP Db怎麽用?PHP Db使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Db類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: optimize
/**
* 優化表
*/
public function optimize()
{
$tables = $_REQUEST['tables'];
if ($tables) {
$Db = Db::getInstance();
if (is_array($tables)) {
$tables = implode('`,`', $tables);
$list = $Db->query("OPTIMIZE TABLE `{$tables}`");
if ($list) {
$this->ajaxReturn(1, "數據表優化完成!");
} else {
$this->ajaxReturn(0, "數據表優化出錯請重試!");
}
} else {
$list = $Db->query("OPTIMIZE TABLE `{$tables}`");
$tables_ts = substr($tables, 3);
if ($list) {
$this->ajaxReturn(1, "數據表'{$tables_ts}'優化完成!");
} else {
$this->ajaxReturn(0, "數據表'{$tables_ts}'優化出錯請重試!");
}
}
} else {
$this->ajaxReturn(0, "請指定要優化的表!");
}
}
示例2: uninstall
public function uninstall()
{
$db_config = array();
$db_config['DB_TYPE'] = C('DB_TYPE');
$db_config['DB_HOST'] = C('DB_HOST');
$db_config['DB_NAME'] = C('DB_NAME');
$db_config['DB_USER'] = C('DB_USER');
$db_config['DB_PWD'] = C('DB_PWD');
$db_config['DB_PORT'] = C('DB_PORT');
$db_config['DB_PREFIX'] = C('DB_PREFIX');
$db = Db::getInstance($db_config);
//讀取插件sql文件
$sqldata = file_get_contents('http://' . $_SERVER['HTTP_HOST'] . __ROOT__ . '/Addons/' . $this->info['name'] . '/uninstall.sql');
$sqlFormat = $this->sql_split($sqldata, $db_config['DB_PREFIX']);
$counts = count($sqlFormat);
for ($i = 0; $i < $counts; $i++) {
$sql = trim($sqlFormat[$i]);
$db->execute($sql);
//執行語句
}
//刪除鉤子
$Hooks = M("Hooks");
$map['name'] = array('in', 'DisplayFocus');
$res = $Hooks->where($map)->delete();
if ($res == false) {
session('addons_install_error', $Hooks->getError());
return false;
}
return true;
}
示例3: step3
public function step3()
{
if (session('step') != 2) {
$this->redirect('step2');
}
$this->display();
//連接數據庫
$dbconfig = session('db_config');
$db = Db::getInstance($dbconfig);
//創建數據表
create_tables($db, $dbconfig['DB_PREFIX']);
//注冊創始人帳號
$auth = build_auth_key();
$admin = session('admin_info');
register_administrator($db, $dbconfig['DB_PREFIX'], $admin, $auth);
//創建配置文件
$conf = write_config($dbconfig, $auth);
session('config_file', $conf);
if (session('error')) {
//show_msg();
} else {
session('step', 3);
$this->redirect('Index/complete');
}
}
示例4: __construct
/**
* 架構函數
* @param array $options 緩存參數
* @access public
*/
public function __construct($options = [])
{
if (!empty($options)) {
$this->options = array_merge($this->options, $options);
}
$this->handler = \Think\Db::instance();
}
示例5: logs
/**
* 記錄用戶日誌
* @param string $logs 用戶日誌
* @param array $data 操作的數據
* @param boolean $autoUid 自動獲取用戶UID 否則傳入UID
*/
function logs($logs, $data = [], $autoUid = true)
{
$uid = $autoUid === true ? UID : $autoUid;
$data = !empty($data) ? json_encode($data, JSON_UNESCAPED_UNICODE) : '';
$data = ['uid' => $uid, 'logs' => $logs, 'datas' => $data, 'create_time' => NOW_TIME];
Db::name('Logs')->insert($data);
}
示例6: __construct
/**
* 架構函數
* @param array $options 緩存參數
* @access public
*/
public function __construct($options = [])
{
if (!empty($options)) {
$this->options = array_merge($this->options, $options);
}
$this->handler = \think\Db::connect(!empty($this->options['hostname']) || !empty($this->options['dsn']) ? $this->options : []);
}
示例7: checkExtends
/**
* 檢測繼承分類是否是相同的模型
* @param [type] $value [description]
* @param [type] $rule [description]
* @param [type] $data [description]
* @return [type] [description]
*/
protected function checkExtends($value, $rule, $data)
{
if (0 != $data['pid']) {
return $value == Db::name('Category')->where('id', $data['pid'])->value('model');
} else {
return true;
}
}
示例8: index
public function index()
{
$Db = Db::getInstance();
$list = $Db->query('SHOW TABLE STATUS');
$list = array_map('array_change_key_case', $list);
$this->assign('list', $list);
$this->display();
}
示例9: checkNode
/**
* 驗證菜單是幾級節點
* @param [type] $value [description]
* @param [type] $rule [description]
* @param [type] $data [description]
* @return [type] [description]
*/
protected function checkNode($pid, $rule, $data)
{
// 一級菜單最多三個
if ($pid == 0) {
return Db::name('WechatMenu')->where('pid', 0)->count() >= 3 ? '一級菜單數量最多三個' : true;
} else {
return Db::name('WechatMenu')->where('pid', $pid)->count() >= 5 ? '二級菜單數量最多五個' : true;
}
}
示例10: autoLogin
/**
* 保存登陸信息
* @param [type] $user
*/
private function autoLogin($user)
{
$loginData = ['uid' => $user['id'], 'account' => $user['account'], 'login' => $user['login'], 'last_time' => $user['last_time'], 'last_ip' => $user['last_ip']];
session('user_auth', $loginData);
session('user_auth_sign', data_auth_sign($loginData));
// 保存登陸信息
$saveData = ['last_ip' => get_client_ip(), 'last_time' => NOW_TIME, 'login' => ['exp', '`login`+1']];
Db::name('Member')->where('id', $user['id'])->update($saveData);
logs('登陸成功', '', $user['id']);
}
示例11: __construct
/**
* 架構函數
* @param array $options 緩存參數
* @access public
*/
public function __construct($options = array())
{
if (empty($options)) {
$options = array('table' => C('DATA_CACHE_TABLE'));
}
$this->options = $options;
$this->options['prefix'] = isset($options['prefix']) ? $options['prefix'] : C('DATA_CACHE_PREFIX');
$this->options['length'] = isset($options['length']) ? $options['length'] : 0;
$this->options['expire'] = isset($options['expire']) ? $options['expire'] : C('DATA_CACHE_TIME');
$this->handler = \Think\Db::getInstance();
}
示例12: treeSelect
/**
* 返回樹形選擇
* @param string 分類模型
* @param integer $unShowId 排除顯示的節點
* @return array
*/
public function treeSelect($model = '', $unShowId = 0)
{
$map['status'] = 1;
if ($unShowId) {
$map['id'] = ['neq', $unShowId];
}
if ($model) {
$map['model'] = $model;
}
$categorys = Db::name('category')->where($map)->order('sort asc')->select();
return Tree::toFormatTree($categorys);
}
示例13: index
/**
* 上傳文件管理
*/
public function index($type = '')
{
$total = disk_total_space(".");
$this->assign('disk_use', round(($total - disk_free_space(".")) / $total * 100, 2));
$map = [];
if ($type) {
$map['type'] = $type;
}
$list = parent::_list('Storage', $map);
$this->assign('list', $list);
$this->assign('size', Db::name('Storage')->where($map)->sum('size'));
$this->assign('types', Db::name('Storage')->field('type')->distinct('type')->select());
return $this->fetch();
}
示例14: getMenuIds
/**
* 獲取用戶菜單節點Id集合
* @param [type] $uid 用戶UID
* @return array
*/
public static function getMenuIds($uid)
{
$gIds = self::getGroupIds($uid);
$menuIds = '';
if ($gIds) {
$menuIds = Db::name('Auth')->where('id', 'in', $gIds)->column('rules');
$menuIds = implode($menuIds, ',');
$menuIds = trim($menuIds, ',');
}
$openMap = ['status' => 2, 'auth' => 0];
$openMenus = Db::name('Menu')->where($openMap)->column('id');
$openMenus = implode($openMenus, ',');
if (!empty($openMenus)) {
$menuIds .= ',' . $openMenus;
}
return trim($menuIds, ',');
}
示例15: password
/**
* 修改密碼
*/
public function password()
{
if (IS_POST) {
$data = $this->request->post();
$validate = Loader::validate('Member');
if (!$validate->scene('changepass')->check($data)) {
return $this->error($validate->getError());
}
$passData = ['password' => umd5($data['newpass']), 'update_time' => NOW_TIME];
if (Db::name('Member')->where('id', UID)->update($passData)) {
return $this->success('密碼修改成功');
} else {
return $this->error();
}
} else {
return $this->fetch();
}
}