用MVC架构时,怎么进行多表联合查询?求一比较优秀的解决办法
用MVC架构时,怎么进行多表联合查询?求一比较优秀的解决办法
回复讨论(解决方案)
任何框架都不可能预测你的需求
你只能按框架的约束组织你的数据
多表查询和MVC框架没有任何关系。
我给你说一些常用的方法吧,
1. 简单的,select 嵌套 select : select A.c1,A.c2,(select B.c3 from B where A.c4=B.c5) from A where c6=xxx
2. 简单的,select多表: select A.c1,A.c2,B.c3,B.c4 from A,B where A.c5=B.c6
3. 灵活的 join, left join, right join, outer join
4. union, union all
5. 上面两种或多种混合使用
其实难的sql查询还有很多情况,MVC框架不能够帮你进行多表查询的优化,所以优化了一条查询语句,可能就会让你的系统效率更高。
仅代表个人愚见,笑纳。
多表查询和MVC框架没有任何关系。
我给你说一些常用的方法吧,
1. 简单的,select 嵌套 select : select A.c1,A.c2,(select B.c3 from B where A.c4=B.c5) from A where c6=xxx
2. 简单的,select多表: select A.c1,A.c2,B.c3,B.c4 fr……
我只是想知道,在用MVC开发时,是怎么转向到原生态的SQL,是直接在控制里写很多JOIN 这些吗?
任何框架都不可能预测你的需求
你只能按框架的约束组织你的数据
大侠,可不可以举一两个例子。
如果你用的框架有规范,则按照它的规范来写
如果没有,则原生的 SQL 应该可以。多表查询也是如此。
如果你用的框架有规范,则按照它的规范来写
如果没有,则原生的 SQL 应该可以。多表查询也是如此。
框架有提供一些规范,我是用TP的来做的。之前没有用框架时,就是写了很多的JOIN语句,发现维护起来不容易,如果要修改,要重新去理解去读懂,有可能还会改错了,或范一些比较低级的错误,比如写单引号忘了写之类的。
见手册 6.23 关联模型
我有一个疑问,类似 销售订单表和客户表、用户表,这种表的关系,用面向对象要怎么设计呢
手册上不是有例子吗?
如果你用的框架有规范,则按照它的规范来写
如果没有,则原生的 SQL 应该可以。多表查询也是如此。
+++ 是的......
引用 3 楼 wangzhlin 的回复:多表查询和MVC框架没有任何关系。
我给你说一些常用的方法吧,
1. 简单的,select 嵌套 select : select A.c1,A.c2,(select B.c3 from B where A.c4=B.c5) from A where c6=xxx
2. 简单的,select多表: select A……
根据框架封装的db类了,查看手册或代码,或者你自己用原生的sql连接去写,数据库部分不用框架。
希望对你有帮助。
楼主可以封装成为视图 直接实例化试图就可 如果网站不是很大的话
多表联合查询跟mvc有什么关系?你还是没真正理解mvc是什么。
把你的联合查询封装在model里,由controller去调来获取数据就可以了。
楼上说封装成db的视图,也是一种方法。我发现很少有人在mysql上使用视图。不知为什么。其实视图可以解决很多问题。比如表结构更新后,只需要重新创建视图名称不变就可以了。而不用再去修改代码。可能是现在的新技术太多了,大家都不屑于使用这些老技术了。
谢谢各位的意见。
其实我想针对这种表联合查询的情况,做一个比较好的处理方案,为以后维护方便。最好是能结合类。我之前的系统是用原生态的SQL,发现修改时,容易写错是一个原因,也不好理解这个业务流程。
如果能把表与表的关系,用类来表现,这个方法不知怎么样。
多表查询和Mvc有什么关系
我的系统是用MVC架构的,而一个系统功能里,都会有多表查询的情况。
那么我想知道的是,各位在使用MVC架构开发时,遇到这种多表查询的情况,是直接用原生态SELECT,还是用视图或者存储过程
一般都是 原生态SELECT ,你可以去看看 mvc框架或者cms 的源码就知道了。
一般都是 原生态SELECT ,你可以去看看 mvc框架或者cms 的源码就知道了。
如果用原生态SELECT连接查询出来的数据,用什么对象接收啊?

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)

Sujets chauds

La souris est l'un des périphériques informatiques les plus importants. Cependant, pendant l'utilisation, la molette de la souris tombe inévitablement en panne ou saute de haut en bas, ce qui affecte grandement le fonctionnement de l'utilisateur. Existe-t-il un moyen de résoudre ce problème ? Jetons un coup d'œil à trois façons de résoudre le problème du saut aléatoire de la molette de la souris. Méthode 1 : Vérifiez que les souris produites par différentes marques ont leurs propres caractéristiques. Certaines roulettes de souris ont une sensibilité élevée ou un faible amortissement, ce qui peut entraîner des sauts irréguliers de la molette. Pour déterminer si le problème vient de la souris elle-même, vous pouvez toucher légèrement la molette de la souris et regarder la page se déplacer sur l'écran. Si vous trouvez que votre souris défile de manière trop sensible, vous pouvez envisager d'acheter une nouvelle souris pour résoudre le problème. Méthode 2 : Vérifiez les paramètres de la souris. Des paramètres de souris incorrects peuvent entraîner des sauts aléatoires de la molette de la souris.

