随便记20140916

1连接查询分类编辑

a.内连接
内连接也叫连接,是最早的一种连接。还可以被称为普通连接或者自然连接,内连接是从结果表中删除与其他被连接表中没有匹配行的所有行,所以内连接可能会丢失信息。
内连接的语法如下:
select fieldlist from table1 [inner] join table2 on table1.column=table2.column
 
2.

使用LINQ返回数据集  

LINQ查询:
    public List<tb_Blog> finAllBlogByUser(Guid userid) {
        DataClassesDataContext db = new DataClassesDataContext();
        List<tb_Blog>  rs =( from r in db.tb_Blogs
                 where r.UserID == userid
                 select r).ToList() ;

        return rs;
    }

数据绑定:
        List<tb_Blog> list= opBlog.finAllBlogByUser(uid);
        RepeaterList.DataSource = list;
        RepeaterList.DataBind();
 

.net在控件上绑定List<T>泛型

 

我们在开发分成架构的Web应用程序时,常常把数据库中的记录放到一个List<Model>中,做到了良好的封装。调用业务逻辑的程 序猿也无需知道库表结构就可以直接使用“Model.属性”来访问各个字段的数据了。但在做显示的时候,初学者可能会碰到一些问题。以往大家在显示控件 (如Repeater)上绑定的都是DataSet,ASPX页面里写的是“<%# Eval("字段名")%>”。那如何绑定一个List<T>泛型呢?

其实,Repeater控件是支持绑定到业务对象的,并且我们也不再用Eval表达式了。看一个例子:

后台代码:

GeekStudio.BLL.Blog optBlog = new GeekStudio.BLL.Blog();Repeater1.DataSource = optBlog.GetModelList();Repeater1.DataBind();其中,GetModelList()返回的是一个List<GeekStudio.ORM.Model.Blog>。我们可以按照以往绑定DataSet的相同写法,将List绑定到Repeater控件上。

再来看看前台代码:

<ul>    <asp:repeater id="Repeater1" runat="server">        <itemtemplate>            <li><%#((GeekStudio.ORM.Model.Blog)Container.DataItem).Title%></li>        </itemtemplate>    </asp:repeater></ul>就这样,很简单,就把GeekStudio.ORM.Model.Blog的Title显示在了网页上

总结一下:

要在Repeater上绑定List泛型,后台代码里只要指定Repeater控件.DataSource = List<你的类型>。前台代码里先强制转换类型,然后就可以访问各属性了,不需要写Eval:<%#((你的类型)Container.DataItem).你的类型的属性%>。这样写的优点非常明显:我们确实无需知道库表结构了,可以直接调用Model类型.属性,不容易写错代码,也增加了可维护性。而且,据说此方法的效率要高于传统的采用Eval绑定方法。

 

http://zhidao.baidu.com/link?url=fLnDhPIICbrkkxrpy_HFq015KdKD0ogAvwXfmBu6cunw2HlCzeSwnR8DzPDIrJvrZVbFWm4ir_kDKyh1jV0D8Wy0TCD52l3-DbdZiurixNO

posted @ 2014-09-16 11:18  劳记在心  阅读(77)  评论(0)    收藏  举报