起步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 ->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;
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();
while ( $row = $result ->fetch_assoc()){
echo $row [ 'name' ];
echo $row [ 'address' ];
}
$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 );
$name = "xiaoming" ;
$address = "adddressss" ;
$stmt ->bind_param( "ss" , $name , $address );
$stmt ->execute();
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();
|