PyCharm est un puissant environnement de développement intégré (IDE) Python largement utilisé dans le travail quotidien des développeurs Python. Cependant, nous pouvons parfois rencontrer le problème que PyCharm ne peut pas être ouvert normalement, ce qui peut affecter la progression de notre travail. Cet article présentera quelques problèmes et solutions courants lorsque PyCharm ne peut pas être ouvert, et fournira des exemples de code spécifiques, dans l'espoir de vous aider à résoudre ces problèmes en douceur. Problème 1 : PyCharm plante ou ne répond plus. Raisons possibles : PyCh.

Solution à l'erreur 629 Connexion haut débit Avec le développement rapide de la technologie Internet, le haut débit est devenu un élément indispensable de notre vie quotidienne. Cependant, nous pouvons parfois rencontrer des problèmes lors de l'utilisation du haut débit, tels que l'erreur 629, erreur de connexion haut débit. Cette erreur nous empêche généralement d’accéder normalement à Internet et entraîne de nombreux désagréments. Dans cet article, nous partagerons quelques méthodes pour résoudre l'erreur 629 de connexion haut débit afin de vous aider à résoudre ce problème rapidement. Premièrement, les problèmes de connexion haut débit de l’erreur 629 sont généralement causés par des problèmes de configuration réseau ou de pilote.

Lorsque les utilisateurs utilisent le navigateur Edge, ils peuvent ajouter des plug-ins pour répondre davantage à leurs besoins. Mais lors de l'ajout d'un plug-in, cela indique que ce plug-in n'est pas pris en charge. Comment résoudre ce problème ? Aujourd'hui, l'éditeur partagera avec vous trois solutions. Venez l'essayer. Méthode 1 : essayez d’utiliser un autre navigateur. Méthode 2 : Le Flash Player du navigateur peut être obsolète ou manquant, ce qui rend le plug-in non pris en charge. Vous pouvez télécharger la dernière version sur le site officiel. Méthode 3 : Appuyez simultanément sur les touches « Ctrl+Shift+Delete ». Cliquez sur "Effacer les données" et rouvrez le navigateur.

Les machines à laver jouent un rôle important dans notre vie quotidienne. Cependant, il arrive parfois que les boutons de la machine à laver fonctionnent mal. Cette situation peut nous déranger car elle affecte nos opérations normales de lavage. Cependant, ne vous inquiétez pas, cet article vous présentera quelques méthodes pour résoudre le problème des boutons défectueux de votre lave-linge. 1. Vérifiez le branchement électrique - la fiche est correctement branchée : Assurez-vous que la fiche d'alimentation du lave-linge est fermement insérée dans la prise. -Si l'interrupteur d'alimentation est allumé : vérifiez si l'interrupteur d'alimentation est allumé. 2. Nettoyez la surface des boutons – Arrêtez : éteignez d'abord la machine à laver et débranchez la fiche d'alimentation pour garantir la sécurité. Dépannage du bouton du lave-linge Dépannage Nettoyage à l'eau tiède Utilisez de l'eau tiède et un détergent neutre pour essuyer délicatement la surface du bouton. Réglage du bouton et position du bouton de réglage du redémarrage : vérifiez si le bouton est

Avec la popularité de Python, PyQt5 est devenu l'un des outils de premier choix pour de nombreuses personnes pour le développement rapide d'interfaces graphiques. Cependant, les problèmes d'installation sont inévitables. Voici plusieurs problèmes courants liés à l’installation de PyQt5 et leurs solutions. Le message d'erreur lors de l'installation de PyQt5 est que le module sip est introuvable. Ce problème se produit généralement lors de l'utilisation de pip pour installer PyQt5. La raison de cette erreur est le manque de dépendances sur le module sip, vous devez donc d'abord installer le module sip manuellement. Entrez le code suivant sur la ligne de commande : pipinsta

SpringDataJPA est basé sur l'architecture JPA et interagit avec la base de données via le mappage, l'ORM et la gestion des transactions. Son référentiel fournit des opérations CRUD et les requêtes dérivées simplifient l'accès à la base de données. De plus, il utilise le chargement paresseux pour récupérer les données uniquement lorsque cela est nécessaire, améliorant ainsi les performances.

Adresse papier : https://arxiv.org/abs/2307.09283 Adresse code : https://github.com/THU-MIG/RepViTRepViT fonctionne bien dans l'architecture ViT mobile et présente des avantages significatifs. Ensuite, nous explorons les contributions de cette étude. Il est mentionné dans l'article que les ViT légers fonctionnent généralement mieux que les CNN légers sur les tâches visuelles, principalement en raison de leur module d'auto-attention multi-têtes (MSHA) qui permet au modèle d'apprendre des représentations globales. Cependant, les différences architecturales entre les ViT légers et les CNN légers n'ont pas été entièrement étudiées. Dans cette étude, les auteurs ont intégré des ViT légers dans le système efficace.
