php实现排序功能(提供全部)

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: php实现排序功能(提供全部)
作者:陈业贵 华为云享专家 51cto(专家博主 明日之星 TOP红人)

@TOC


前言

和大家一起完成php+mysqli排序功能的实现.

一、sql:

-- phpMyAdmin SQL Dump
-- version 4.5.1
-- http://www.phpmyadmin.net
--
-- Host: 127.0.0.1
-- Generation Time: 2022-03-17 17:19:09
-- 服务器版本: 10.1.13-MariaDB
-- PHP Version: 5.6.21

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";


/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8mb4 */;

--
-- Database: `a`
--

-- --------------------------------------------------------

--
-- 表的结构 `search`
--

CREATE TABLE `search` (
  `id` int(11) NOT NULL DEFAULT '0',
  `content` text COLLATE utf8_vietnamese_ci NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_vietnamese_ci;

--
-- 转存表中的数据 `search`
--

INSERT INTO `search` (`id`, `content`) VALUES
(666, 'cyg'),
(2, 'liwen'),
(555, 'liwen&cyg');

/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

二、使用步骤

核心问题:
1.怎么链接数据库呢?

$link=mysqli_connect('localhost','root','','a');

解析:链接数据库,在自己的电脑本地地址上localhost。数据库软件用户名:root.密码"", 数据库名:a
2.怎么设置链接的数据库的字符编码呢?

mysqli_set_charset($link,'utf8');

设置这种utf8编码,不至于有汉字乱码。
3.怎么运行php中的sql呢?

mysqli_query($link,$sql);

解析:第一个参数是数据库链接赋值的变量。第二个参数是sql语句变量

4.怎么在插入语句中写变量呢?

$sql = "INSERT INTO search(id,content)
VALUES ('{$id}','{$content}')";

解析:按照这种格式来就行了

5.排序的sql语句,升序怎么写?从小到大的是升序。越来越大

$sql = "SELECT id,content FROM search ORDER BY id";

6.从大到小的降序sql怎么写?越来越小

$sql = "SELECT id,content FROM search ORDER BY id desc";

7.mysqli_query遍历出来的数据要转化为数组才能运行.

$row=mysqli_fetch_array($result)

解析:因为foreach不支持mysqli_query数据直接输出

1.cyg.php

代码如下(示例):

<?php
$link=mysqli_connect('localhost','root','','a');
//然后是指定php链接数据库的字符集
mysqli_set_charset($link,'utf8');
$sql="select * from search";
$result=mysqli_query($link,$sql);//运行sql

?>
<!--显示的效果-->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <table border="1" cellpadding="5">
        <tr>
            <td>id</td>
            <td>标题</td>
            <td>内容</td>
        
        <?php 
            while ($row=mysqli_fetch_array($result)) {//把对象变成数组输出,不然会报错哦
                
        ?>
        <tr>
            <td><?=$row['id'];?></td>
            <td><?=$row['content'];?></td>

            
        </tr>
        <?php 
        }
        ?>
        <td><a href="create.php">创建才能排序哦</a></td>
            <td><a href="asc.php">升序</a></td><!--从小到大-->
            <td><a href="desc.php">降序</a></td><!--从大到小-->
        </tr>
    </table>
</body>
</html>

2.create.php

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <form action="create.php" method="POST">
    <input type="text" name="id">
        <input type="text" name="content">
        
        <input type="submit" value="提交">
    </form>
</body>
</html>
<?php
if(!$_POST['content']||!$_POST['id'])
{
exit();
}
$content=$_POST['content'];
$id=$_POST['id'];

$link=mysqli_connect('localhost','root','','a');
//然后是指定php链接数据库的字符集
mysqli_set_charset($link,'utf8');
$sql = "INSERT INTO search(id,content)
VALUES ('{$id}','{$content}')";
 
$result=mysqli_query($link,$sql);
echo "<script>alert('创建成功');</script>";
?>
<button><a href="cyg.php">返回</a></button>

2.asc.php

<?php
$link=mysqli_connect('localhost','root','','a');
//然后是指定php链接数据库的字符集
mysqli_set_charset($link,'utf8');
$sql = "SELECT id,content FROM search ORDER BY id";
 
$result=mysqli_query($link,$sql);

?>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <table border="1" cellpadding="5">
        <tr>
            <td>id</td>
            <td>标题</td>
            <td>内容</td>
        
        <?php 
            while ($row=mysqli_fetch_array($result)) {//把对象编程数组输出,不然会报错哦
                
        ?>
        <tr>
            <td><?=$row['id'];?></td>
            <td><?=$row['content'];?></td>

            
        </tr>
        <?php 
        }
        ?>
        <td><a href="create.php">创建才能排序哦</a></td>
            <td><a href="asc.php">升序</a></td><!--从小到大-->
            <td><a href="desc.php">降序</a></td><!--从大到小-->
        </tr>
    </table>
</body>
</html>

2.desc.php

<?php
$link=mysqli_connect('localhost','root','','a');
//然后是指定php链接数据库的字符集
mysqli_set_charset($link,'utf8');
$sql = "SELECT id,content FROM search ORDER BY id desc";
 
$result=mysqli_query($link,$sql);

?>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <table border="1" cellpadding="5">
        <tr>
            <td>id</td>
            <td>标题</td>
            <td>内容</td>
        
        <?php 
            while ($row=mysqli_fetch_array($result)) {//把对象编程数组输出,不然会报错哦
                
        ?>
        <tr>
            <td><?=$row['id'];?></td>
            <td><?=$row['content'];?></td>

            
        </tr>
        <?php 
        }
        ?>
        <td><a href="create.php">创建才能排序哦</a></td>
            <td><a href="asc.php">升序</a></td><!--从小到大-->
            <td><a href="desc.php">降序</a></td><!--从大到小-->
        </tr>
    </table>
</body>
</html>

总结

讲解完了,谢谢大家的访问。

相关文章
|
1月前
|
编译器 PHP 开发者
深入PHP 7新特性:性能优化与功能增强
【7月更文挑战第15天】本文将深入探讨PHP 7版本中引入的一系列新特性,重点分析这些特性如何对PHP应用的性能进行优化和对功能进行增强。我们将从类型声明的引入、抽象语法树(AST)的改进、到性能提升的各个方面进行剖析,并通过实际代码示例来展示这些新特性的应用。文章旨在为PHP开发者提供一份详尽的指南,帮助他们更好地利用PHP 7的新特性来构建更快、更稳定的应用程序。
33 9
|
2月前
|
大数据 PHP 开发者
深入PHP 7新特性:性能优化与功能增强
【6月更文挑战第19天】在PHP 7的发布中,开发者社区迎来了一系列令人振奋的性能提升和功能增强。本文将深入探讨这些变化如何影响了PHP的应用开发,特别是性能优化方面的细节,如改进的Zend引擎、新增的运算符以及错误处理机制的变革等。我们还将一探究竟,看看这些更新如何使得PHP继续在Web开发领域中保持其竞争力。
|
2月前
|
缓存 Java 编译器
PHP 8的新特性:性能与功能的双重提升
【6月更文挑战第9天】PHP 8携JIT编译器提升性能,引入类型推导和命名参数增强功能。JIT编译器提高执行速度,性能比PHP 7.4提升10%-15%。类型推导增强类型安全性,命名参数提升代码可读性。其他改进包括函数调用优化、垃圾回收机制改进及字符串和数组处理优化,实现性能与功能双重提升,为开发者带来更高效、可靠的PHP体验。
|
1月前
|
存储 PHP 索引
|
2月前
|
Ubuntu 中间件 Linux
linux php添加扩展zip libzip ZipArchive功能
linux php添加扩展zip libzip ZipArchive功能
66 1
|
3月前
|
PHP
PHP公众号开发给用户发微信消息提醒功能
该内容是一个关于如何在时间紧迫的情况下,通过微信客服消息接口实现用户资金到账或成员变动时发送微信通知的项目总结。
42 2
|
2月前
|
存储 安全 关系型数据库
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
|
2月前
|
前端开发 关系型数据库 MySQL
使用 PHP 和 MySQL 实现留言板功能
使用 PHP 和 MySQL 实现留言板功能
61 0
|
3月前
|
数据采集 监控 API
使用PHP实现动态代理IP的功能
使用PHP实现动态代理IP的功能
|
3月前
|
SQL 前端开发 PHP
【PHP开发专栏】PHP分页功能的设计与实现
【4月更文挑战第29天】本文介绍了PHP实现分页功能,包括设计逻辑(用户界面和后端处理)、SQL查询优化和前端展示。后端通过计算页码和偏移量进行数据查询,前端展示分页信息并处理用户交互。优化点有使用索引、LIMIT语句和避免子查询。此外,还提到了无限滚动、AJAX分页和分页大小选择等高级功能,以提升用户体验。
48 0