PHP与mysql数据库交互

PHP与mysql数据库交互

文章目录

方法速查

php 复制代码
函数名								 		作用
mysqli_connect()				与MySQL 数据库建立连接。
mysqli_close()					关闭与MYSQL 数据库建立的连接。
mysqli_connect_errno()			与MySQL 数据库建立连接时,发生错误时的错误编号。
mysqli_connect_error()			与MySQL 数据库建立连接时,发生错误时的错误信息。
mysqli_query()					执行SQL 语句
mysqli_errno()					执行SQL 语句时,发生错误的编号。
mysqli_error()					执行SQL 语句时,发生错误的信息。
mysqli_fetch_assoc()			从结果集对象中取数据,按条取数据。

建立与Mysql链接

想要建立连接想要用到一个PHP函数mysqli_connect( d b h o s t , db_host, dbhost,db_user, d b p a s s , db_pass, dbpass,db_name);

里面有四个参数

php 复制代码
$db_host
主机的名称
php 复制代码
$db_user
连接数据库的用户名
php 复制代码
$db_pass
连接数据库用户名的密码
php 复制代码
$db_name
连接的库名
php 复制代码
$db_host='localhost';
$db_user='root';
$db_pass='root';
$db_name='xl_bbs';
$link= @mysqli_connect($db_host, $db_user, $db_pass, $db_name);

$link变量就相当于获取到了一个通行证

捕获连接错误

如果说建立连接失败就会停止执行所有语句,并输出错误和错误编号

php 复制代码
if(!$link){
    exit("[".mysqli_connect_errno()."] ".mysqli_connect_error());
}

SQL语句的执行

要执行sql语句时需要用到mysqli_query()方法

php 复制代码
$sql = "select * from users"
$results = mysqli_($link,$sql);

如果执行正常就会返回object类型数据否则,就是bool(false)。

SQL 错误

如果在执行SQL 语句的时候发生错误,mysqli_query 将返回false。可以使用以下函数捕获错误原因:

php 复制代码
if(!$results){
    exit("[".mysqli_errno($link)."] ".mysqli_error($link));
}

SQL语句执行

需要用到mysqli_fetch_assoc()方法

导出第一条语句

php 复制代码
var_dump($result);

所有语句全部导出

php 复制代码
while($result = mysqli_fetch_assoc($results)){
    var_dump($result);
}

如果说导入第二条语句的话需要执行两遍var_dump($result);但是第一条结果会被覆盖只显示第二条语句

结果集对象

方法速查
php 复制代码
函数														说明
mysqli_fetch_row()							以索引数组的方式获取一条记录的数据
mysqli_fetch_assoc()						以关联数组的方式获取一条记录的数据
mysqli_fetch_array()						以索引数组或关联数组的方式获取一条记录的数据
mysqli_fetch_all()							以索引数组或关联数组的方式获取全部记录的数据
mysqli_num_rows()							获取结果集对象中数据条数
mysqli_free_result()						释放与一个结果集合相关的内存

案例

利用之前做好的数据库来实现网页显示成果为下图

新建一个数据库把之前数据库实验的备份文件进行导入依次输入以下命令

sql 复制代码
create database bbs;
use bbs;
source C:/bbs.sql;

准备好数据库后用php代码创建连接

php 复制代码
<?php
    $db_host="127.0.0.1";
    $db_user= "root";
    $db_pass= "rooe";
    $db_name= "bbs";
    $link=@mysqli_connect("$db_host","$db_user","$db_pass","$db_name");
?>

做一个 捕获错误连接不上数据库时进行简单报错

php 复制代码
 if(!$link){
        exit("数据库连接错误"."【".mysqli_connect_errno()."】".mysqli_connect_error());
}

写入查询sql语句并用mysqli_query()方法执行sql语句

php 复制代码
 $sql="select * from message";
    $results=mysqli_query($link,$sql);

想要去每条数据使用while循环用mysqlo_fetch_assoc()方法进行取值进行输出条件为mysqlo_fetch_assoc()把全部值取完

再加入表格元素那么就成功了

php 复制代码
echo "<table border='2'> <tr><td>ID</td><td>UID</td><td>TITLE</td><td>CONTENT</td></tr> ";
    while($result=mysqli_fetch_assoc($results))
    {   echo "<tr>";
        foreach($result as $key=>$value){ 
            echo "<td>";
            echo $value;
            echo "</td>";
        
        }
        echo "</tr>";
    }

最后再关闭链接

php 复制代码
mysqli_close($link);

优化后可以通过id查找数据库内容的源码如下

php 复制代码
<pre>
    <meta charset="utf-8">
<?php
    $db_host="127.0.0.1";
    $db_user= "root";
    $db_pass= "root";
    $db_name= "bbs";
    $link=@mysqli_connect("$db_host","$db_user","$db_pass","$db_name");
    if(!$link){
        exit("数据库连接错误"."【".mysqli_connect_errno()."】".mysqli_connect_error());
        }
$id=isset($_REQUEST["id"])?$_REQUEST['id']:1;
    $sql="select m.id, u.username, m.title,m.content from message m,user u where m.uid= u.id and m.id={$id};";
    $results=mysqli_query($link,$sql);
    if(!$results){
        exit("数据库错误".mysql_errno().mysql_error());
    }
    echo "<table border='2'> <tr><td>ID</td><td>UID</td><td>TITLE</td><td>CONTENT</td></tr> ";
    while($result=mysqli_fetch_assoc($results))
    {   echo "<tr>";
        foreach($result as $key=>$value){ 
            echo "<td>";
            echo $value;
            echo "</td>";
        
        }
        echo "</tr>";
    }
mysqli_close($link);
?>
相关推荐
Z***G4797 分钟前
【零基础学Mysql】常用函数讲解,提升数据操作效率的利器
数据库·mysql
aml258__22 分钟前
MySQL 数据库管理入门:从创建到删除(T1)
数据库·mysql·oracle·初学数据库
beata39 分钟前
MySQL 索引你真的用对了吗?
mysql
chxii1 小时前
PHP 配置全解析:Apache vs Nginx 的线程安全差异与 Windows 实战指南
运维·php
TDengine (老段)1 小时前
MySQL/PG/TDengine 时间范围 SQL 表达式
sql·mysql·tdengine
用户607320369452 小时前
PHP cURL 接口调不通?最全故障排查流程来了(新手必收藏)
php
大白的编程日记.2 小时前
【计算网络学习笔记】MySql的多版本控制MVCC和Read View
网络·笔记·学习·mysql
q***72193 小时前
PHP使用Redis实战实录2:Redis扩展方法和PHP连接Redis的多种方案
开发语言·redis·php
gAlAxy...5 小时前
SpringMVC 响应数据和结果视图:从环境搭建到实战全解析
大数据·数据库·mysql
vx_dmxq2116 小时前
【微信小程序学习交流平台】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·python·mysql·微信小程序·小程序·idea