【PHP网页应用】MySQL数据库增删改查 基础版

这篇具有很好参考价值的文章主要介绍了【PHP网页应用】MySQL数据库增删改查 基础版。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

使用PHP编写一个简单的网页,实现对MySQL数据库的增删改和展示操作

页面实现在index.php,其中basic.php为没有css美化的原始人版本

函数实现在database.php

目录

功能基本实现版

 CSS美化版

basicindex.php 

index.php 

 database.php

代码讲解

功能基本实现版

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

 CSS美化版

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

我们来展示一下页面和操作示例。

运行网页,可以看到页面展示出了数据库的名字,还有数据库下的表。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

我们点击其中一个表,可以看到表名和表的数据以及可以点击操作的按钮。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

然后我们输入新的数据准备添加。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

点击添加,可以看到添加成功的提示。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

可以看到新添加的数据。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

然后我们尝试修改数据,将visits_made改成2,点击更新。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

可以看到visits_made已经变成2了。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

然后我们删除这一行数据,点击删除。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

可以看到我们刚刚添加的一行数据没了。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

basicindex.php 

<?php
include 'database.php';
global $primaryKey;
$tableNames=getTableNames();
echo '<h1>数据库表名</h1>';
foreach ($tableNames as $name){
    echo '<a href="?table=' . $name . '">' . $name . '</a><br>';
}
if (isset($_GET['table'])) {
    $tableName = $_GET['table'];
    setPrimaryKey($tableName);
    if (isset($_POST['add'])) {
        // 添加数据
        $data = $_POST;
        unset($data['add']);
        insertRecord($tableName, $data);
    } elseif (isset($_POST['delete'])) {
        // 删除数据
        $id = $_POST['id'];
        deleteRecord($tableName, $id);
    } elseif (isset($_POST['update'])) {
        // 修改数据
        $id = $_POST['id'];
        $data = $_POST;
        unset($data['update'], $data['id']);
        updateRecord($tableName, $id, $data);
    }

    $tableData = getTableData($tableName);
} else {
    $tableNames = getTableNames();
}
?>

<!DOCTYPE html>
<html>
<head>
    <title>MySQL 数据库操作</title>
</head>
<body>
<?php if (isset($tableData)) { ?>
    <h1><?php echo $tableName; ?></h1>
    <table>
        <tr>
            <?php foreach (array_keys($tableData[0]) as $key) { ?>
                <th><?php echo $key; ?></th>
            <?php } ?>
            <th>操作</th>
        </tr>
        <?php foreach ($tableData as $row) { ?>
            <form method="post">
                <tr>
                    <?php foreach ($row as $key => $value) { ?>
                        <td>
                            <input type="text" name="<?php echo $key; ?>" value="<?php echo $value; ?>">
                        </td>
                    <?php } ?>
                    <td>
                        <input type="hidden" name="id" value="<?php echo $row[$primaryKey]; ?>">
                        <input type="submit" name="update" value="更新">
                        <input type="submit" name="delete" value="删除">
                    </td>
                </tr>
            </form>
        <?php } ?>
        <form method="post">
            <tr>
                <?php foreach (array_keys($tableData[0]) as $key) { ?>
                    <td>
                        <input type="text" name="<?php echo $key; ?>" placeholder="<?php echo $key; ?>">
                    </td>
                <?php } ?>
                <td>
                    <input type="submit" name="add" value="添加">
                </td>
            </tr>
        </form>
    </table>
<?php }?>
</body>
</html>

index.php 

<?php
include 'database.php';
global $primaryKey;
global $database;
$tableNames = getTableNames();
if (isset($_GET['table'])) {
    $tableName = $_GET['table'];
    setPrimaryKey($tableName);
    if (isset($_POST['add'])) {
        // 添加数据
        $data = $_POST;
        unset($data['add']);
        echo '<script>alert("'.insertRecord($tableName, $data).'")</script>';
    } elseif (isset($_POST['delete'])) {
        // 删除数据
        $key = $_POST['key'];
        echo '<script>alert("'.deleteRecord($tableName, $key).'")</script>';
    } elseif (isset($_POST['update'])) {
        // 修改数据
        $key = $_POST['key'];
        $data = $_POST;
        unset($data['update'], $data['key']);
        echo '<script>alert("'.updateRecord($tableName, $key, $data).'")</script>';
    }
    $tableData = getTableData($tableName);
}
?>

