fonction de requête de détails de transaction thinkPHP
Cet article présente principalement la fonction de requête de détails de transaction thinkPHP, analyse la fonction de requête de base de données thinkPHP et affiche les compétences opérationnelles liées aux résultats sous forme d'exemples. Les amis dans le besoin peuvent s'y référer
Cet article analyse le. Détails de la transaction thinkPHP avec exemples. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
Détails de la transaction
Généralement, ils sont sur une base mensuelle, y compris la date de la transaction, le montant de la transaction, le statut de la transaction (facultatif ou non )
volume total des transactions, etc.
S'il y a beaucoup de données, il est préférable de les paginer.
Il est préférable de vérifier quel commerçant spécifique.
1. Simulez SQL pour implémenter la fonction de requête
SELECT a.id as user_id,a.username,b.name as store_name,c.id as order_id,c.price,c.paytime,c.sendtime,c.receivetime FROM sh_user a LEFT JOIN sh_store b on a.id = b.user_id LEFT JOIN sh_order c ON b.id = c.store_id WHERE a.opener_id = 1 and a.`status` = 1 and c.status = 1 ORDER BY c.id desc; SELECT count(b.id) as count ,sum(c.price) as total_price FROM sh_user a LEFT JOIN sh_store b on a.id = b.user_id LEFT JOIN sh_order c ON b.id = c.store_id WHERE a.opener_id = 1 and a.`status` = 1 and c.status = 1;
La requête SQL est essentiellement effectuée, et le reste consiste à utiliser php. , thinkphp implémente cette fonction de requête et ajoute de la logique et des conditions.
// 商户交易 public function trade(){ if($type = $this->_request('type','trim')){ $s_year = $this->_request('s_year','trim'); $s_month = $this->_request('s_month','trim'); $s_user_id = $this->_request('s_user_id','trim,intval'); $this->assign('s_user_id',$s_user_id); if($type == 'last'){ // 获取上一月 if($s_month==1){ $useYear = $s_year-1; $useMonth = 12; }else{ $useYear = $s_year; $useMonth = $s_month-1; } } if($type == 'next'){ // 获取下一月 if($s_month==12){ $useYear = $s_year+1; $useMonth = 1; }else{ $useYear = $s_year; $useMonth = $s_month+1; } } if ($type == 'selectuser'){ $useYear = $s_year; $useMonth = $s_month; } }else{ // 获取当前年 月 $useYear = date('Y'); $useMonth = date('m'); } $this->assign('s_year',$useYear); $this->assign('s_month',$useMonth); $b_time = strtotime($useYear.'-'.$useMonth.'-'.'1'); $e_time = strtotime($useYear.'-'.$useMonth.'-'.date('t',strtotime($b_time)).' 23:59:59'); if(isset($s_user_id) && $s_user_id > 0){ $where['a.id'] = $s_user_id; } $where['a.opener_id'] = $this->opener_id; $where['a.status'] = 1; // 合法的用户 $where['c.status'] = 1; // 合法的订单 $where['c.paytime'] = array(array('gt',$b_time),array('lt',$e_time),'and'); $count_and_totalprice = M()->table('sh_user a') ->join('sh_store b on a.id = b.user_id') ->join('sh_order c on b.id = c.store_id') ->where($where) ->field('count(b.id) as count ,sum(c.price) as totalprice') ->find(); $count = $count_and_totalprice['count']; $totalprice = $count_and_totalprice['totalprice'] ? $count_and_totalprice['totalprice'] : 0; $Page = new Page($count, 10); $list = M()->table('sh_user a') ->join('sh_store b on a.id = b.user_id') ->join('sh_order c on b.id = c.store_id') ->where($where) ->order('c.id desc') ->limit($Page->firstRow.','.$Page->listRows) ->field('a.id as user_id,a.username,b.name as store_name,c.id as order_id,c.price,c.paytime,c.sendtime,c.receivetime') ->select(); foreach ($list as $k => $v) { if($v['sendtime'] == 0 && $v['receivetime'] == 0){ $list[$k]['progress'] = '1'; // 已付款,待发货 } if($v['sendtime'] > 0 && $v['receivetime'] == 0){ $list[$k]['progress'] = '2'; // 已发货,待签收 } if($v['sendtime'] > 0 && $v['receivetime'] > 0){ $list[$k]['progress'] = '3'; // 交易完成 } } // 获取拓展员用户 $user_list = M('User') ->where(array('opener_id'=>$this->opener_id)) ->field('id,username') ->select(); $this->assign('user_list',$user_list); $this->assign('totalprice',$totalprice); $this->assign('page',$Page->show()); $this->assign('list', $list); $this->display(); }
partie html Apprenez-en davantage sur la conception. La chose la plus importante est l'affichage de l'interface. Toutes les données sont basées sur plusieurs affichages, alors déterminez d'abord quelles données vous avez. dont vous avez besoin, puis obtenez-les.
<include file="Public:head" title="交易详情" /> <style> .top { background-color: #eee; height: 50px; line-height: 50px; font-size: 18px; border-bottom: #ddd 1px solid; margin-bottom: -1px; } .list-group{ border: 1px solid #DDDDDD; } .list-group .list-group-item { text-align: left; line-height: 25px; border: none; background-color: #F9F9F9; font-size: 14px; } #select-date { padding: 0px 10px; } #select-date .date-txt { font-size: 18px; } #total { width: 140px; height: 140px; background-color: #EC6C00; margin: auto; } #total .money-txt { color: white; padding-top: 10px; } #datalist { margin-top: 30px; } #relief .form-control{ margin-top: 10px; margin-bottom: 10px; /*background-color: #FFCE42;*/ } .page{ margin-right: 10px; margin-bottom: 20px; } .table th { color: #C4C4C4; } .table tbody tr td+td+td { color: #D3964F; } </style> <script type="text/javascript"> function lastMonth(){ todo('last'); } function nextMonth(){ todo('next'); } function selectUser(){ todo('selectuser'); } function todo(type){ var s_year = $('#s_year').val(); var s_month = $('#s_month').val(); var s_user_id = $('#s_user_id').val(); window.location.href="{sh::U('User/trade')}&s_year="+s_year+"&s_month="+s_month+"&s_user_id="+s_user_id+"&type="+type; } </script> <body> <p data-example-id="list-group-btns" class="bs-example"> <p id="select-date"> <ul class="pager"> <li class="previous"><a onclick="lastMonth();"><span aria-hidden="true">←</span> </a></li> <span class="date-txt"><strong>{sh:$s_year}.{sh:$s_month}</strong> <present name="paymentData"><span class="glyphicon glyphicon-ok-sign" aria-hidden="true"></span></present> </span> <input type="text" id="s_year" value="{sh:$s_year}" hidden="hidden"> <input type="text" id="s_month" value="{sh:$s_month}" hidden="hidden"> <li class="next"><a onclick="nextMonth();"><span aria-hidden="true">→</span></a></li> </ul> </p> <p id="relief"> <select id="s_user_id" onchange="selectUser();" class="form-control btn-success"> <option value="">全部商户</option> <volist name="user_list" id="vo"> <option value="{sh:$vo.id}" <eq name="vo.id" value="$s_user_id">selected="selected"</eq>>{sh:$vo.username}</option> </volist> </select> </p> <p id="total" class="img-circle"> <p class="text-center money-txt"> <h3>总交易金额</h3> <h2>¥{sh:$totalprice}</h2> </p> </p> <p id="datalist"> <table class="table table-striped"> <thead> <tr> <th>商户</th> <th>日期</th> <th>交易金额</th> <!-- <th>状态</th> --> </tr> </thead> <tbody> <empty name="list"><tr><td class="text-center" colspan="4">暂无数据</td></tr></empty> <volist name="list" id="vo"> <tr> <td>{sh:$vo.username}</td> <td>{sh:$vo.paytime|date="Y-m-d H:i",###}</td> <td>{sh:$vo.price}</td> <!-- <td> <if condition="$vo.progress eq 1"><span class="text-primary">待发货</span> <elseif condition="$vo.progress eq 2"/><span class="text-danger">待签收</span> <elseif condition="$vo.progress eq 3"/><span class="text-success"><strong>已完成</strong></span> </if> </td> --> </tr> </volist> </tbody> </table> <p class="page text-right"> {sh:$page} </p> </p> </body> </html>
Recommandations associées :
PHP implémente simplement la fonction d'enregistrement des visites de sites Web
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Pour exécuter le projet ThinkPHP, vous devez : installer Composer ; utiliser Composer pour créer le projet ; entrer dans le répertoire du projet et exécuter php bin/console serve ; visiter http://localhost:8000 pour afficher la page d'accueil.

Téléchargez la dernière version de l'application de réservation de billets 12306. C'est un logiciel d'achat de billets de voyage dont tout le monde est très satisfait. Il est très pratique d'aller où vous voulez. Il existe de nombreuses sources de billets fournies dans le logiciel. -authentification par nom pour acheter des billets en ligne. Tous les utilisateurs Vous pouvez facilement acheter des billets de voyage et des billets d'avion et profiter de différentes réductions. Vous pouvez également commencer à réserver à l'avance pour récupérer des billets. Vous pouvez réserver des hôtels ou des transferts spéciaux en voiture. Grâce à lui, vous pouvez aller où vous voulez et acheter des billets en un seul clic. Voyager est plus simple et plus pratique, ce qui rend l'expérience de voyage de chacun. plus confortable. Désormais, l'éditeur le détaille en ligne. Offre à 12306 utilisateurs un moyen de consulter l'historique des achats de billets. 1. Ouvrez Railway 12306, cliquez sur Mon dans le coin inférieur droit, puis cliquez sur Ma commande. 2. Cliquez sur Payé sur la page de commande. 3. Sur la page payante

ThinkPHP dispose de plusieurs versions conçues pour différentes versions de PHP. Les versions majeures incluent 3.2, 5.0, 5.1 et 6.0, tandis que les versions mineures sont utilisées pour corriger les bogues et fournir de nouvelles fonctionnalités. La dernière version stable est ThinkPHP 6.0.16. Lorsque vous choisissez une version, tenez compte de la version PHP, des exigences en matière de fonctionnalités et du support de la communauté. Il est recommandé d'utiliser la dernière version stable pour de meilleures performances et une meilleure assistance.

Comment vérifier mes diplômes universitaires sur Xuexin.com ? Vous pouvez vérifier vos diplômes universitaires sur Xuexin.com. De nombreux utilisateurs ne savent pas comment vérifier leurs diplômes universitaires sur Xuexin.com. Ensuite, l'éditeur vous propose un didacticiel graphique sur la façon de vérifier vos diplômes universitaires sur Xuexin.com. les utilisateurs viennent jeter un oeil ! Tutoriel d'utilisation de Xuexin.com : Comment vérifier vos diplômes universitaires sur Xuexin.com 1. Entrée Xuexin.com : https://www.chsi.com.cn/ 2. Requête sur le site Web : Étape 1 : Cliquez sur l'adresse Xuexin.com ci-dessus pour accéder à la page d'accueil Cliquez sur [Requête sur l'éducation] ; Étape 2 : Sur la dernière page Web, cliquez sur [Requête] comme indiqué par la flèche dans la figure ci-dessous. Étape 3 : Cliquez ensuite sur [Connexion au fichier de crédits académiques] sur la nouvelle page ; Étape 4 : Sur la page de connexion, saisissez les informations et cliquez sur [Connexion] ;

Étapes pour exécuter ThinkPHP Framework localement : Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un hôte virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

Comparaison des performances des frameworks Laravel et ThinkPHP : ThinkPHP fonctionne généralement mieux que Laravel, en se concentrant sur l'optimisation et la mise en cache. Laravel fonctionne bien, mais pour les applications complexes, ThinkPHP peut être mieux adapté.

Étapes d'installation de ThinkPHP : Préparez les environnements PHP, Composer et MySQL. Créez des projets à l'aide de Composer. Installez le framework ThinkPHP et ses dépendances. Configurez la connexion à la base de données. Générez le code de l'application. Lancez l'application et visitez http://localhost:8000.

MySQL et PL/SQL sont deux systèmes de gestion de bases de données différents, représentant respectivement les caractéristiques des bases de données relationnelles et des langages procéduraux. Cet article comparera les similitudes et les différences entre MySQL et PL/SQL, avec des exemples de code spécifiques à illustrer. MySQL est un système de gestion de bases de données relationnelles populaire qui utilise le langage de requête structuré (SQL) pour gérer et exploiter des bases de données. PL/SQL est un langage procédural unique à la base de données Oracle et est utilisé pour écrire des objets de base de données tels que des procédures stockées, des déclencheurs et des fonctions. même
