PHP mysqli操做數據庫

起步php

 

因爲mysql鏈接方式被廢除,在php7中要使用mysql_connect()還須要額外下載組件。mysql

使用mysqli有面向過程和麪向對象兩種方式。sql

mysqli提供了三個類:數據庫

● mysqli 鏈接相關的php7

● mysqli_result 處理結果集函數

● mysqli_stmt 預處理類fetch

數據庫鏈接編碼

1spa

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();

相關文章
相關標籤/搜索