由于同志们一直给我提建议说。曾经发的版本号有问题。所以经过了我这一年多的使用和扩展,如今方法基本稳定了。

如今贴出来给大家使用:

首先上场的是数据库操作层:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Linq.Expressions;
using System.Data.Objects.DataClasses;
using System.Reflection;
using JFrame.Utility;
namespace JFrame.AccessCommon
{
public class AccessBase<T> where T : EntityObject
{
protected string _TableName;
protected string _QueryColums;
protected string _PrimaryKey;
protected Type _PrimaryKeyType; /// <summary>
/// 运行数据库操作基础类方法
/// </summary>
protected DataCommon Data; /// <summary>
/// 实例化操作对象
/// </summary>
/// <param name="ConnectionString">EF连接字符串</param>
/// <param name="PrimaryKey">主键</param>
/// <param name="strTableName">表名</param>
/// <param name="QueryColums">查询的列</param>
/// <param name="IsEntityData">是否为ADO实体对象</param>
public AccessBase(string ConnectionString, string PrimaryKey = "", string strTableName = "", string QueryColums = "")
{
Data = new DataCommon(ConnectionString);
Type t = typeof(T);
if (string.IsNullOrEmpty(strTableName))
{
strTableName = t.Name; //GetType(t).ToString();
}
_TableName = strTableName;
if (string.IsNullOrEmpty(QueryColums))
{
_QueryColums = " * ";
} if (string.IsNullOrEmpty(PrimaryKey))
{
PropertyInfo[] infos = t.GetProperties();
PrimaryKey = GetPrimaryKey(infos);
}
_PrimaryKey = PrimaryKey;
} /// <summary>
/// 获取主键
/// </summary>
/// <param name="infos"></param>
/// <param name="IsEdmScalarPropertyAttribute"></param>
/// <returns></returns>
private string GetPrimaryKey(PropertyInfo[] infos)
{
string columnName = string.Empty;
foreach (PropertyInfo propertyInfo in infos)
{
object[] customInfos = propertyInfo.GetCustomAttributes(typeof(EdmScalarPropertyAttribute), true);
if (customInfos == null
|| customInfos.Length == 0)
return string.Empty; EdmScalarPropertyAttribute limit = customInfos.GetValue(0) as EdmScalarPropertyAttribute;
if (limit.EntityKeyProperty)
{
_PrimaryKeyType = propertyInfo.PropertyType;
return columnName = propertyInfo.Name;
}
}
return columnName; } /// <summary>
/// 添加单个实体
/// </summary>
/// <param name="t"></param>
public virtual void AddEntity(T t)
{
Data.InsertEntity<T>(t);
} /// <summary>
/// 获取单个实体
/// </summary>
/// <param name="query">查询条件</param>
/// <returns></returns>
public virtual T GetSingleEntity(Expression<Func<T, bool>> query)
{
return Data.GetSingleEntity<T>(query);
} public virtual List<T> GetAllEntityByPage(Expression<Func<T, bool>> query,PagingInfo PageInfo, Func<T, object> orderByDesc)
{
return Data.GetAllEntity<T>(query, PageInfo, orderByDesc);
} /// <summary>
/// 获取单个实体
/// </summary>
/// <typeparam name="T">泛型类型參数</typeparam>
/// <param name="express">查询条件</param>
/// <returns></returns>
public virtual T TryGetSingleEntity(Expression<Func<T, bool>> query)
{
try
{
return Data.GetSingleEntity<T>(query);
}
catch (Exception ex)
{
return null;
}
} /// <summary>
/// 依据条件获取单个实体
/// </summary>
/// <param name="query">查询条件</param>
/// <returns>实体对象</returns>
public virtual T GetSingleEntity(string query)
{
return GetListByWhere(query).FirstOrDefault();
} /// <summary>
/// 依据主键获取对象
/// </summary>
/// <param name="PrimaryKeyValue">主键值</param>
/// <returns>对象</returns>
public virtual T GetSingleEntity(object PrimaryKeyValue)
{
StringBuilder strWhere = new StringBuilder();
switch (_PrimaryKeyType.Name.ToLower())
{
case "int16":
case "int32":
case "int64":
case "int":
case "decimal":
case "double":
case "float":
case "short":
strWhere.AppendFormat(" {0}={1}", _PrimaryKey, PrimaryKeyValue);
break;
case "bool":
case "boolean":
if ((bool)PrimaryKeyValue)
{ strWhere.AppendFormat(" {0}=1", _PrimaryKey); }
else
{ strWhere.AppendFormat(" {0}=0", _PrimaryKey); } break;
default:
strWhere.AppendFormat(" {0}='{1}'", _PrimaryKey, PrimaryKeyValue);
break;
} return GetListByWhere(strWhere.ToString()).FirstOrDefault();
} /// <summary>
/// 改动单个实体
/// </summary>
/// <param name="t"></param>
public virtual void UpdateEntity(T t)
{
Type type = typeof(T);
PropertyInfo[] infos = type.GetProperties();
PropertyInfo info = infos.Where(p => p.Name == _PrimaryKey).FirstOrDefault();
object value = null;
if (info != null)
{
value = info.GetValue(t, null);
}
else
{
return;
}
Data.Update<T>(t, _PrimaryKey, value);
} /// <summary>
/// 依据条件删除信息
/// </summary>
/// <param name="query">条件</param>
public virtual void Delete(Expression<Func<T, bool>> query)
{
Data.DeleteEntitys<T>(query);
} /// <summary>
/// 依据条件获取相关信息表
/// </summary>
/// <param name="strWhere">Where条件</param>
/// <returns>数据集合</returns>
public virtual List<T> GetListByWhere(string strWhere)
{
StringBuilder strSql = new StringBuilder();
strSql.AppendFormat("select {1} from {0}", _TableName, _QueryColums);
if (!string.IsNullOrEmpty(strWhere))
{
strSql.AppendFormat(" where {0}", strWhere);
}
return Data.ExecuteQuery<T>(strSql.ToString()).ToList();
} public virtual List<T> GetListByWhere()
{
return GetListByWhere(string.Empty);
} /// <summary>
/// 依据条件获取相关信息
/// </summary>
/// <param name="strTableName">表名</param>
/// <param name="strColums">相关列(前面可加Top)</param>
/// <param name="strWhere">Where条件</param>
/// <returns>数据集合</returns>
public virtual List<T> GetListByWhere(string strTableName,string strColums,string strWhere,string strOrderBy)
{ StringBuilder strSql = new StringBuilder();
strSql.AppendFormat("select {1} from {0}", strTableName, strColums);
if (!string.IsNullOrEmpty(strWhere))
{
strSql.AppendFormat(" where {0}", strWhere);
} if (!string.IsNullOrEmpty(strOrderBy))
{
strSql.AppendFormat(" Order by {0}", strOrderBy);
} return Data.ExecuteQuery<T>(strSql.ToString()).ToList();
} /// <summary>
/// 依据条件获取相关监測信息表
/// </summary>
/// <param name="strWhere">Where条件</param>
/// <returns>数据集合</returns>
public virtual List<T> GetListByWhere(Expression<Func<T, bool>> query)
{
return Data.GetAllEntity<T>(query);
} /// <summary>
/// 获取列最大值
/// </summary>
/// <param name="CloumnName">列名</param>
/// <returns>最大值</returns>
public virtual object GetCloumnNameMaxValue<T2>(string CloumnName)
{
if (string.IsNullOrEmpty(CloumnName))
{
throw new Exception("列名值不能为空");
}
StringBuilder strSql = new StringBuilder();
strSql.AppendFormat("select max({1}) as val from {0}", _TableName, CloumnName);
return Data.ExecuteQuery<T2>(strSql.ToString()).FirstOrDefault(); } /// <summary>
/// 获取最大主键
/// </summary>
/// <returns></returns>
protected virtual int? GetMaxPrimaryKey()
{
StringBuilder strSql = new StringBuilder();
strSql.AppendFormat("select max({1}) from {0}", _TableName, _PrimaryKey);
return Data.ExecuteQuery<int>(strSql.ToString()).FirstOrDefault();
}
}
}

