sujin190
V2EX  ›  问与答

小菜求教个模型问题?

  •  
  •   sujin190 · Apr 21, 2013 · 3235 views
    This topic created in 4774 days ago, the information mentioned may be changed or developed.
    在mvc中模型一般会被定义成对一个表的增删查改,但有时需要多个表中的数据,也许只需一个联合查询就可以做到的但此时却需要对数据库进行多次查询,那么此时是不是反而造成了效率的低下?这种情况又是怎么解决的呢?模型的要义又是什么?
    11 replies    1970-01-01 08:00:00 +08:00
    ljbha007
        1
    ljbha007  
       Apr 21, 2013
    MVC模型跟你最终怎么查询完全没关系
    是用多次查询还是联合查询完全是你自己决定的 然后把查询结果填充到模型里边就行了
    sujin190
        2
    sujin190  
    OP
       Apr 21, 2013
    @ljbha007 那么比如在CodeIgniter中,他封装了一些数据库的基本查询比如where子句、order_by子句,似乎这些查询内部还做了缓存处理,但这些基本查询似乎又不可以组合成比较复杂的查询,那么我们也可以直接执行sql语句吗?那么这样是不是又破坏了原有的特性呢?
    ljbha007
        3
    ljbha007  
       Apr 21, 2013
    @sujin190
    那个是他的框架自己实现的ORM
    这个你在挑选MVC框架的时候就应该事先了解
    ljbha007
        4
    ljbha007  
       Apr 21, 2013
    @sujin190
    像Python的Flask、Tornado
    Java的struts2、SpringMVC
    这些都是非常优秀的MVC框架 并且可以和别的ORM框架无缝衔接
    ljbha007
        5
    ljbha007  
       Apr 21, 2013
    @sujin190
    MVC框架自带ORM 并且和框架本身紧耦合的坏处就是万一ORM写得很搓或者效率很低就悲剧了
    fsw90628
        6
    fsw90628  
       Apr 21, 2013 via iPhone
    为了性能写 SQL 还是值得的,问题是那部分是不是瓶颈。
    sujin190
        7
    sujin190  
    OP
       Apr 21, 2013
    @ljbha007 那是不是说在大多数mvc框架都把一个模型对应到数据库的一个表,这只是最通用的做法,并不是模型的定义,或者说mvc中模型并只定义它作为数据的提供者并未定义它如何和数据存储部分的交互过程呢?
    sujin190
        8
    sujin190  
    OP
       Apr 21, 2013
    @ljbha007 刚看了下源码发现CodeIgniter原来是可以可以直接执行sql语句的,为什么这官方文档写得这么简单,完全不明所以
    sujin190
        9
    sujin190  
    OP
       Apr 21, 2013
    @fsw90628 是啊,不过有时似乎会突破一个模型对应一个表的限制,不知道好不好
    ljbha007
        10
    ljbha007  
       Apr 21, 2013
    @sujin190
    是的 只是有些MVC把和数据库打交道的部分也集成进去了而已 实际上这种做法跟MVC模式没有任何关系
    sujin190
        11
    sujin190  
    OP
       Apr 21, 2013 via Android
    @ljbha007 原来如此 ,被误导了
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2988 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 04:46 · PVG 12:46 · LAX 21:46 · JFK 00:46
    ♥ Do have faith in what you're doing.