百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>网页制作> PHP mysqli操纵数据库
分享文章到:

PHP mysqli操纵数据库

发布时间:09/01 来源:未知 浏览: 关键词:
起步

由于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操纵数据库的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板