小菜求教个模型问题?

2013-04-21 12:05:22 +08:00
 sujin190
在mvc中模型一般会被定义成对一个表的增删查改,但有时需要多个表中的数据,也许只需一个联合查询就可以做到的但此时却需要对数据库进行多次查询,那么此时是不是反而造成了效率的低下?这种情况又是怎么解决的呢?模型的要义又是什么?
2614 次点击
所在节点    问与答
11 条回复
ljbha007
2013-04-21 12:10:21 +08:00
MVC模型跟你最终怎么查询完全没关系
是用多次查询还是联合查询完全是你自己决定的 然后把查询结果填充到模型里边就行了
sujin190
2013-04-21 12:26:02 +08:00
@ljbha007 那么比如在CodeIgniter中,他封装了一些数据库的基本查询比如where子句、order_by子句,似乎这些查询内部还做了缓存处理,但这些基本查询似乎又不可以组合成比较复杂的查询,那么我们也可以直接执行sql语句吗?那么这样是不是又破坏了原有的特性呢?
ljbha007
2013-04-21 12:50:53 +08:00
@sujin190
那个是他的框架自己实现的ORM
这个你在挑选MVC框架的时候就应该事先了解
ljbha007
2013-04-21 12:55:10 +08:00
@sujin190
像Python的Flask、Tornado
Java的struts2、SpringMVC
这些都是非常优秀的MVC框架 并且可以和别的ORM框架无缝衔接
ljbha007
2013-04-21 12:56:10 +08:00
@sujin190
MVC框架自带ORM 并且和框架本身紧耦合的坏处就是万一ORM写得很搓或者效率很低就悲剧了
fsw90628
2013-04-21 12:59:20 +08:00
为了性能写 SQL 还是值得的,问题是那部分是不是瓶颈。
sujin190
2013-04-21 17:11:49 +08:00
@ljbha007 那是不是说在大多数mvc框架都把一个模型对应到数据库的一个表,这只是最通用的做法,并不是模型的定义,或者说mvc中模型并只定义它作为数据的提供者并未定义它如何和数据存储部分的交互过程呢?
sujin190
2013-04-21 17:13:30 +08:00
@ljbha007 刚看了下源码发现CodeIgniter原来是可以可以直接执行sql语句的,为什么这官方文档写得这么简单,完全不明所以
sujin190
2013-04-21 17:14:58 +08:00
@fsw90628 是啊,不过有时似乎会突破一个模型对应一个表的限制,不知道好不好
ljbha007
2013-04-21 21:19:28 +08:00
@sujin190
是的 只是有些MVC把和数据库打交道的部分也集成进去了而已 实际上这种做法跟MVC模式没有任何关系
sujin190
2013-04-21 23:15:34 +08:00
@ljbha007 原来如此 ,被误导了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/66489

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX