SubSonic 3.0简介

接触到SubSonic3.0 ORM框架是看了AllEmpty大神的从零开始编写自己的C#框架(链接在此)系列的随笔接触到的,本文章学习内容源于AllEmpty大神。

SubSonic就是一个ORM开源框架。作者是Robe Conery,用C#语言写的。其中包含了T4模板可以快速生成数据层实体类,这是一个实用的快速开发框架。让开发人员原理SQL语句的拼接,专注于业务逻辑的实现。SubSonic 3.0支持MsSql、MySql与SQLite三种数据库,对数据库操作灵活,对生成的SQL语句会自动进行优化,虽然是ORM框架,但在性能上并没有太大的损失。它上手容易,是一个非常棒的ORM开发框架。

我使用过程中的切身体会是:一次编写,终身使用。将自己需要的功能写在T4模板,利用T4模板强大的自定义功能可以迅速而准确地生成自己的实体类。可以Select类、实体类查询,支持LINQ,支持聚合函数,支持存储过程,可以使用Distinct关键字。(部分功能AllEmpty添加,我使用的是他的修改版)。

SubSonic 3.0配置

创建项目(整个解决方案下载链接在本文后面)并将SubSonic.Core和Castle.dll引用后,添加SubSonic文件夹。此时,整个项目的文件结构如下所示:

然后需要配置一下数据库连接,这里介绍的是MSSQLSERVER。打开SubSonicTest项目中SubSonic文件夹中的Setting.ttinclude,该文件位置如下图红框所示:

打开该文件在开始找到如下所示的内容:

上图红色箭头指向的数据库连接字符串对应Web.config配置文件中的ConnectionStrings的名称,数据名称对应与ConnectString中的数据库。ConnectionStrings配置方式(以我的为例)如下图红框内容所示:

上图中的数据库连接字符串名称一定要和Web.config配置文件中的保持一致,否则会出现错误。确保没有问题后,按如下所示使用T4模板生成数据库实体类:

生成的实体类如下所示:

SubSonic 3.0简单实用

在SubSonicTest项目中新建一个Aspx窗体文件,这里名称是Test.aspx。对应的cs后台文件代码如下所示:

using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using SubSonic.Linq.Structure;
using SubSonic.Query;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Solution.DataAccess.DataModel;

namespace SubSonicTest
{
    public partial class Test : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {

            //新增记录
            var branch1 = new Branch
            {
                DeptCode = SPs.P_Branch_GetMaxBranchDeptCode(, ).ExecuteScalar() + "",
                Name = "网络部",
                Comment = "网络问题解决中心",
                ParentId = ,
                Sort = ,
                Depth =
            };

            //保存至数据库
            branch1.Save();
            //打印出来S
            PrintImpInfo("记录添加成功,新增Id="+branch1.Id);

            //查询刚刚添加的记录并修改
            var branchModel = Branch.SingleOrDefault(x => x.Comment == "网络问题解决中心");
            branchModel.Name = "售后服务部";
            branchModel.Save();

            //删除刚才添加的记录
            Branch.Delete(x => x.Comment == "网络问题解决中心");
            if (Branch.Exists(x => x.Comment == "网络问题解决中心"))
            {
                PrintImpInfo("存在");
            }
            else
            {
                PrintImpInfo("不存在");
            }

            //查询Branch下所有的数据
            var list = Branch.All();
            foreach (var branch in list)
            {
                PrintImpInfo(string.Format("名字={0},评论={1},添加日期={2}", branch.Name, branch.Comment, branch.AddDate.ToString("yyyy-MM-dd HH:mm:ss")));
            }

            // //使用类实体附带的函数查询
            PrintImpInfo("使用类实体附带的函数查询");
            );
            foreach (var branch in braanchList)
            {
                PrintImpInfo(branch.Id.ToString());
                PrintImpInfo(branch.Name);
                PrintImpInfo(branch.AddDate.ToString("yyyy-MM-dd HH:mm:ss"));
            }
            PrintImpInfo("------------------------");

