对象关系映射(ORM)及代码生成器和插件C#源码(DBFrameworkV4.5.3)

1. ORM及代码生成器和插件C#源码(DBFrameworkV4.5.3)

一、使用对象关系映射组件Kenly.DBFramework.dll不用编写任何SQL或者存储过程即可实现下列功能:
1、数据表、视图和存储过程与对象之间的转换。
2、数据表、视图的自定义条件查询。
3、数据表、视图的分页查询。
4、根据ID、主键或自定义条件对数据表进行增、删、改操作。
5、实现一对一、一对多、多对一和多对多的关系映射。
6、支持单个对象和多个对象之间的事务控制。
7、支持查询结果排序。
8、支持查询表达式生成。
9、支持延迟加载。

二、代码生成器
1、根据指定的数据库连接,自动生成数据表、视图和存储过程对应的对象代码(C#代码)。
2、自动生成相关的工程文件,生成完整的业务层项目文件。
3、可以帮助生成自定义查询方法。
4、支持SQLServer2000、SQLServer2005和Oracle代码生成插件,支持插件扩展。

提供
1、对象关系映射组件: Kenly.DBFramework.dll
2、代码生成器源码:Xsd2CS。
3、代码生成器插件源码(支持SQLServer2000、SQLServer2005和Oracle):Plugin。
4、使用手册:DBFramework.Manual V4.5.3.pdf。 

下载地址:http://download.csdn.net/source/720607   

 

 [Serializable()]
    [Table(TableName = "usyUser")]
    public class BusinessUser : SqlTableGateway<BusinessUser>, ICloneable
    {

        public BusinessUser()
        {
            string connectionString = SystemConfig.ConnectionString;
            base.InitializeGateway(connectionString, this);
        }

        略.............

        #region Properties

        [Column(ColumnName = "UserId", IsIdentity = true, IsPrimaryKey = true)]
        public int UserId
        {
            get { return _userId; }
            set { _userId = value; }
        }

        [Column(ColumnName = "EmployeeNumber")]
        public string EmployeeNumber
        {
            get { return _employeeNumber; }
            set { _employeeNumber = value; }
        }

        [Column(ColumnName = "UserName")]
        public string UserName
        {
            get { return _userName; }
            set { _userName = value; }
        }


       Role[] _roles = new Role[0];
      [Relation(RelationType = RelationType.ManyToMany, InterrelationType = typeof(UserRole), ResultOrder = "RoleName ASC")]
        public Role[] Roles
        {
            get { return _roles; }
            set { _roles = value; }
        }



      public DataTable RoleTable
        {
            get
            {
                Role role = new Role();
                return role.ToTable(_roles, false);
            }
        }

      #endregion //Properties



       }

        Role role = new Role();
        gvRole.DataSource = role.QueryAll();
        gvRole.DataBind();

        Role role = new Role();
        int roleId=1;
        role.RoleId = roleId;
        role.IsActive = false;
        role.PartialUpdateById("IsActive") ;

        Role role = new Role();
        int roleId=1;
        role.RoleId = roleId;
        role.RetrieveById();
        role.IsActive = false;
        role.UpdateById() ;

        BusinessUser user = new BusinessUser();
        user.UserId = 2;
        user.RetrieveRelationObject(typeof(Role));

 

转载于:https://www.cnblogs.com/Jessy/archive/2010/12/08/1900767.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/263708.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

念一城,安一世

时光飞快的流逝&#xff0c;岁月总是行行匆匆&#xff0c;随着迷茫的脚步渐行渐远&#xff0c;伴随着若有若无的孤单心事&#xff0c;猛然间离道阻挡在路中央&#xff0c;才诚惶诚恐的发现&#xff0c;留一份是匆忙&#xff0c;取一分就变成了离殇。在多愁中起步&#xff0c;在…

c语言如何读取mp3歌曲信息,VC中读取mp3文件信息的方法

标准格式的mp3文件中&#xff0c;都有一些自身描述的信息&#xff0c;比如歌曲名称、歌手、专辑名称等信息。这些信息都记录在mp3文件中&#xff0c;而且格式是固定的。那么&#xff0c;我们就可以用编程的方式来获取这些信息。其实说简单一点&#xff0c;就是VC文件读取的操作…

kvm虚拟机热迁移

1. 迁移介绍 迁移&#xff1a; 系统的迁移是指把源主机上的操作系统和应用程序移动到目的主机&#xff0c;并且能够在目的主机上正常运行。在没有虚拟机的时代&#xff0c;物理机之间的迁移依靠的是系统备份和恢复技术。在源主机上实时备份操作系统和应用程序的状态&#xff0c…

使用Backtrace函数打印调用栈 - Debug居家必备

glibc提供了backtrace这个库函数&#xff0c;可以用来打印call stack。比如我们可以在程序中注册常见的一些signal&#xff0c;比如SIGSEGMENT, SIGPIPE&#xff0c;然后在这些信号的回调函数中&#xff0c;利用backtrace打印出call stack&#xff0c;这样debug就非常的方便。 …

《C语言及程序设计》实践项目——三种循环语句

返回&#xff1a;贺老师课程教学链接 【项目1&#xff1a;利用循环求和】求1000以内所有偶数的和要求&#xff1a;请编出3个程序来&#xff0c;分别用三种循环语句完成&#xff0c;注意体会各种循环语句的执行过程及语法特点。[参考解答]【项目2&#xff1a;求阶乘】输入n&…

C语言数组学完学啥,我的c语言学习-数组专题

学到最后的数组专题了。数组数组&#xff0c;怎么着也要是一组数吧&#xff0c;对&#xff0c;数组是按顺序排列的一组同类型的数据构成的集合&#xff0c;用来保存大量同类型的相关数据。一 一维数组定义一个一维数组int a[5],表示有五个元素&#xff0c;a[0]、a[1]、a[2]…

通过图表简化sql语句的表关联

在之前的博文中分享过一个执行了两天的一条sql语句&#xff0c;走了两个大表的扫描&#xff0c;导致执行时间很长&#xff0c;通过简化sql做了不小的改进&#xff0c;今天我们来看看还可以做些什么。 上次简化后的语句如下&#xff1a;with tmp_logical_date as (SELECT logica…

输入三个数,按照由大到小的顺序输出

voidswap(int*p1,int*p2)/*实现两个数交换的函数*/{inttemp; temp*p1;*p1*p2;*p2temp;}voidexchange(int*p1,int*p2,int*p3)/*实现3个数两两比较、交换的函数*/{if(*p1<*p2) swap(p1,p2);/*比较第一个数和第二个数*/if(*p1<*p3) swap(p1,p3);/*比较第一个数和第三个数*/i…

android 自定义text,android – 使用自定义textSize实现自定义TextView

我已经实现了自定义TextView,然后我需要更改其文本大小以供将来使用.在那一步,我决定使用style.xml和attr.xml进行textSize自定义但是,当我的自定义布局膨胀时,我收到运行时错误.与我为了自定义而更改的部件相关的错误.这是我实现的代码片段.attr.xmlstyles.xml?attr/right_de…

[翻译] BFKit

BFKit BFKit is a collection of useful classes to develop Apps faster. BFKit是一个有用的工具集合&#xff0c;帮助你快速开发。 Installing and Usage Pod Pod安装 Create a Podfile in your project directoryWrite:platform :ios, 7.0xcodeproj Project.xcodeproj pod …

Camera Vision - video surveillance on C#

http://www.codeproject.com/KB/audio-video/cameraviewer.aspx 开发的资源 介绍&#xff1a;纵观当今的监控系统的发展趋势&#xff0c;能很容易发现基于IP的解决方案正在迅速的普及。有许多的制造商&#xff0c;提供广泛的IP视频射像和视频服务器&#xff0c;意味着个人的IP…

android 接口定义常量,Android开发笔记(5):常量的合理使用

今天&#xff0c;我们来聊一些“细枝末节”的问题——java中的常量。觉得很有意思&#xff0c;给大家分享一下&#xff1a;下面是我见过的几种常量定义操作&#xff1a;1.普通款&#xff1a;public class Constants {private Constants(){}public static final int MAX Intege…

mysql数据库操作手册

1 存储过程的写法 以下是一个带有入参的存储过程模板&#xff0c; #删除方案-存储过程 CREATE PROCEDURE procPersonAppointRecallPlanByPlanUuidDelete(in planUuid varchar(48)) BEGIN update PERSON_APPOINT_RECALL_DUTY set duty_status 2 WHERE duty_list_uuid in (sel…

如何写 go 代码 (How to Write Go Code 翻译)

目录 1. 写在前面的话2. 介绍3. 代码组织 3.1. 工作区3.2. GOPATH 环境变量3.3. Package 路径3.4. 第一个 GO 程序3.5. 第一个 GO 库3.6. Package name4. 测试5. 远程 package6. 下一步7. 获取帮助写在前面的话 本文为Go官方网站 How to Write Go Code 这篇文章的翻译, 水平有限…

Servlet规范定义的Servlet 生命周期

Servlet有良好的生存期的定义&#xff0c;包括如何加载、实例化、初始化、处理客户端请求以及如何被移除。这个生存期由javax.servlet.servlet接口的init,service和destroy方法表达。1、加载和实例化 容器负责加载和实例化一个Servlet。实例化和加载可以发生在引擎启动的时候&…

android auto 源代码,最近心血来潮,把Androidautosize的源码搂了一眼

https://codechina.csdn.net/mirrors/jessyancoding/androidautosize?utm_sourcecsdn_github_accelerator以上是Androidautosize的源码&#xff0c;有兴趣的就去下下来搂一眼我这边还没看完&#xff0c;就把最基础的看了一下&#xff0c;然后顺了下简单的流程&#xff0c;顺便…

11次作业

1、实验要求&#xff1a;建立一个通信录&#xff0c;通信录的结构体记录包括&#xff1a;姓名、生日、电话号码&#xff1b;其中生日又包括三项&#xff1a;年、月、日。编写程序&#xff0c;定义一个嵌套的结构类型&#xff0c;输入n&#xff08;n<10&#xff09;个联系人的…

Lucene.net 下载地址

Lucene.net 官方网站 http://lucene.apache.org/lucene.net/ Lucene.net 2.9.2 下载地址 Lucene.Net_2_9_2/ 转载于:https://www.cnblogs.com/leco/archive/2010/12/22/1913806.html

android内存卡测试,安卓sd卡真假检测工具_内存卡检测扩容卡软件_sd insight

内存卡检测扩容卡软件内存卡检测扩容卡软件由于U盘、TF卡&#xff0c;sd内存卡等移动存储设备越来越便宜&#xff0c;导致很在某宝上买到便宜且容量大的U盘或者内存卡&#xff0c;结果基本上都是扩容盘&#xff0c;所谓扩容盘&#xff0c;就是实际容量比如2G的U盘&#xff0c;经…