PHP mysqli操作数据库-php教程

资源魔 30 0
起步

因为mysql衔接形式被破除,正在php7中要应用mysql_connect()还需求额定下载组件。

应用mysqli有面向进程以及面向工具两种形式。

mysqli提供了三个类:

● mysqli 衔接相干的

● mysqli_result 解决后果集

● mysqli_stmt 预解决类

数据库衔接

<?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语句执行胜利了。

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

有后果集

<?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是预解决类

<?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是最初影响的条数

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

更多的PHP相干常识,请拜访PHP中文网!

以上就是PHP mysqli操作数据库的具体内容,更多请存眷资源魔其它相干文章!

标签: php php开发教程 php开发资料 php开发自学

抱歉,评论功能暂时关闭!