PHP SQL:在显示所有数据的同时更改过滤数据的样式

php sql:在显示所有数据的同时更改过滤数据的样式

本文档旨在解决在使用 PHP 和 SQL 查询数据库时,如何在网页上显示所有数据,并同时突出显示或改变特定过滤数据的样式的问题。我们将提供一种解决方案,该方案允许用户搜索特定 ID,并在显示所有记录的同时,突出显示匹配的记录。如果搜索的 ID 不存在,则显示“Record not found”消息。

实现原理

核心思路是将搜索操作和显示操作分离。首先,根据用户输入的搜索关键词执行查询,判断是否存在匹配的记录。如果存在,则保存匹配的 ID。然后,执行查询以获取所有数据,并在循环遍历数据时,检查当前记录的 ID 是否与之前保存的匹配 ID 相等。如果相等,则应用特定的样式(例如,更改背景颜色或加粗字体)。

具体实现步骤

创建搜索表单:

首先,创建一个简单的 HTML 表单,允许用户输入要搜索的员工 ID。

立即学习“PHP免费学习笔记(深入)”;

    

处理搜索关键词:

在 PHP 中,获取用户输入的搜索关键词。


查询匹配的 ID:

根据搜索关键词执行 SQL 查询,查找匹配的 ID。

query($sql_want_search);    $searched_data = []; // 使用数组保存所有匹配的ID    if ($result_want_search->num_rows > 0) {        while ($row_want_search = $result_want_search->fetch_assoc()) {            $searched_data[] = $row_want_search["id"]; // 将匹配的ID添加到数组        }    } else {        echo "Record not found.";        return; // 提前退出,避免执行后续的显示代码    }}?>

注意:

使用预处理语句和参数绑定来防止 SQL 注入攻击。如果查询结果为空,则显示 “Record not found.” 消息并退出。

查询所有数据并应用样式:

执行 SQL 查询以获取所有数据,并在循环遍历数据时,检查当前记录的 ID 是否与之前保存的匹配 ID 数组中。如果相等,则应用特定的样式。

