资讯专栏INFORMATION COLUMN

PHP mysqli 操作数据库

13651657101 / 3411人阅读

摘要:起步由于连接方式被废除,据说在中要使用还需要额外下载组件。使用有面向过程和面向对象两种方式。

起步

由于mysql连接方式被废除,据说在php7中要使用mysql_connect()还需要额外下载组件。
使用mysqli有面向过程和面向对象两种方式。
mysqli提供了三个类:

mysqli 连接相关的

mysqli_result 处理结果集

mysqli_stmt 预处理类

数据库连接
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语句执行成功了。

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

有结果集

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是预处理类

prepare($sql);
//绑定参数 第一个参数为绑定的数据类型
/*
i:integer 整型
d:double 浮点型
s:string 字符串
b:a blob packets blob数据包
*/
$name = "xiaoming";
$address = "affffdressss";
$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 idprepare($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是最后影响的条数

multi_query($sql);
if($result === false){
    echo $mysqli->error;
}
$mysqli->close();

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/21168.html

相关文章

  • 你想不到的最简单php操作MySQL

    摘要:千锋出品之天龙八部操作必须先开启扩展函数库首先先开启开启成功呢我就可以开始连接数据库了,第一步连接数据库服务器地址用户名,密码第二步判断连接数据库是否成功连接错误号连接错误信息第三步选择数据库数据库名称第四步设置字符集第五步准备语句表名第六  千锋PHP出品之天龙八部: Php操作mysql必须先开启mysq扩展函数库   首先先开启extension = mysqli_dll;   ...

    pkhope 评论0 收藏0
  • PHP操作MySQL

    摘要:操作操作的三种方式非永久连接,性能比较低,以后废弃永久连接,减轻服务器压力,只支持能实现的常用功能,支持大部分数据库扩展查看函数配置文件方式连接数据库设置的字符集连接数据库选择数据库设置字符集方式执行语句对之类的操作,执行成功时返回出错 PHP操作MySQL PHP操作MySQL的三种方式: MySQL:非永久连接,性能比较低,PHP5.5以后废弃; MySQLi:永久连接,...

    phodal 评论0 收藏0
  • PHP扩展 Mysql 与 Mysqli

    摘要:开发中,使用扩展来链接数据库进行增删改查等操作。从起这个扩展已经被废弃,并且从开始被移除。扩展允许我们访问及以上版本提供的功能。相关概念与都是方面的函数集。多次运行将使用同一连接进程,减少了服务器的开销。版本为只能使用扩展。 PHP开发中,使用Mysql扩展来链接Mysql数据库进行增删改查等操作。 在选择Mysql扩展的时候,官方提供了两种: MySQL 原始版。 http://cn...

    Neilyo 评论0 收藏0

发表评论

0条评论

13651657101

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<