            //分页功能,获取第2页记录(每页5条记录)
            PrintImpInfo("获取第2页记录(每页5条记录");
            , );
            foreach (var branch in il)
            {
                PrintImpInfo(branch.Id.ToString());
                PrintImpInfo(branch.Name);
                PrintImpInfo(branch.Sort.ToString());
                PrintImpInfo(branch.Depth.ToString());
                PrintImpInfo(branch.ParentId.ToString());
                PrintImpInfo(branch.AddDate.ToString("yyyy-MM-dd HH:mm:ss"));
            }
            PrintImpInfo("------------------------");

            //使用数据库名+DB可以直接调用聚合函数
            PrintImpInfo("数据库名+DB可以直接调用聚合函数");
            var db = new SubSonicTestDB();
            //平均值
            PrintImpInfo().ExecuteScalar()+" ");
            //计算数量
            PrintImpInfo("计算数量" + db.Count<Position>(x => x.Id).ExecuteScalar() + " ");
            //计算合计量
            PrintImpInfo("计算合计量" + db.Sum<Position>(x => x.Id).ExecuteScalar() + " ");
            //最大值
            PrintImpInfo("最大值" + db.Max<Position>(x => x.Id).ExecuteScalar() + " ");
            //最小值
            PrintImpInfo("最小值" + db.Min<Position>(x => x.Id).ExecuteScalar() + " ");

            //存储过程调用方法
            ,).ExecuteScalar();
            PrintImpInfo("存储过程调用obj="+obj);

            //Linq查询方式
            PrintImpInfo("Linq查询方式");
            var query = new Query<Branch>(db.provider);
            var posts = from p in query
                ")
                select p;
            foreach (var branch in posts)
            {
                PrintImpInfo(branch.ToString());
            }

            query = db.GetQuery<Branch>();
            posts = from p in query
                 && p.Id <
                select p;
            foreach (var branch in posts)
            {
                PrintImpInfo(branch.ToString());
            }

            var newBranchList = query.ToList<Branch>();
            foreach (var branch in newBranchList)
            {
                PrintImpInfo(branch.ToString());
            }

            //Linq多表关联查询方式
            PrintImpInfo("Linq多表关联查询方式");
            var query1 = from b in Position.All()
                join p in Branch.All() on b.Branch_Id equals p.Id
                "
                select p;
            foreach (var branch in query1)
            {
                PrintImpInfo(branch.ToString());
            }

        }
        /// <summary>
        /// 在Debug模式下打印信息到输出窗口中
        /// </summary>
        /// <param name="info"></param>
        private void PrintImpInfo(string info)
        {
            System.Diagnostics.Debug.WriteLine(info);

        }

    }
}

加入断点调试(要求Debug下),即可输出打印出的内容,如下所示(打开输出窗口的快捷键是Ctrl+Alt+O):

感谢AllEmpty大神让我认识到了SubSonic这个ORM框架,么么哒。

整个解决方案在下面:

点此下载

SunSonic 3.0 ORM开源框架的学习的更多相关文章

  1. Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作 下一篇:Farseer.net轻量级ORM开源 ...

  2. Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射 下一篇:Farseer.net轻量级ORM ...

  3. Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作 下一篇:Farseer.net轻量级ORM开源框 ...

  4. Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件 下一篇:Farseer.net轻量级ORM开源 ...

  5. Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射 下一篇:Farseer.net轻量级ORM开源框 ...

  6. Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明 下一篇:Farseer.net轻量级ORM开源框架 ...

  7. Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:没有了 下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置 前言 V1.x版本终于到来了.本次 ...

  8. C++的ORM 开源框架

    C++的ORM 开源框架 介绍一个C++的ORM工具ODB SOCI.LiteSQL.POCO数据库访问类库对比

  9. Farseer.net轻量级ORM开源框架 V1.x 教程目录

    本篇教程将以Ver 1.x版本进行详细使用讲解 大家有任何疑问可以加入我们的官方QQ群进行讨论.QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net 整个 ...

随机推荐

  1. 欧姆龙PLC以太网FINSTCP通信例程与操作步骤

    http://wenku.baidu.com/link?url=aa8kvtCg1eYp-wkIZY_hDpE5IuENT21Uvk1zVNtFiIyPTk-kjfarzSVyGt2DPs4ikXLT ...

  2. Openstack的keystone的user-role-list命令的使用

    直接在shell模式下执行 [root@node-5 ~]# keystone user-role-list WARNING: Bypassing authentication using a tok ...

  3. 数据可视化:Echart中k图实现动态阈值报警及实时更新数据

    1 目标 使用Echart的k图展现上下阈值,并且当真实值超过上阈值或低于下阈值时候,标红报警. 2 实现效果 如下:

  4. gfortran、g77等编译器中使用多个文件

    gfortran aaaa.f90 bbbb.f90 -o cccc (生成cccc可执行文件,cccc名称可自由设定) 又可以分成两步,因为gfortran先把程序文件编译成*.o文件,再把*.o文 ...

  5. 基于webrtc的资源释放问题(一)

    基于webrtc的资源释放问题(一) ——重复释放webrtc的相关资源 背景: 视频通讯大都只是作为一个功能存在于各种应用中,比如微信,qq .既然只是应用的一部分,这样就涉及反复的开启和关闭视频通 ...

  6. 复习练习(03)jquery Css方法一步步升级

    jquery Css方法一步步升级 <script src="jquery-1.8.3.js"></script> <script type=&quo ...

  7. mysql5.6中 order by 多个字段排序问题

    今天用order by排序 后面跟了多个字段,如sql语句: SELECT a.id,a.loginname,a.address,u.id,u.`name`,u.address FROM admin_ ...

  8. Linux sticky bit 目录权限 rwt权限

    [linux权限分为 user group others三组] 今天看到有个目录的权限是rwxrwxrwt 很惊讶这个t是什么,怎么不是x或者-呢?搜了下发现: 这个t代表是所谓的sticky bit ...

  9. php 中的常量

    1.__FINE__ 返回当前常量所在的行号. 2.__FILE__ 返回文件的完整路径和文件名. 3.__FUNCTION__ 返回函数名称. 4.__CLASS__ 返回类名称. 5.__METH ...

  10. php上传绕过

    URL:http://www.ichunqiu.com/section/45 php语言除了可以解析以php为后缀的文件,还可以解析php2.php3.php4.php5这些后缀的文件.