query($sql_initial);if ($result_initial->num_rows > 0) {    while ($row_initial = $result_initial->fetch_assoc()) {        $is_highlighted = false;        if (!empty($search_keyword) && in_array($row_initial["id"], $searched_data)) {            $is_highlighted = true;        }        if ($is_highlighted) {            echo "" . $row_initial["id"] . " " . $row_initial["name"] . " " . $row_initial["address"] . " 
"; } else { echo $row_initial["id"] . " " . $row_initial["name"] . " " . $row_initial["address"] . "
"; } }}?>

解释:

$is_highlighted 变量用于标记当前记录是否需要突出显示。in_array() 函数用于检查当前记录的 ID 是否在 $searched_data 数组中。如果 $is_highlighted 为 true,则使用 标签将记录加粗。

完整代码示例

                    query($sql_want_search);        if ($result_want_search->num_rows > 0) {            while ($row_want_search = $result_want_search->fetch_assoc()) {                $searched_data[] = $row_want_search["id"]; // 将匹配的ID添加到数组            }        } else {            echo "Record not found.";            goto end_script; // 使用 goto 语句直接跳到脚本末尾        }    }    // Initial display all data before search or if search successful    $sql_initial = "SELECT id, name, address FROM employee";    $result_initial = $conn->query($sql_initial);    if ($result_initial->num_rows > 0) {        while ($row_initial = $result_initial->fetch_assoc()) {            $is_highlighted = false;            if (!empty($search_keyword) && in_array($row_initial["id"], $searched_data)) {                $is_highlighted = true;            }            if ($is_highlighted) {                echo "" . $row_initial["id"] . " " . $row_initial["name"] . " " . $row_initial["address"] . " 
"; } else { echo $row_initial["id"] . " " . $row_initial["name"] . " " . $row_initial["address"] . "
"; } } } end_script: // 脚本末尾的标签 ?> document.onkeydown = function(evt) { var keyCode = evt ? (evt.which ? evt.which : evt.keyCode) : event.keyCode; if (keyCode == 13) { //your function call here document.searchForm.submit(); } }

重要优化:

使用 goto 语句: 在 Record not found 的情况下,使用 goto end_script; 直接跳到脚本末尾,避免执行后续的显示所有数据的代码,提高效率。 请注意,goto 语句应谨慎使用,因为它可能会降低代码的可读性。 在这个例子中,使用 goto 可以避免嵌套的 if 语句,使代码更简洁。使用数组保存匹配的 ID: 将所有匹配的 ID 保存在数组中,而不是只保存一个 ID,这样可以支持搜索多个 ID 的情况。 例如,如果搜索关键词是 1,2,3,则可以将 ID 为 1、2 和 3 的记录都突出显示。 要实现这个功能,需要修改 SQL 查询语句,使用 IN 运算符。

注意事项

SQL 注入: 务必对用户输入进行过滤和转义,以防止 SQL 注入攻击。 使用预处理语句和参数绑定是防止 SQL 注入的最佳实践。性能: 对于大型数据集,查询所有数据可能会影响性能。 可以考虑使用分页或延迟加载等技术来优化性能。样式: 可以使用 CSS 来定义更丰富的样式,例如更改背景颜色、字体大小、边框等。

总结

通过将搜索操作和显示操作分离,并使用 PHP 和 SQL 查询数据库,我们可以轻松地实现在网页上显示所有数据,并同时突出显示特定过滤数据的样式的功能。 这种方法具有灵活性和可扩展性,可以根据实际需求进行调整和优化。 记住,安全性和性能是开发 Web 应用程序时需要考虑的关键因素。

以上就是PHP SQL:在显示所有数据的同时更改过滤数据的样式的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1581044.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Golangdefer顺序执行与错误处理案例
上一篇 2026年5月10日 10:36:07
HTML文本域怎么添加_HTMLtextarea文本域的创建与属性设置
下一篇 2026年5月10日 10:36:08

相关推荐

  • html5如何用li_html5使用li标签方法【标签用法】

    li标签必须嵌套在ol或ul内,不可直接置于body等非法父元素中;需闭合标签;可嵌套多层列表;不可在dl中使用li替代dt/dd。 如果您希望在HTML5中正确使用 标签来构建列表结构,则需要确保标签始终嵌套在有序列表或无序列表内部。以下是几种标准且兼容的使用方法: 一、在无序列表中使用li标签 …

    2026年5月10日
    500
  • html视频playsinline属性作用_html视频内联播放功能

    playsinline属性用于视频内联播放,避免移动设备自动全屏;添加playsinline和webkit-playsinline可提升兼容性,适用于短视频嵌入等场景,需注意安卓厂商实现差异及autoplay时需静音。 在HTML中,playsinline 是一个用于 标签的布尔属性,主要作用是**…

    2026年5月10日
    000
  • 如何用css做form表单?css form表单制作的方法

    网页中的表单是用于搜集用户的输入,简而言之,就是表单是网页与用户交互的一个不可或缺的元素,也就是说表单是用于向服务器传输数据的,总而言之,表单在网页中是非常重要的,所以,接下来的这篇文章将给大家来介绍如何用css来制作一个form表单,话不多说,让我们来看一下用css做form表单的具体内容。 首先…

    2026年5月10日
    000
  • HTML文本域怎么添加_HTMLtextarea文本域的创建与属性设置

    使用标签创建多行文本输入框,可设置name、rows、cols、placeholder、disabled、readonly、required和maxlength等属性;2. 常与form结合使用,实现表单提交时的数据验证与传输,提升用户体验。 在HTML中,textarea 元素用于创建多行文本输入…

    2026年5月10日
    000
  • Golangdefer顺序执行与错误处理案例

    defer执行顺序为后进先出,常用于资源释放和错误处理;通过命名返回值,defer可修改返回错误,如文件关闭或数据库事务回滚时确保清理操作执行。 在Go语言中,defer 是一个非常有用的关键字,用于延迟函数调用的执行,直到外围函数即将返回时才执行。它常被用于资源释放、锁的释放或错误处理等场景。理解…

    2026年5月10日
    000
  • html如何插入本地图片 本地图片引用教程

    html如何插入本地图片 本地图片引用教程html如何插入本地图片 本地图片引用教程html如何插入本地图片 本地图片引用教程html如何插入本地图片 本地图片引用教程

    要在html中插入本地图片,需正确使用标签并指定路径。1. 使用src属性指向图片文件,推荐使用相对路径以确保可移植性;2. 注意路径拼写、大小写及文件是否存在;3. 图片无法显示时检查路径、缓存、权限,并通过开发者工具查看请求状态码;4. 优化加载速度可通过压缩图片、选择合适格式、使用cdn、懒加…

    2026年5月10日 用户投稿
    000
  • HTML文档语言怎么设置_HTML语言属性设置方法

    设置HTML文档语言需在标签添加lang属性,如lang=”zh-CN”表示简体中文;2. 此设置提升SEO,帮助搜索引擎准确识别内容语言;3. 有助于辅助技术正确朗读,改善用户体验;4. 多语言页面可在特定元素上设置lang属性以覆盖根语言,确保各语言片段被正确处理。 HT…

    2026年5月10日
    000
  • React Hooks实现可拖拽组件:声明式渲染与事件处理指南

    本教程深入探讨了在React中使用Hooks创建可拖拽组件的正确方法。我们将分析直接操作DOM的常见陷阱,例如导致拖拽功能无法在首次尝试时生效的问题,并详细介绍如何利用React的声明式特性和事件系统,通过JSX直接绑定拖拽事件,实现流畅、响应式的拖拽体验。内容涵盖关键的HTML5拖拽属性、Reac…

    2026年5月10日
    000
  • JavaScript中高效移除指定CSS类名DOM元素的方法

    本教程详细探讨了在javascript中高效移除具有特定css类名的dom元素的方法。我们将介绍传统removechild方法的潜在复杂性,并重点推荐使用现代且简洁的element.prototype.remove()方法。通过具体的表格行移除示例,文章将指导读者如何利用该方法清空动态生成的ui组件…

    2026年5月10日
    000
  • 在Shopify主题中高效集成外部与内部JavaScript脚本

    本教程详细介绍了如何在shopify主题中直接注入自定义javascript脚本标签的两种核心方法。文章涵盖了通过liquid的`script_tag`过滤器引入外部url托管的脚本,以及将自定义js文件上传至主题资产并利用`asset_url`和`script_tag`过滤器进行引用的步骤。旨在提…

    2026年5月10日
    000
  • 如何在CSS中精确计算文本宽度,考虑大写和小写字母的差异?

    解决文本宽度计算问题 在css文本大小设置中,小写英文字符并不遵循所设定的字体大小,导致使用文本字数乘以字体大小无法准确获取文本宽度。本文旨在讨论如何解决这一问题。 匹配大写和小写英文字符 为了分别获得大写和小写英文字符的数量,可以使用正则表达式: 立即学习“前端免费学习笔记(深入)”; 大写英文:…

    2026年5月10日
    000
  • vs html怎么运行_Visual Studio运行html步骤【指南】

    Visual Studio中运行HTML文件可通过四种方式实现:一、使用IIS Express或静态服务器,打开项目后设HTML为起始页并点击浏览器图标运行;二、手动在资源管理器中找到文件,双击用默认浏览器打开;三、安装Web Essentials扩展,右键选择“Preview in Browser…

    2026年5月10日
    000
  • Golang开发基础学生信息管理系统

    答案:通过分层架构设计,使用Gin框架处理API请求,结合database/sql与MySQL交互,定义Student结构体作为数据模型,并利用接口实现解耦,确保系统的可维护性与扩展性。 搭建一个基于Golang的学生信息管理系统,核心在于利用其简洁的语法、强大的并发特性和丰富的标准库,快速实现数据…

    2026年5月10日
    000
  • html5文件如何实现上传权限验证 html5文件JWT令牌的携带方式

    首先前端登录获取JWT并存储,再通过XMLHttpRequest或Fetch API在上传文件时携带Authorization头发送令牌;服务端需解析并验证JWT签名、有效期及权限,确认无误后处理文件上传请求。 如果需要在HTML5中实现文件上传时的权限验证,并通过JWT令牌确保请求的安全性,必须在…

    2026年5月10日
    000
  • HTML5如何设置隐藏_HTML5元素隐藏属性设置【隐藏】

    HTML5元素隐藏有六种方法:一、hidden属性(移除渲染树);二、CSS display: none(不占布局);三、visibility: hidden(占位但不可见);四、opacity+transform(视觉隐藏且可交互);五、aria-hidden配合视觉隐藏类(兼顾无障碍);六、da…

    2026年5月10日
    100
  • PHP命令怎么实现文本替换_PHP命令行批量文本替换技巧

    使用PHP命令行可高效实现文本替换。1. 单文件替换:通过php -r调用file_get_contents、str_replace和file_put_contents将“hello”替换为“world”。2. 批量处理:编写脚本遍历目录下指定类型文件,循环读取、替换并写回内容。3. 支持正则:使用…

    2026年5月10日
    000
  • Golang模块初始化与go.mod文件配置实践

    Go语言从1.11引入模块机制,通过go.mod实现依赖管理;执行go mod init创建模块,自动生成go.mod文件;该文件包含module、go、require等核心指令,分别定义模块路径、Go版本和依赖项;实际开发中常用go mod tidy整理依赖,replace替换私有库,exclud…

    2026年5月10日
    000
  • php数据如何使用策略模式优化代码_php数据策略模式应用场景

    策略模式通过封装不同算法为独立类,实现业务逻辑与具体策略解耦。在PHP中适用于折扣计算、数据导出、权限控制等场景,由上下文调用统一接口,支持运行时切换行为,避免冗长条件判断,提升可维护性与扩展性,符合开闭原则。 在PHP开发中,当处理多种数据格式、计算规则或业务逻辑分支时,代码容易变得臃肿且难以维护…

    2026年5月10日
    000
  • C++如何进行代码格式化_使用Clang-Format统一C++项目代码风格的配置

    Clang-Format 可统一 C++ 代码风格,支持通过包管理器安装,生成 .clang-format 配置文件并选择或自定义格式规则,如 IndentWidth、ColumnLimit 等;可用于格式化单个或多个文件,结合 Git pre-commit 脚本自动格式化提交的代码,并与 VS C…

    2026年5月10日
    000
  • 使用PHP和AJAX实现待办事项的无刷新删除

    本文详细介绍了如何利用PHP、MySQL和jQuery AJAX技术,实现待办事项列表的无刷新删除功能。通过客户端JavaScript发送异步请求到服务器端PHP脚本,PHP负责数据库操作,JavaScript则在成功后动态更新页面UI,从而提供流畅的用户体验,避免了页面整体刷新。 引言 在现代We…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信