Entity Framework底层操作封装V2版本号(1)的更多相关文章

  1. Entity Framework底层操作封装V2版本号(4)

    这个版本号里面.由于涉及到了多库的操作.原有的系统方法不能做到这种事情了.所以这里有了一点差别 这个类的主要用作就是,连接字符串的作用,默认是指向默认配置里面的,可是你能够指向其它的连接 using ...

  2. Entity Framework底层操作封装V2版本号(2)

    这个类是真正的数据库操作类.上面的那个类仅仅是调用了这个封装类的方法进行的操作 using System; using System.Collections.Generic; using System ...

  3. Entity Framework底层操作封装V2版本号(3)

    如今是附加的,组合查询须要的扩展类.大家知道lanmda表达式的组合条件比較麻烦,所以就加了一样一个类,方便进行组合查询: using System; using System.Collections ...

  4. Entity Framework底层操作封装V2版本号(5)

    这个框架到如今最大的变化立即就要出现了,哪就是对缓存的使用.由于系统常常要去读取数据库数据.可是大家知道.数据库的处理能力是有限的,所以对于一些数据量不大,可是又 须要常常去读取的功能来说.更好的方法 ...

  5. entity framework 时间操作

    ).FirstOrDefault(); if (useractiveentity == null) { UserActive userActive = new UserActive(); userAc ...

  6. .NET Entity Framework入门操作

    Entity Framework是微软借鉴ORM思想开发自己的一个ORM框架. ORM就是将数据库表与实体对象(相当于三层中的Model类)相互映射的一种思想. 最大的优点就是非常方便的跨数据库平台. ...

  7. UWP: 在 UWP 中使用 Entity Framework Core 操作 SQLite 数据库

    在应用中使用 SQLite 数据库来存储数据是相当常见的.在 UWP 平台中要使用 SQLite,一般会使用 SQLite for Universal Windows Platform 和 SQLit ...

  8. Entity Framework 基础操作(1)

    EF是微软推出的官方ORM框架,默认防注入可以配合LINQ一起使用,更方便开发人员. 首先通过SQLSERVER现在有的数据库类生产EF 右键->添加->新建项,选择AOD.NET实体数据 ...

  9. 实体框架Entity Framework 4.1快速入门

    介 绍 在旧的Entity 框架中,开发者可以从已存在的数据库中产生业务实体的模型,这种开发方法被称为数据库驱动的开发方法.而在4.1的Entity Framework中,支开发者先创建实体业务类,然 ...

随机推荐

  1. CodeForces 738D Sea Battle

    抽屉原理. 先统计最多有$sum$个船可以放,假设打了$sum-a$枪都没打中$a$个船中的任意一个,那么再打$1$枪必中. #pragma comment(linker, "/STACK: ...

  2. Maven实用总结

    使用Maven还是推荐IDEA,以前用eclipse总是喜欢出现乱七八糟的问题,具体错误和解决方案也记不清楚了. 下面总结下IDEA中遇到的问题和解决方法: 与IDEA搭配的相关问题 如何根据模板快速 ...

  3. Codeforces Round #260 (Div. 1) Boredom(DP)

    Boredom time limit per test 1 second memory limit per test 256 megabytes input standard input output ...

  4. Linux基础系列-Day2

    基础命令(文件内容管理) 1.cat:在当前终端显示文本文件内容 格式:cat [文件路径] -n 从1开始对所有输出的行数编号 -b 和-n相似,只不过对于空白行不编号:2.head:从文件内容开头 ...

  5. 【HDU 5730】Shell Necklace

    http://acm.hdu.edu.cn/showproblem.php?pid=5730 分治FFT模板. DP:\(f(i)=\sum\limits_{j=0}^{i-1}f(j)\times ...

  6. cogs 1075. [省常中2011S4] 最短路径问题

    1075. [省常中2011S4] 最短路径问题 ★   输入文件:short.in   输出文件:short.out   简单对比 时间限制:1 s   内存限制:128 MB [问题描述] 平面上 ...

  7. (疯狂java)第一课

    (本文章只是为了好玩,没有别的意思,有理解错误之处,恳请提醒,谢谢) 环境变量的安装 记得很久之前大学学习java的时候还需要配置环境变量.系统变量,今天看了一下居然还是需要配置,想想啊,mac下面已 ...

  8. 原生js实现图片轮播思路分析

    一.复习原生js实现图片轮播 1.要点 自动轮播 点击小圆圈按钮,显示相应图片 点击左右箭头,实现向前向后轮播图片 2.实现思路 <div id="container"> ...

  9. 神勇的产品经理之路系列-10 PD三板斧

    一.三板斧的来源及理解  三板斧 古代长兵器的一种,又名“马战斧”.相传为程咬金所用.斧阔五寸,柄长七尺.用法有劈.砍.剁.搂.截.撩.云.片.推.支等. 比喻义:解决问题的方法不多,但却非常管用. ...

  10. 改变element-ui滚动条设置,

    基于vue的滚动条组件之--element隐藏组件滚动条scrollbar使用 在项目中,总是需要用到滚动条,但windows浏览器默认的滚动条是很丑的,为了页面美观,可以考虑优化滚动条样式.  vu ...