zoukankan      html  css  js  c++  java
  • 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       

    <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" />

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

    这里可以看到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

  • 相关阅读:
    你不知道的javaScript笔记(7)
    你不知道的javaScript笔记(6)
    你不知道的javaScript笔记(5)
    你不知道的javaScript笔记(4)
    你不知道的javaScript笔记(3)
    你不知道的javaScript笔记(2)
    java 单链表反转
    Java找出两个链表的第一个公共节点
    Java产生死锁的一个简单例子
    Java 中Enum的使用与分析
  • 原文地址:https://www.cnblogs.com/JangoJing/p/2610034.html
Copyright © 2011-2022 走看看