起步
由于mysql連接方式被廢除,在php7中要使用mysql_connect()還需要額外下載組件,
使用mysqli有面向程序和面向物件兩種方式,
mysqli提供了三個類:
● mysqli 連接相關的
● mysqli_result 處理結果集
● mysqli_stmt 預處理類
資料庫連接
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<?php
$db_host = 'localhost';
$db_name = 'test';
$db_user = 'root';
$db_pwd = '';
//面向物件方式
$mysqli = new mysqli($db_host, $db_user, $db_pwd, $db_name);
//面向物件的昂視屏蔽了連接產生的錯誤,需要通過函式來判斷
if(mysqli_connect_error()){
echo mysqli_connect_error();
}
//設定編碼
$mysqli->set_charset("utf8");//或者 $mysqli->query("set names 'utf8'")
//關閉連接
$mysqli->close();
//面向程序方式的連接方式
$mysqli = mysqli_connect($db_host, $db_user, $db_pwd, $db_name);
//判斷是否連接成功
if(!$mysqli ){
echo mysqli_connect_error();
}
//關閉連接
mysqli_close($mysqli);
?>
|
資料庫查詢
通用:執行sql陳述句都可用query(sql),執行失敗會回傳false,select成功則回傳結果集物件,其他回傳true,只要不是false就說明sql陳述句執行成功了,
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<?php
//無結果集示例
$sql = "insert into table_name (`name`, `address`) values ('xiaoming', 'adddddrrreess')";
$result = $mysqli->query($sql);
//或者
$sql = "delete from table_name where name='xiaoming'";
$result = $mysqli->query($sql);
if($result === false){
echo $mysqli->error;
echo $mysqli->errno;
}
//影響條數
echo $mysqli->num_rows;
//插入的id
echo $mysqli->insert_id;
$mysqli->close();
|
有結果集
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<?php
$sql = "select * from table_name";
$result = $mysqli->query($sql);
if($result === false){//執行失敗
echo $mysqli->error;
echo $mysqli->errno;
}
//行數
echo $result->num_rows;
//列數 欄位數
echo $result->field_count;
//獲取欄位資訊
$field_info_arr = $result->fetch_fields();
//移動記錄指標
//$result->data_seek(1);//0 為重置指標到起始
//獲取資料
while($row = $result->fetch_assoc()){
echo $row['name'];
echo $row['address'];
}
//也可一次性獲取所有資料
//$result->data_seek(0);//如果前面有移動指標則需重置
$data = $result->fetch_all(MYSQLI_ASSOC);
$mysqli->close();
|
預處理示例
預處理能有效的防止sql注入的產生,mysqli_stmt是預處理類
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
<?php
$sql = "insert inro table_name ('name','address') values (?,?)";
//獲得預處理物件
$stmt = $mysqli->prepare($sql);
//系結引數 第一個引數為系結的資料型別
/*
i:integer 整型
d:double 浮點型
s:string 字串
b:a blob packets blob資料包
*/
$name = "xiaoming";
$address = "adddressss";
$stmt->bind_param("ss", $name, $address);//系結時使用變數系結
//執行預處理
$stmt->execute();
/*
//可重新系結 多次執行
$stmt->bind_param("ss", $name, $address);
$stmt->execute();
*/
//插入的id 多次插入為最后id
echo $stmt->insert_id;
//影響行數 也是最后一次執行的
echo $stmt->affected_rows;
//錯誤號
echo $stmt->errno;
//錯誤資訊
echo $stmt->error;
//關閉
$stmt->close();
$mysqli->close();
下面示例select的預處理
//注釋部分省略
$sql = "select * from table_name where id<?";
$stmt = $mysqli->prepare($sql);
$id = 30;
$stmt->bind_param("i", $id);
$stmt->execute();
//獲取結果集
$result = $stmt->get_result();//結果集取后的操作就和之前一樣了
//獲取所有資料
$data = $result->fetch_all(MYSQLI_ASSOC);
$result->close();
$mysqli->close();
|
一次執行多條sql陳述句multiquery(不推薦),執行結果不是結果集,affectd_rows是最后影響的條數
|
1
2
3
4
5
6
7
8
9
10
11
12
|
<?php
$sql_arr = array(
"insert into table_name (`name`,`address`) values ('xiaoming','a')",
"insert into table_name (`name`,`address`) values ('xiaohong','a')",
'delete from table_name where id=23',
);
$sql = implode(';', $sql_arr);
$result = $mysqli->multi_query($sql);
if($result === false){
echo $mysqli->error;
}
$mysqli->close();
|

明確的學習思路能更高效的學習

點此加入該群學習
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/119118.html
標籤:PHP
上一篇:thinkphp5配合datatable插件分頁后端處理程式
下一篇:php中 continue break exit return 的區別