# **MySql 基礎使用**
> 具體使用方法詳見 cmspro/lib/mysql.lib.php
## 系統內置數據庫操作
**附加可選參數**
```
getField 指定欲取的字段,多個請以(,)分號隔開//例如 ->getField('uid','tid')
where 查詢條件 //例如 ->where("id=100")
order 指定排序 //例如 ->order('id asc') ID正序 | ->order('id desc') ID倒序
limit 指定欲取的數據條數 //例如 ->limit(5) 獲取5條數據 | ->limit(100,10) 從第100條開始獲取10條數據
field 指定欲取的字段 名稱,多個請以(,)分號隔開 //例如 ->field('uid','tid')
```
**添加數據**
單條數據添加
```
/**
* 添加數據
*/
$data = array(
'port' => $port,
'type' => 'port',
'ps' => $ps,
'addtime' => date('Y-m-d H:i:s')
);
DB('table')->add($data);
```
多條數據添加
```
/**
* 添加數據
*/
$c = 10; //添加10條數據
for ($i=1;$c>=$i;$i++) {
$data[] = array(
'port' => $port,
'type' => 'port',
'ps' => $ps,
'addtime' => date('Y-m-d H:i:s')
);
}
DB('table')->adds($data);
```
**更新數據(單條)**
```
/**
* 更新數據,返回受影響行
*/
//更新全部
DB('table')->save($data);
//條件更新
DB('table')->where("id='100'")->save($data);
//或者
DB('table')->where("id='100'")->update($data);
```
**更新數據(多條)**
循環DEMO
```
/**
* 使用說明:
* alias 是要查詢的字段,例如查詢ID的話就需要把 alias 換成id
* value 是要設置的字段,例如設置name的話就需要把 alias 換成name
* $alias 條件名稱 例如:CP_SITE_NAME
* $value 更新成值 例如:CMSPRO
*/
//循環多條待更新數據
foreach ($_POST as $id=> $value) {
$list_data .= PHP_EOL . "WHEN '$id' THEN '$value'";
$list_where .= "'$idw',";
}
$data = "value = CASE alias $list_data END" . PHP_EOL;
$list_wheres = substr($list_where, 0, -1);
DB('table')->where("alias IN($list_wheres)")->saves($data);
```
懶人版
```
/* 設置項 */
$table = "user"; //需要更新的表名稱 例如:user
$whrer_id = "id"; //需要查詢的字段 例如:id
$whrer_vl = "name"; //需要設置的字段 例如:name
$list_where = "1,2,3"; //需要查詢字段值 例如查詢設置多個ID 1,2,3 用逗號隔開
$list_data = "WHEN 1 THEN 'xiaoming' WHEN 2 THEN 'xiaohong' WHEN 3 THEN 'xiaolv'"; //需要設置的值 例如批量設置對應id的name值
//進行更新
DB($table)->where("$whrer_id IN($list_where)")->saves("$whrer_vl = CASE $whrer_id $list_data END");
```
**指定字段加**
```
/**
* 指定字段加N,默認加1
*/
//全部修改
DB('table')->sum('number', '100');
//條件修改
DB('table')->where("id='100'")->sum('number', '100');
```
**刪除數據**
```
/**
* 刪除數據(返回受影響行)
*/
//全部修改
DB('table')->delete();
//條件修改
DB('table')->where("id='100'")->delete();
```
**取數據集**
```
/**
* 取數據集(返回符合條件的所有數據)
*
* 可選擇參數 field 指定欲取的字段,多個請以(,)分號隔開
* 可選參數 where 條件查詢
* 可選參數 order 指定 字段 排序 desc.倒序|asc.正序
* 可選參數 limit 指定欲取的數據條數(1):一條 |(30,60):從第30條到第60條
*/
//例1
$rows = DB('table')->field('id,name,username,password,accept')->where("type='1'")->select();
//例2
$rows = DB('table')->where("type='1'")->select();
//或者
$rows = DB('table')->where("type='1'")->rows();
foreach ($rows as $res) {
echo $res['id'];
}
```
**取一行數據**
```
/**
* 取一行數據(只返回第一條數據)
*
* 可選擇參數 field 指定欲取的字段,多個請以(,)分號隔開
* 可選參數 where 條件查詢
* 可選參數 order 指定排序 desc.倒序|asc.正序
*/
$row = DB('table')->field('id,name,username,password,accept')->where("type='1'")->find();
//或者
$row = DB('table')->where("type='1'")->row();
echo $row['id'];
```
**取指定字段值**
```
/**
* 取指定字段值(當只有一條數據時,直接返回鍵值,否則返回數組,失敗返回false)
*/
DB('table')->where("id=1")->getField('status');
```
**設定指定字段值**
```
/**
* 設定指定字段值
*/
DB('table')->where("id=1")->setField('status', '1');
```
**取符合條件的數據總行數**
```
/**
* 取符合條件的數據總行數
* 可選參數 where 條件查詢
*/
//全部表
DB('table')->getCount();
//條件查詢
DB('table')->where("status=1")->getCount();
```
**執行SQL語句,返回受影響行**
```
/**
* 執行SQL語句,返回受影響行
*
* $sql SQL語句
* $data 更新內容
*/
//例1
$sqlstr = "INSERT INTO logs(type,log,addtime) VALUES(:type,:log,:addtime)";
DB('table')->execute($sqlstr, $data);
//例2
$sql = 'alter table tasks add column param text;';
DB('table')->execute($sql, null);
```
**同表復制數據**
返回創建的ID
```
/**
* 同表復制數據
* @param String $data 所復制的數據
* @param String $type 1:默認不復制ID 其它值復制數據中的ID
* @return $this
*/
//查詢信息
$row = DB('try')->where("id={$_GET['id']}")->find();
//自定義數據(可選)
$row['status'] = '-1';
$row['lasttime'] = time();
$row['addtime'] = time();
$row['starttime'] = time();
$row['endtime'] = time() + 86400 * CP_TRY_OUTTIME;
//復制信息
$tid = DB('try')->copy($row);
```
**執行SQL語句,返回數據集**
```
/**
* 執行SQL語句,返回數據集
*
* 純原生SQL執行
* 限查詢
*/
//例1
$sqlstr = "INSERT INTO logs(type,log,addtime) VALUES(:type,:log,:addtime)";
$rows1 = DB('table')->query($sqlstr, $data);
foreach ($rows1 as $res) {
echo $res['id'];
}
//例2
$sql = 'alter table tasks add column param text;';
$rows2 = DB('table')->query($sql, null);
foreach ($rows2 as $res) {
echo $res['id'];
}
```
**純原生SQL執行**
```
/*
* 純原生SQL執行
* 限插入或更新
*/
//例1
$sqlstr = "INSERT INTO logs(type,log,addtime) VALUES(:type,:log,:addtime)";
$rows1 = DB('table')->execute($sqlstr, $data);
foreach ($rows1 as $res) {
echo $res['id'];
}
//例2
$sql = 'alter table tasks add column param text;';
$rows2 = DB('table')->execute($sql, null);
foreach ($rows2 as $res) {
echo $res['id'];
}
```
## 自定義鏈接數據庫操作
**載入數據庫操作類**
```
//載入數據庫操作類
cp::re('mysql');
//配置數據庫信息
$conn['DB_HOST'] = '127.0.0.1'; //主機地址 本地一般采用127.0.0.1或localhost
$conn['DB_PORT'] = '3306'; //數據庫端口
$conn['DB_USER'] = 'root'; //數據帳戶
$conn['DB_PWD'] = '123456'; //數據密碼
$conn['DB_NAME'] = 'test'; //數據庫名
$conn['DB_PREFIX'] = 'cp_'; //表前綴
$conn['DB_CHARSET'] = 'utf8'; //數據庫編碼
$conn['DB_TABLE'] = 'table'; //需要操作的數據庫表
$db = Mysql::start($conn);
//數據庫操作 其它操作參考【系統內置數據庫操作】
$db->add($data);
```
**自定義鏈接數據庫封裝操作**
```
function M($table) {
cp::re('mysql');
$conn['DB_HOST'] = '127.0.0.1'; //主機地址 本地一般采用127.0.0.1或localhost
$conn['DB_PORT'] = '3306'; //數據庫端口
$conn['DB_USER'] = 'root'; //數據帳戶
$conn['DB_PWD'] = '123456'; //數據密碼
$conn['DB_NAME'] = 'test'; //數據庫名
$conn['DB_PREFIX'] = 'cp_'; //表前綴
$conn['DB_CHARSET'] = 'utf8'; //數據庫編碼
$conn['DB_TABLE'] = $table; //需要操作的數據庫表
return Mysql::start($conn);
}
//數據庫操作 其它操作參考【系統內置數據庫操作】
M('table')->add($data);
```
- 關于CMSPRO
- 安裝使用
- 首次使用
- 功能使用
- 系統后臺
- 系統
- 系統配置
- 開發使用
- 基礎學習
- php如何修改文件創建時間
- 類方法
- 系統框架
- 系統入口框架
- URL處理
- 自動附加封裝類、函數入口
- 內置應用
- GET與POST
- 字符控制
- 多語言使用
- 數據庫使用
- 頁面跳轉
- 數組控制
- 時間相關
- 文件操作
- 獲取系統設置的應用目錄
- IP獲取與解析
- 數據分頁
- 內置插件
- 短信發送
- 信息模板
- 消息操作
- 消息操作(舊)
- 資金操作
- 優惠券
- 積分操作
- 服務器接口
- 寶塔接口
- 域名接口
- 西部數據
- whois查詢
- 事件管理器
- 規則管理器
- 電子郵件
- 常用代碼
- 數據獲取與分頁
- 模型自動構建表單
- 排版布局
- 常用樣式
- 編輯表單
- tab選項卡
- JS相關
- 插件
- 鉤子
- 高級進階
- 消息和模板組合使用
- API接口
- 充值支付
- 積分充值兌換
- 短信驗證碼
- 郵箱驗證碼
- 微信消息模板
- 獲取貨幣信息
- 獲取積分信息
- 商品操作
- 信息反饋
- LayIM相關
- 自定義一級URL
- 自定義功能
- 用戶中心
- 網站管理
- 模板引擎v2
- 基礎學習
- 變量輸出
- 使用函數
- 運算符
- 原樣輸出
- 模板注釋
- 模板繼承
- 包含文件
- 內置標簽
- 循環標簽
- 比較標簽
- 條件判斷
- 資源文件加載
- 標簽嵌套
- 原生PHP
- 定義標簽
- 功能應用
- 站點統計
- 數據列表
- 單條數據
- 功能動作
- 賬戶資金
- 賬戶積分
- 網站導航
- 從零使用
- 結構了解
- 基礎工作
- 模板引擎v1
- 模板標簽
- 導航菜單
- 獲取數據列表
- 獲取單條數據
- 廣告以及連接
- if判斷
- 判斷是否登錄
- 判斷系統變量
- 自定義判斷
- 常規判斷
- 模板表單
- 高級使用
- 前后分離v1
- 通用
- 支付
- 積分
- 論壇
- 下載
- 微信
- 云服務SDK開發
- 通用請求