数据库通过模型查询

时间:2011-05-05 07:37:26

标签: database model-view-controller model data-modeling querying

使用MVC框架并使用模型从控制器查询数据库时,最佳做法是什么?

模型是否应该提供非常灵活的功能以允许控制器查询数据库?就像来自控制器的呼叫一样:

User->find ([
    { 
        or => [ 
            {field => 'name', value => 'john', op => '~' },
            { 
                and => [
                    { field => 'organization', value => 'acme', op => '~' },
                    { field => 'city', value => 'tokyo', op => '=' }
                ]
             }
        ],
     });

    } 

或者该模型是否具有严格的API,从而产生如下调用:

User->find_john_or_people_from_acme_in_tokyo();

最好的方法是什么? SQL应该遍布模型吗?或者包含在一个queryFactory函数中?你能指点我正确的方向吗?一些操作系统代码会很棒。

谢谢!

2 个答案:

答案 0 :(得分:2)

将Model和DataAccess分离为两个不同的层始终是一个好习惯。 这描述了模型层逻辑分离的最佳实践。当需要在不修改ViewModel层的情况下更改基础数据访问实体时,这会有所帮助。

Best practices to partition Model code to logical parts in MVC? Which is the best?

答案 1 :(得分:0)

一个好的做法是将所有与数据库相关的代码分离到一个单独的DAO层中。这样,您的业务逻辑代码就不依赖于您使用的特定数据库技术(JDBC与Hibernate与JPA等),甚至不依赖于数据是存储在数据库中还是存储在其他存储中。