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);
?>
相关推荐
知初~2 小时前
出行项目案例
hive·hadoop·redis·sql·mysql·spark·database
子非衣4 小时前
MySQL修改JSON格式数据示例
android·mysql·json
钊兵5 小时前
数据库驱动免费下载(Oracle、Mysql、达梦、Postgresql)
数据库·mysql·postgresql·oracle·达梦·驱动
隔壁老王1567 小时前
mysql实时同步到es
数据库·mysql·elasticsearch
Hanson Huang9 小时前
【存储中间件API】MySQL、Redis、MongoDB、ES常见api操作及性能比较
redis·mysql·mongodb·es
LUCIAZZZ10 小时前
EasyExcel快速入门
java·数据库·后端·mysql·spring·spring cloud·easyexcel
yuanbenshidiaos10 小时前
【正则表达式】
数据库·mysql·正则表达式
哥坐11路11 小时前
网络IP跳动问题解决详
开发语言·php
雾里看山12 小时前
【MySQL】内置函数
android·数据库·mysql