<!DOCTYPE html>
<html>
<head>
    <title>数据库管理系统</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            margin: 0;
            padding: 0;
            background-color: #f5f5f5;
        }

        h2 {
            background-color: #333;
            color: #fff;
            text-align: center;
            padding: 10px;
        }

        table {
            border-collapse: collapse;
            width: 80%;
            margin: auto;
            background-color: #fff;
        }

        th, td {
            padding: 10px;
            text-align: center;
        }

        th {
            background-color: #333;
            color: #fff;
        }

        tr:nth-child(even) {
            background-color: #f2f2f2;
        }

        tr:hover {
            background-color: #ddd;
        }

        form {
            display: inline;
        }

        input {
            text-align: center;
        }

        input[type="text"] {
            width: 100%;
            padding: 5px;
        }

        input[type="submit"] {
            background-color: #333;
            color: #fff;
            border: none;
            padding: 5px 10px;
            cursor: pointer;
        }

        input[type="submit"]:hover {
            background-color: #555;
        }
    </style>
</head>
<body>
<h2>Database <?php echo $database ?></h2>
<table>
    <?php foreach ($tableNames as $name) { ?>
        <tr>
            <td><?php echo '<a href="?table=' . $name . '">' . $name . '</a>'; ?></td>
        </tr>
    <?php } ?>
</table>
<?php if (isset($tableData)) { ?>
    <h2 colspan=100%><?php echo 'Table ' . $tableName; ?></h2>
    <table>
        <tr>
            <?php foreach (getTableHeader($tableName)as $key) { ?>
                <th><?php echo $key; ?></th>
            <?php } ?>
            <th>操作</th>
        </tr>
        <?php if (!empty($tableData)) { ?>
            <?php foreach ($tableData as $row) { ?>
                <form method="post">
                    <tr>
                        <?php foreach ($row as $key => $value) { ?>
                            <td>
                                <input type="text" name="<?php echo $key; ?>" value="<?php echo $value; ?>">
                            </td>
                        <?php } ?>
                        <td>
                            <input type="hidden" name="key" value="<?php echo $row[$primaryKey]; ?>">
                            <input type="submit" name="update" value="更新">
                            <input type="submit" name="delete" value="删除">
                        </td>
                    </tr>
                </form>
            <?php } ?>
        <?php } ?>
        <form method="post">
            <tr>
                <?php foreach (getTableHeader($tableName) as $key) { ?>
                    <td>
                        <input type="text" name="<?php echo $key; ?>" placeholder="<?php echo $key; ?>">
                    </td>
                <?php } ?>
                <td>
                    <input type="submit" name="add" value="添加">
                </td>
            </tr>
        </form>
    </table>
<?php } ?>
</body>
</html>

 database.php

<?php
$host = "localhost"; // 数据库主机
$username = "root"; // 数据库用户名
$password = ""; // 数据库密码
$database = "taobao"; // 数据库名称
$conn = new mysqli($host, $username, $password, $database);
$primaryKey = "";
if ($conn->connect_error) {  //数据库连接失败弹出提示
    echo '<script>alert("数据库连接失败")</script>';
    die(); //终止代码
}

function setPrimaryKey($tableName)
{
    global $conn;
    global $primaryKey;
    $sql = "show index from $tableName";
    $result = mysqli_query($conn, $sql);
    $row = mysqli_fetch_assoc($result);
    $primaryKey = $row['Column_name'];
}

function getTableNames()
{
    global $conn;
    $sql = "show tables";
    $result = $conn->query($sql);
    $tableNames = array();
    if ($result->num_rows > 0) {
        while ($row = $result->fetch_assoc()) {
            $tableNames[] = $row['Tables_in_' . $GLOBALS['database']];
        }
    }
    return $tableNames;
}

