关于c#:从MetadataWorkspace读取MaxLength

        string connectionString { get { return "Server=;Database=;Integrated Security=SSPI;"; } }

        [Test]
        public void Test()
        {
            using var dbcontext = new DB_Context(connectionString);
            var entity = new ResultInfoEntity();
            var maxLength = GetMaxLenth(dbcontext, nameof(ResultInfoEntity), nameof(entity.EntName));
        }

        private int GetMaxLenth(DbContext context, string entityName, string propertyName)
        {
            var tables = context.Model.GetEntityTypes();
            var table = tables.First(type => type.ClrType.Name == entityName);
            return table.FindProperty(propertyName).GetMaxLength() ?? -1;
        }

获取数据库字段名和MaxLength,放到字典

       static public Dictionary<string, int> GetColumeMaxLengthDictionary<T>(DbContext dbcontext, T entity)
        {
            //var entity1 = default(T);
            //var entity2 = typeof(T);

            var entityName = typeof(T).Name;

            var colume_maxLength = new Dictionary<string, int>();

            Type type = entity.GetType();
            PropertyInfo[] ps = type.GetProperties();
            foreach (PropertyInfo i in ps)
            {
                if (i.PropertyType == typeof(string) || i.PropertyType == typeof(decimal))
                {
                    if (!colume_maxLength.ContainsKey(i.Name))
                    {
                        var ml = GetMaxLenth(dbcontext, entityName, i.Name);
                        colume_maxLength.Add(i.Name, ml);
                    }
                }
            }

            return colume_maxLength;
        }

调用

            var dbcontext = new DB_Context_CIS(this.CurrentService.ConnectionString);
            var entity = new ResultInfoEntity();
            var maxLengthDictionary = this.GetColumeMaxLengthDictionary(dbcontext, entity);

            var dbcontextTarget = new DB_Context_CIS(this.CurrentService.TargetConnectionString);
            var entityTarget = new ResultInfoEntity();
            var maxLengthDictionaryTarget = this.GetColumeMaxLengthDictionary(dbcontextTarget, entityTarget);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值