NewLife.XCode 上手指南

Posted 天王星天

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了NewLife.XCode 上手指南相关的知识,希望对你有一定的参考价值。

想了解什么是XCode

      在这里我不对XCode做过多介绍,XCode曾经是一个轻量级ORM组件,现在是一个重量级数据映射框架,支持实体对象数据到不同媒体的数据映射,提供面向对象的方式操作数据库,解决90%以上的数据库操作场景.是大石头和他的NewLife团队10年来的智慧结晶,感谢前人栽树!

   

      你可以用XCode生成Domain,做增、删、改、查. 对于一个ORM我不要多强大,我只求简单,好用,能查到我要的数据,能完成我要的操作,遇到问题能有人帮助.如果你的需求和我一样,那么就停下来看看XCode的神奇之处吧!

 

想深入了解什么是XCode

请移步大石头的博客

ORM组件XCode(速览)

http://www.cnblogs.com/nnhy/archive/2010/09/12/1824349.html

 

ORM组件XCode(简介)

http://www.cnblogs.com/nnhy/archive/2010/09/13/1824666.html

 

 

给第一次接触XCode的人说的话

对于初学者,XCode看似给了一个很高的门槛,没有完整的教程,没有任何指导,有的只是源代码和一些零碎的博文和高级应用,让初学者无法入门,楼主也是才接触XCode1个多月的新手,不敢说指教,只是想丰富一下XCode的入门教程,让更多的人不会徘徊在门外不得入内.这也是楼主写本文的初衷.至于能不能写下去成为一个系列就看大家的反响吧.

 

正文开始!

 

第一次使用XCode的准备

       对于第一次使用者来说,首先必要的就是提供所有的资源和材料,这点楼主第一次用XCode的时候就找了很久才把Dll和生成器下载下来,而且还不知道自己下载的是不是最新的.这里说明一下,XCode没有完整版,稳定版之说,每天大石头和他的NewLife团队都在更新,每天源码在ftp上编译4次,找到适合自己的才是最重要的,群里有人都3个月没更新dll了,照样用的挺好.不要盲目追求最新版,或者你就是喜欢当小白鼠.

   

dll和工具下载地址请至:http://www.newlifex.com/showtopic-51.aspx

   

正式开始XCode之旅

 

1.新建一个工程

image

2.引用DLL

这里楼主又要多啰嗦了,其实也是对大家好,当你解压完DLL压缩包后,你会发现有很多DLL,这些DLL到底是干什么的呢,我应该引用哪个呢?

DLL里面其实是NewLife团队的所有组件,如果只是用ORM框架的话只需要用到下面提到的DLL,其他的DLL的作用其实楼主也不是很明白,楼主也不在这里误导大家.

NewLife.Core.dll   NewLife核心代码,XCode也需要引用

XCode.dll               XCode代码

          所以引用DLL就是主要用这2个DLL,同名的XML文件一起复制进去,作用是智能提示的时候能够显示注释内容,同名的pdb文件是调试文件,在报错的时候能指示该错误发生在第几行,用于向大石头和他的团队求助时让他们定位到错误发生的精确位置.

imageimage

 

3.数据库建立

       XCode强大之处,不仅仅是可以从数据库导出Domain,更强大的是可以根据连接字段反向生成数据库,这么说可能没想到有什么用,换句话说就是,你可以用SQL2K开发,然后部署的时候直接带上你的程序部署,XCode会自动帮你根据连接字段生成数据库,你可以直接部署到mysql,SQL2005里,不需要改代码,不要备份数据库.当然XCode这时只是生成了一个数据库表,并没有数据,初始化菜单和管理员这些数据XCode也支持,但不是本节我们讨论的内容.这些在以后有机会再介绍.(该功能需要配config,默认该功能关闭)

       这里我们讲的是如何从数据库导出Domain,为我们所用.

我们先新建一个数据库,叫XCodeTest,这里为了方便讲解,我们用最经典的,学生-科目-教师-成绩表来示范

建立一个Student表,设置ID为主键,自增

image

建立一个Subject表,设置ID为主键,自增

关联TeacherID,一个科目由一个老师来负责,一个老师可以负责多个科目

image

建立一个Teacher表,设置ID为主键,自增

image

建立一个成绩表,ID主键,自增

关联SubjectID和StudentID

image

          在建立数据库的时候,我一再强调ID主键,自增,是因为XCode对自增主键支持比较好,在Save方法内部,通过判断ID是否为空来选择Insert或Update,同样你可以用Guid做主键,但那样使用就不方便了,你要自己控制Insert还是Update

 

4.代码生成器

终于轮到代码生成器了,说实话,楼主自己第一次用代码生成器的时候就不知道怎么用.

在打开代码生成器之前,我们要配置一下连接字符串,解压到的文件中,有XCode.exe.config,打开他编辑,可以看到已经有了很多连接字段,都是示例,我们是SQL就复制一条mssql的来改吧

image       

1
<add name="XCodeTest" connectionString="Server=(local);User id=sa;Pwd=sa;Database=XCodeTest" providerName="System.Data.SqlClient"/>

改好后,保存关闭.

打开代码生成器,看到我们刚才写的连接字符串已经被读到了

image

 

然后点连接,可以看到我们的表都已经读取到了

image

接下来改一改连接名,命名空间,输出目录

image

然后是生成,选则好模版,点击生成所有表,模版只要选择实体业务和实体数据2项就可以了,选一次模版,点一次生成所有表,再选一次模版,再点一次生成所有表!

image

关掉代码生成器,回到我们的项目来,新建一个文件夹Domain, 右键文件夹,添加---现有项,  把刚才生成文件都添加进来

image

 

5.从登录开始 
拖2个TextBox,一个Button就可以开始了.

image