function getTableData($tableName)
{
    global $conn;
    $sql = "select*from $tableName";
    $result = $conn->query($sql);
    $tableData = array();
    if ($result->num_rows > 0) {
        while ($row = $result->fetch_assoc()) {
            $tableData[] = $row;
        }
    }
    return $tableData;
}

function insertRecord($tableName, $data)
{
    global $conn;
    $keys = implode(', ', array_keys($data)); // 连成字符串
    $values = "'" . implode("', '", array_values($data)) . "'";
    $sql = "insert into $tableName ($keys) values ($values)";
    $result = $conn->query($sql);
    if ($result == 1)
        return '添加成功';
    else
        return '添加失败';
}

function deleteRecord($tableName, $key)
{
    global $conn;
    global $primaryKey;
    $sql = "delete from $tableName where $primaryKey = '$key'";
    $result = $conn->query($sql);
    if ($result == 1)
        return '删除成功';
    else
        return '删除失败';
}

function updateRecord($tableName, $pkey, $data)
{
    global $conn;
    global $primaryKey;
    $set = "";
    foreach ($data as $key => $value) {
        $set .= "$key = '$value', ";
    }
    $set = rtrim($set, ', '); // 移除最后一个字符','
    $sql = "update $tableName set $set where $primaryKey = '$pkey'";
    $result = $conn->query($sql);
    if ($result == 1)
        return '修改成功';
    else
        return '修改失败';
}

function getTableHeader($tableName)
{
    global $conn;
    $sql = "describe $tableName";
    $result = $conn->query($sql);
    $tableHeader = array();
    if ($result) {
        while ($row = $result->fetch_assoc()) {
            $tableHeader[] = $row['Field'];
        }
    }
    return $tableHeader;
}

?>

代码讲解

这次写了两个php文件,一个database.php和一个index.php,database.php实现数据库连接以及增删改等等函数的实现,index.php实现网页页面以及功能逻辑。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

然后连接MySQL的数据库,并在连接失败的时候弹出提示窗口。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

当我们忘记打开数据库的时候就会连接失败,可以看到提示弹窗。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

写一个函数来获取数据库中所有的表名,使用MySQL的show tables命令。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

写一个函数用来获取表的数据,根据表名使用MySQL的select*from命令获取表的数据。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

因为删掉和修改的时候需要知道和找出要删除修改哪一行的数据,所以我们需要找到一个表数据的唯一标识,所以我们写了一个函数来寻找表的主码,使用MySQL的show index。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

实现数据库插入操作,将传入的表单数据中提取出属性名key和对应的属性值value,用MySQL的插入语句完成插入操作,并判断插入操作的结果是否成功,返回插入的结果。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

实现数据库的删除操作,根据传入的表名和主键值用MySQL的删除语句完成删除操作,同样判断操作的结果是否成功,返回删除的结果。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

实现数据库的修改操作,根据传入的表名和主键值以及修改后的表单使用MySQL的update语句完成修改操作,同样判断操作的结果是否成功,返回修改的结果。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

最后是一个获取表属性名的函数,用来展示表的属性,用的是describe语句。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

接下来看index.php文件。

页面展示用的是HTML内嵌php的代码,首先展示数据库中的表名,设计成可以点击的链接,通过点击可以给URL设置要展示的表。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

然后是表名以及表的属性名的展示,后者通过调用我们之前写的函数取到。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

然后判断这个表是否为空,不为空的话,就展示表的数据,并在右侧一栏显示修改和删除的操作,用户可以通过直接在展示的数据中修改并点击更新完成修改操作,可以通过点击删除完成删除的操作。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

然后在最后一行显示添加的功能,用户可以在相应的属性上输入值并点击添加来添加数据。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql

还有一个逻辑判断,即通过判断用户点击了什么操作来调用相应的操作函数来处理,并通过弹出提示窗口来展示操作的结果。

php连接数据库实现前端网页内容增删改查,MySQL数据库系统,PHP,数据库,php,mysql文章来源地址https://www.toymoban.com/news/detail-795174.html

