从 azure table 读取行时的空值

Null values when reading rows from azure table

我正在尝试从 Azure 存储中获取所有行 table,但是当我向它们显示所有值时,除了 PartitionKey 和 RowKey 为 null 或 0。是我遗漏了什么还是我做错了什么导致无法正确读取所有值?

这是我用来获取所有数据的代码。

 List<Employe> employeList = new List<Employe>();
 TableQuery<Employe> query = new TableQuery<Employe>();
 employeList = table.ExecuteQuery(query).ToList();

这是模型。

class Employe:TableEntity
    {
        public string prenume { get; set; }
        public string functie  { get; set; }
        public int salar_baza { get; set; }
        public int retineri { get; set; }
        public int spor { get; set; }
        public int total_brut { get; set; }
        public int brut_impozabil { get; set; }
        public int impozit { get; set; }
        public int cas { get; set; }
        public int cass { get; set; }
        public int virat_card { get; set; }
        public  int premii_brute { get; set; }

        public Employe()
        {
        }
        public Employe(string nr_crt, string name,string prename,string function, int salarBaza,int retinere,int sporuri,int premiu_burt)
        {
            PartitionKey = nr_crt;
            RowKey = name;
            this.prenume = prename;
            this.functie = function;
            this.salar_baza = salarBaza;
            this.retineri = retinere;
            this.spor = sporuri;
            this.premii_brute = premiu_burt;

            this.total_brut = salarBaza+(salarBaza*(sporuri/100))+premiu_burt;
            this.cas = (25/100)*total_brut;
            this.cass = (10/100)*total_brut;
            this.brut_impozabil = total_brut-cas-cass;
            this.impozit = (10/100)*brut_impozabil;
            this.virat_card =total_brut-impozit-cas-cass-retinere;
        }
    }

我自己还没有测试过,但我很确定这适用:

使用 TableQuery 及其内置反序列化器时,它使用无参数构造函数 public Employe() 创建一个新的空对象。然后它会尝试查找匹配的属性,但不查找它们的名称。但是由于您的所有属性的名称都与 table 存储中的值不同,因此 none 已设置。

因此,要么重命名您的属性以匹配您的存储(例如,将 public string prenume 重命名为 public string prename),要么在您的属性上使用注释,例如 these.