用户名:<asp:TextBox ID="txtUserName" runat="server"></asp:TextBox>
        <br />
        &nbsp;密 码:<asp:TextBox ID="txtPsw" runat="server" TextMode="Password"></asp:TextBox>
        <br />
        <asp:Button ID="btnLogin" runat="server" Text="Button" />

1
  
1
然后就是登录按钮的单击事件,这里插一段:
1
在这个业务里,我们需要根据用户名查找用户,看一下跟Student有关的2个文件,一个叫Student.cs 一个叫Student.Biz.cs
1
在进去仔细看一看(PS,我的Windows Live Writer的代码着色插件好像没有用嘛~~~不知道发送出去会不会着色)
public partial class Student : IStudent
{

}    


public partial class Student : Entity<Student>
{

}

1
这里可以看到partial这个属性,部分的,所以我们的Student类可以写在多个文件中,这样我们就利用这个特性,新建一个
Student.My.cs

image

报错了,别着急,改一改,这样就可以了,所有我们自己新增和修改的代码都写在这个文件里,这样的话,如果我们数据库结构改变了,重新生成实体和业务只要覆盖那2个文件就可以了,我们自己编写的代码完全不受影响,之前楼主直接把代码写在Biz.cs里,后来数据库一改,每次替换的时候都提心吊胆的,生怕覆盖了自己写的代码.

image

接下来继续我们的业务,要根据用户名查找用户,XCode生成的Biz.cs文件里已经有了一些常用的方法了,可以去看一看,包括一些高级的方法,也被注释掉了,可以照着改,

image

/// <summary>根据Name查找</summary>
        /// <param name="id"></param>
        /// <returns></returns>
        public static Student FindByUserName(string userName)
        {
            if (Meta.Count >= 1000)
                return Find(_.Name, userName);
            else // 实体缓存
                return Meta.Cache.Entities.Find(_.Name, userName);
            // 单对象缓存
            //return Meta.SingleCache[id];
        }

这里有必要解释下代码,Meta.Count这里判断表内数据是否超过1000,如果没超过1000的话用实体缓存来获取数据,这比较适合象菜单,权限这样的表,内容固定且不多,直接从缓存中获取,效率极高,如果超过1000条那从内存中找效率和数据库中找其实优势就不大了,所以直接从数据库中找.

接下来回到页面的登录按钮单击事件

image

        protected void btnLogin_Click(object sender, EventArgs e)
        {
            string userName = txtUserName.Text.Trim();
            string psw = txtPsw.Text.Trim();
            Student student = Student.FindByUserName(userName);
            if(student != null)
            {
                //这里密码就不做md5加密处理了,真实应用中一定要加密,切勿重蹈csdn覆辙
                if(psw == student.Psw)
                {
                    //登录成功跳转
                    Response.Redirect("Welcome.aspx");
                }
            }
            Response.Write("用户名或密码错误!!!");
        }

建立一个Welcome.aspx的文件,里面就写一句"登录成功"吧~~~登录成功后保存用户状态不在本节讨论范围内!各位看官自行处理~~ 

为了演示,我们到数据库里加1个用户吧~

image

编译执行~~结果...报错了...

image

仔细一看,原来是XCode自作聪明,发现我们Subject表里有TeacherID,于是就关联到了Teacher表中的ID,然后生成了一大堆扩展属性,

最要命的是还连续生成了2份,导致了错误,只要错误是出在Biz.cs中的,只管删,有能力的可以仔细分析错误,把多余的内容删除掉,其实XCode是好心做坏事了

 

在这里我把带红线的上上下下都删除了!

 

结果又出了一个错~~

image

好吧,我承认我错了,我不该把表命名为Score,然后里面又有Score这个属性,结果就是这个类叫Score,里面还有个Score的属性,这个好办,把属性Score改成MySCore 
image

再编译下,继续报错, 
image

好吧,还有个接口没改,一起改了吧 
image

 

编译~~~通过了   (PS:在这里,楼主把出的错也写上来,怎么解决的也一并写上来,给大家参考下吧...遇到报错不要急,看错误提示,其实很好解决,实在不行问度娘) 

一输入帐号和密码,点确定,,,结果又报错了

image 

哦~~~~MyGod,为什么我又忘记配置Web.Config的连接字段了~~~~这里可以看到,请设置XCodeTest连接字符串,所以我们的连接字段名称必须是XCodeTest,这个当然是我们在用代码生成器的时候生成的咯....其实大家也可以在Student.cs顶上的属性声明中看到里面声明了连接字段名. 

结束程序,打开web.config

  <connectionStrings>
    <add name="XCodeTest" connectionString="Server=(local);User id=sa;Pwd=sa;Database=XCodeTest" providerName="System.Data.SqlClient"/>
  </connectionStrings>

 

把连接字段配置好,再跑一次~~ 
image 

当我看到这个的时候,我就知道成功了.~~再输错一次密码试试~~ 
image 
嘿嘿~~成功了~~下一节我们来示范成绩表的操作~~~

 

 

本文的Demo下载地址:

http://dl.dbank.com/c0m64ioz5r

 

NewLife论坛地址:

http://www.newlifex.com/

 

大石头博客:

http://www.cnblogs.com/nnhy/ 

 

NewLife.XCode开发资源目录

http://www.cnblogs.com/asxinyu/archive/2012/06/02/2532210.html

以上是关于NewLife.XCode 上手指南的主要内容,如果未能解决你的问题,请参考以下文章

[NewLife.XCode]脏数据

[NewLife.XCode]数据模型文件

[NewLife.XCode]实体缓存

[NewLife.XCode]数据初始化

[NewLife.XCode]导入导出(实体对象百变魔君)

[NewLife.XCode]对象字典缓存(百万军中取敌首级)