C# 自定义ORM框架,包含一对一,一对多关系模型

前情提要:由于是老项目,引用的数据库Ngpsql.dll 2.0.6文件版本太老,直接升级dll文件会导致很多以前的接口用不过,sql语句执行报错。所以暂时升级不了。只能...
摘要由CSDN通过智能技术生成

前情提要:由于是老项目,引用的数据库Ngpsql.dll 2.0.6 文件版本太老,直接升级dll文件会导致很多以前的接口用不过,sql语句执行报错。所以暂时升级不了。用不了微软提供的EntityFramework框架,进入正题

首先定义标签

    public class TableAttribute : Attribute
    {
        public string TableName { get; set; }
    }

    public class Column : Attribute
    {
        public string name { get; set; }

        public Column(string name)
        {
            this.name = name;
        }
    }

    public class PK : Attribute
    {
        public PK() { }
    }

    public class Ignore : Attribute
    {
        public Ignore() { }
    }

    public class ForeignKey : Attribute
    {
        public string column { get; set; }
        public ForeignKey(string column)
        {
            this.column = column;
        }
    }

    public class CollectionQuery : Attribute { 
        public string column { get; set; }
        public CollectionQuery(string column)
        {
            this.column = column;
        }
    }

然后就是框架实现模块

public class ByuHealthORM {
    private string connstring = null;
   
    public ByuHealthORM(string connstring) {
        this.connstring = connstring;
    }
    
    public List<T> Query<T>(string sqlstring) {
        try {
            List<T> result = new List<T>();
            using (NpgsqlConnection conn = new NpgsqlConnection(this.connstring)) {
                conn.Open();//打开数据库  
                NpgsqlCommand cmd = new NpgsqlCommand(sqlstring, conn);
                using (NpgsqlDataReader reader = cmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        object obj = SetModel(typeof(T), reader);
                        result.Add((T)obj);
                    }
                }
            }              
            return result;
        }
        catch (Exception e)
        {
           throw e;
        }
    }

    private object GetModel(Type tp, string sqlstring)
    {
        try
        {
            object obj = null;
            using (NpgsqlConnection conn = new NpgsqlConnection(this.connstring))
            {
                conn.Open();
                NpgsqlCommand cmd = new NpgsqlCommand(sqlstring, conn);
                NpgsqlDataReader reader = cmd.ExecuteReader();
                while (reader.Read())
                {
                    obj = SetModel(tp, re
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值