到了这里,关于【PHP网页应用】MySQL数据库增删改查 基础版的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • PHP NBA球迷俱乐部系统Dreamweaver开发mysql数据库web结构php编程计算机网页

    一、源码特点     PHP NBA球迷俱乐部系统是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 基于PHP的NBA球迷俱乐部 二、功能介绍 1、前台主要功能: 系统首页 网站介绍 网站新闻浏览 球迷注册 球队简介浏

    2024年02月09日
    浏览(43)
  • PHP 旅游网站系统mysql数据库web结构apache计算机软件工程网页wamp

    一、源码特点     PHP 旅游网站系统 是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为PHP APACHE,数据库为 mysql5.0,使用php语言开发。 代码下载  https://download.csdn.net/download/qq_41221322/87952564 视频

    2024年02月11日
    浏览(43)
  • PHP 门户信息网站系统mysql数据库web结构apache计算机软件工程网页wamp

    一、源码特点     PHP 门户信息网站系统 是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 下载地址 https://download.csdn.net/download/qq_41221322/88179035 https://download.csdn.net/download/qq_41221322/88179035 视频演示 PHP 门户

    2024年02月13日
    浏览(44)
  • PHP流浪动物招领网站mysql数据库web结构apache计算机软件工程网页wamp

    一、源码特点      PHP流浪动物招领网站 是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 下载链接   null https://download.csdn.net/download/qq_41221322/88190168 视频演示 PHP流浪动物招领网站mysql数据库web结构apach

    2024年02月13日
    浏览(41)
  • PHP 人才信息与招聘系统mysql数据库web结构apache计算机软件工程网页wamp

    一、源码特点     PHP 人才信息与招聘系统 是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为PHP APACHE,数据 库为mysql5.0,使用php语言开发。 视频演示 PHP 人才信息与招聘系统mysql数据库web结构

    2024年02月11日
    浏览(41)
  • PHP&MySQL基础(一):创建数据库并通过PHP进行连接

    PHP同样可以对数据库进行连接,并且实现增删改查、登录注册等功能,这一篇写一下怎么使用PHP去连接MySQL数据库 目录 一、创建数据库 1.1 登录页面 1.2 创建数据库 1.3 创建数据库表 1.4 添加表字段 1.5 插入数据 1.6 导出和导入 二、PHP连接数据库 2.1 通过 mysqli() 进行实例化 2.

    2024年02月03日
    浏览(48)
  • PHP OA协同办公管理系统mysql数据库web结构apache计算机软件工程网页wamp

    一、源码特点     PHP OA协同办公管理系统 是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 代码下载 https://download.csdn.net/download/qq_41221322/87959360 https://download.csdn.net/download/qq_41221322/87959360 演示 PHP OA协同办

    2024年02月11日
    浏览(46)
  • PHP 在线考试管理系统mysql数据库web结构layUI布局apache计算机软件工程网页wamp

    一、源码特点     PHP 在线考试管理系统是一套完善的web设计系统 layUI技术布局 ,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 PHP 在线考试系统1 代码 https://download.csdn.net/download/qq_41221322/88460810 论文 https://download.csdn.net/downloa

    2024年02月08日
    浏览(41)
  • 【PHP系统学习】——Laravel框架数据库的连接以及数据库的增删改查的详细教程

    👨‍💻个人主页 :@开发者-曼亿点 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 曼亿点 原创 👨‍💻 收录于专栏 :PHP程序开发 —   按照 MVC 的架构,对数据的操作应该放在 Model 中完成,但如果不使用 Model,我们也可以用 laravel框架提供的 D8 类

    2024年04月15日
    浏览(40)
  • SpringBoot结合Vue.js+axios框架实现增删改查功能+网页端实时显示数据库数据(包括删除多条数据)

    本文适用对象:已有基础的同学,知道基础的SpringBoot配置和Vue操作。 在此基础上本文实现基于SpringBoot和Vue.js基础上的增删改查和数据回显、刷新等。 实现步骤: 第1步:编写动态请求响应类:在启动类同父目录下创建controller包,在包下创建DataController类,添加@RestController、

    2024年02月04日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包