关于Farseer.net轻量级ORM开源框架 V1.0 概念版本开发的消息
V0.2版的开源距离今天(05年03月)已有近3年的时间。可以说这个版本已经有点落伍的感觉了,呵呵。
V0.2版至今一直处于BUG的修复及一些细小功能的增加,所以版本号上一直没有变化。
其实在这1、2年中,我一直在想着Farseer.Net 的未来发展状况。有尝试用EF的核心、也有想过用NHibernate的核心。仅仅是在这些核心的基础下做二次开发,以个人编码的经验从客户端调用角度进行“优化”,但总是感觉缺少点什么?没错,就是缺少研发精神,缺少属于Farseer.Net独特的一面,有种寄人(第三方框架)篱下的感觉。所以决定还是完全采用自己的编码吧。当然在一些处理手法上,也会尝试去学习他们的优点。
本次V1.0的升级,是一个质的改变,(尽可能不改变客户端调用)
- 完全重写内核代码(FS.Core);
- 以面向接口的设计模式进行编写。
- 实现批量SQL的传输(相对V0.2,是每一条SQL就与数据库交互的)。
- 实现延迟加载。
- 内置内存数据库。(有时候为了做一些小尝试,没必要去专门创建一个数据库,或者无法联网的情况下)
- 考虑到可能有些人只用到本框架ORM部份,因此非必要的代码,独立为一个类库,按实现需要附加。
- 分离表、存储过程、视图。
- Farseer.Net未提供到的一些SQL高级运用,支持自定义SQL。
- 更易于扩展新的SQL的方法。(比如V0.2中,GroupBy/Join是未支持的。需要支持的话,对于V0.2来说,是比较困难的(维护))。
- 提供与V0.2方式一样的数据访问以外,增加数据仓库的方式。第三条说到的批量SQL,是将执行中的SQL,加到组队列中(SQL被暂存到每个队列中,来等待被执行)
这10条中的每一条要实现都是比较困难的,暂时计划是2015年4月初有一个比较完整的版本出来。
不了解Farseer.Net 的朋友,可以看看V0.2的教程。其实目前优秀的ORM框架不胜其数,Farseer.Net开源仅是为了让大家学习了解一般的ORM框架的实现。从中希望大家对里在面代码不科学地方,多提出来。让大家一同进步。
下面,放上目前框架中片断代码,有兴趣的朋友,可以到GitHub处下载。目前框架完全托管在GitHub中。并且我将每天进行不间断的更新。
using System;
using FS.Configs;
using FS.Core.Data; namespace FS.Core.Context
{
/// <summary>
/// 表上下文
/// </summary>
public class TableContext : IDisposable
{
/// <summary>
/// 通过数据库配置,连接数据库
/// </summary>
/// <param name="dbIndex">数据库选项</param>
/// <param name="tableName">表名称</param>
protected internal TableContext(int dbIndex = , string tableName = null) : this(DbFactory.CreateConnString(dbIndex), DbConfigs.ConfigInfo.DbList[dbIndex].DataType, DbConfigs.ConfigInfo.DbList[dbIndex].CommandTimeout, tableName) { } /// <summary>
/// 通过自定义数据链接符,连接数据库
/// </summary>
/// <param name="connectionString">数据库连接字符串</param>
/// <param name="dbType">数据库类型</param>
/// <param name="commandTimeout">SQL执行超时时间</param>
/// <param name="tableName">表名称</param>
protected internal TableContext(string connectionString, DataBaseType dbType = DataBaseType.SqlServer, int commandTimeout = , string tableName = null) : this(new DbExecutor(connectionString, dbType, commandTimeout), tableName) { } /// <summary>
/// 事务
/// </summary>
/// <param name="database">数据库执行</param>
/// <param name="tableName">表名称</param>
protected internal TableContext(DbExecutor database, string tableName = null)
{
Database = database;
TableName = tableName;
IsMergeCommand = true;
} /// <summary>
/// 数据库
/// </summary>
internal protected DbExecutor Database { get; private set; } /// <summary>
/// 合并执行命令
/// </summary>
internal protected bool IsMergeCommand { get; set; } /// <summary>
/// 表名
/// </summary>
internal protected string TableName { get; protected set; } /// <summary>
/// 保存修改
/// IsMergeCommand=true时:只提交一次SQL到数据库
/// </summary>
public int SaveChanges()
{
return -;
} /// <summary>
/// 释放资源
/// </summary>
public void Dispose()
{
Database.Dispose();
Database = null;
}
}
}
using System;
using System.Collections.Generic;
using System.Linq.Expressions;
using FS.Core.Infrastructure; namespace FS.Core.Context
{
public class TableSet<TEntity> : IDisposable where TEntity : class, new()
{
/// <summary>
/// 数据库上下文
/// </summary>
private TableContext<TEntity> _dbContext; /// <summary>
/// 禁止外部实例化
/// </summary>
private TableSet() { } internal TableSet(TableContext<TEntity> dbContext) : this()
{
_dbContext = dbContext;
QueryProvider = DbFactory.CreateQuery(_dbContext);
} /// <summary>
/// 数据库查询支持
/// </summary>
private IQuery QueryProvider { get; set; } /// <summary>
/// 字段选择器
/// </summary>
/// <param name="select">字段选择器</param>
public TableSet<TEntity> Select<T>(Expression<Func<TEntity, T>> select)
{
//QueryProvider.QueryQueue.ExpSelect = QueryProvider.QueryQueue.ExpSelect == null ? QueryProvider.QueryQueue.ExpSelect = select : Expression.Add(QueryProvider.QueryQueue.ExpSelect, select);
return this;
} /// <summary>
/// 查询条件
/// </summary>
/// <param name="where">查询条件</param>
public TableSet<TEntity> Where(Expression<Func<TEntity, bool>> where)
{
//QueryProvider.QueryQueue.ExpWhere = QueryProvider.QueryQueue.ExpWhere == null ? QueryProvider.QueryQueue.ExpWhere = where : Expression.Add(QueryProvider.QueryQueue.ExpWhere, where);
return this;
} public TableSet<TEntity> Desc<TKey>(Expression<Func<TEntity, TKey>> desc)
{
//QueryProvider.QueryQueue.ExpOrderBy = QueryProvider.QueryQueue.ExpOrderBy == null ? QueryProvider.QueryQueue.ExpOrderBy = desc : Expression.Add(QueryProvider.QueryQueue.ExpOrderBy, desc);
return this;
} public TableSet<TEntity> Asc<TKey>(Expression<Func<TEntity, TKey>> asc)
{
//QueryProvider.QueryQueue.ExpOrderBy = QueryProvider.QueryQueue.ExpOrderBy == null ? QueryProvider.QueryQueue.ExpOrderBy = asc : Expression.Add(QueryProvider.QueryQueue.ExpOrderBy, asc);
return this;
}
public List<TEntity> ToList()
{
return QueryProvider.QueryQueue.List.Query<TEntity>();
} public TEntity ToInfo()
{
return QueryProvider.QueryQueue.Info.Query<TEntity>();
} public TEntity Update(TEntity entity)
{
QueryProvider.QueryQueue.Update.Query(entity);
return entity;
} public int Delete()
{
return QueryProvider.QueryQueue.Delete.Query<TEntity>();
} public TEntity Insert(TEntity entity)
{
QueryProvider.QueryQueue.Insert.Query(entity);
return entity;
} public void Dispose()
{
throw new NotImplementedException();
}
}
}
using System.Collections.Generic;
using FS.Core.Context;
using FS.Core.Infrastructure; namespace FS.Core.Client.SqlServer
{
public class SqlServerQuery : IQuery
{
/// <summary>
/// 组列表
/// </summary>
private List<IQueryQueue> GroupQueryQueueList { get; set; } public SqlServerQuery(TableContext tableContext)
{
TableContext = tableContext;
Init();
} public TableContext TableContext { get; private set; }
public IQueryQueue QueryQueue { get; set; } public void Execute()
{
GroupQueryQueueList.Add(QueryQueue);
Init();
} public void Init()
{
QueryQueue = new SqlServerQueryQueue(this);
if (GroupQueryQueueList == null) { GroupQueryQueueList = new List<IQueryQueue>(); }
}
}
}
using System.Linq.Expressions;
using System.Text;
using FS.Core.Client.SqlServer.Query;
using FS.Core.Infrastructure;
using FS.Core.Infrastructure.Query; namespace FS.Core.Client.SqlServer
{
public class SqlServerQueryQueue : IQueryQueue
{
private readonly IQuery _queryProvider;
public Expression ExpOrderBy { get; set; }
public Expression ExpSelect { get; set; }
public Expression ExpWhere { get; set; }
public StringBuilder Sql { get; set; }
public SqlServerQueryQueue(IQuery queryProvider)
{
_queryProvider = queryProvider;
} private IQueryQueueList _list;
public IQueryQueueList List { get { return _list ?? (_list = new SqlServerQueryList(_queryProvider)); } } private IQueryQueueInfo _info;
public IQueryQueueInfo Info { get { return _info ?? (_info = new SqlServerQueryInfo(_queryProvider)); } } private IQueryQueueInsert _insert;
public IQueryQueueInsert Insert { get { return _insert ?? (_insert = new SqlServerQueryInsert(_queryProvider)); } } private IQueryQueueUpdate _update;
public IQueryQueueUpdate Update { get { return _update ?? (_update = new SqlServerQueryUpdate(_queryProvider)); } } private IQueryQueueDelete _delete;
public IQueryQueueDelete Delete { get { return _delete ?? (_delete = new SqlServerQueryDelete(_queryProvider)); } } public void Dispose()
{
Sql.Clear();
ExpOrderBy = null;
ExpSelect = null;
ExpWhere = null;
Sql = null;
_list = null;
_info = null;
_insert = null;
_update = null;
_delete = null;
}
}
}
可能当你看到以上代码时,已经是陈旧了。关注最新代码,请到GitHub中。
using (var context = new TableContext<UserPO>())
{
var info = context.TableSet.Where(o => o.ID > ).Desc(o => new { o.ID, o.LoginCount }).Asc(o => o.GenderType).ToInfo();
info.PassWord = ""; context.TableSet.Update(info);
context.TableSet.Insert(info); var lst = context.TableSet.Where(o => o.ID > ).Desc(o => new { o.ID, o.LoginCount }).Asc(o => o.GenderType).ToList(); context.SaveChanges();
}
TableContext<UserPO>.Data.Select(o => o.ID).Where(o => o.ID > ).ToList();
QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net
关于Farseer.net轻量级ORM开源框架 V1.0 概念版本开发的消息的更多相关文章
- Farseer.net轻量级ORM开源框架 V1.0 开发目标
本篇主要给大家说明下在V1.0中,计划开发的任务的状态.按照国际惯例.上大表格 开发计划状态 编号 模块 状态 说明 1 分离Utils.Extend.UI √ 在V0.2版本中,是集成在一个项 ...
- Farseer.net轻量级ORM开源框架 V1.x 教程目录
本篇教程将以Ver 1.x版本进行详细使用讲解 大家有任何疑问可以加入我们的官方QQ群进行讨论.QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net 整个 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射 下一篇:Farseer.net轻量级ORM ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作 下一篇:Farseer.net轻量级ORM开源框 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射 下一篇:Farseer.net轻量级ORM开源框 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文 下一篇:Farseer.net轻量级ORM开源框 ...
随机推荐
- visio2010对齐粘附功能
对齐与粘附功能在绘图时应用非常广泛.可以快速将图形对齐,以及将连接点准确地吸附在你想要连接的点上. 那么visio2010对齐粘附功能隐藏在什么地方呢? 你可以点击[视图]选项卡,在[视觉帮助]组中. ...
- jetty9 web app的部署
jetty9将web app和web app的context配置文件都放在${JETTY_HOME}/webapps下面. 例如,如果有一个myapp.war,首先将其放入${JETTY_HOME}/ ...
- VCL代码的一些设计手法(使用OO虚函数的技巧)
1. 抽象类法(VCL不推荐):第一,允许创建抽象类对象,因为语法没问题,但允许其错误.第二,接口更好.第三,如果是混合抽象类,则推荐Place Holder方法2. Place Holder(占位) ...
- C++明确规定,不能获取构造函数和析构函数的地址
C++标准明确规定,不能获取构造函数和析构函数的地址,因此也无法形成指向他们的成员函数指针. 指向成员函数的指针可以,指向构造函数析构函数的不行.因为构造函数和析构函数都是没有返回值的,无法声明一个没 ...
- 设计模式-(12)迭代器模式 (swift版)
一,概念 迭代器模式(Iterator Pattern)是 Java 和 .Net 编程环境中非常常用的设计模式.这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示.迭代器模式属于行为型 ...
- Cmake的介绍和使用 Cmake实践【转】
本文转载自:http://www.cppblog.com/Roger/archive/2011/11/17/160368.html Cmake的介绍和使用 Cmake实践 Cmake优点: 1. ...
- action 与 action 之间的跳转
这个要看你的两个action是不是在通一个package下了 <!-- 相同package下调用其它action --><action name="loginUser&qu ...
- 数据库sqlite3的使用-ios中引用方法
一.简单说明 在iOS中使用SQLite3,首先要添加库文件libsqlite3.dylib和导入主头文件. 导入头文件,可以使用库中的函数(是纯C语言的) 二.具体说明 新建一个项目,在项目的主界面 ...
- KMP算法在字符串中的应用
KMP算法是处理字符串匹配的一种高效算法 它首先用O(m)的时间对模板进行预处理,然后用O(n)的时间完成匹配.从渐进的意义上说,这样时间复杂度已经是最好的了,需要O(m+n)时间.对KMP的学习可以 ...
- 使用expdp的心得
第一步:首先使用DBA权限的用户创建directory,我使用system ,可以在服务器本地创建,也可以远程连接sqlplus进行创建,使用的将是服务器上面的路径.要确保创建directory时,操 ...