c# Database.SqlQuery<T> 试验

1.概要

Database.SqlQuery<T> T应该是个什么样的类型呢?

1.简单类型可以吗?(int,string)

2.用类有啥要求?

2.1 简单的成员空页面? int a;

2.2 是否必须要属性 ? int a{seg;get;}

2.3 变量是否需要共有?

3.用objcect 作为这个T可以吗?

4.用dynamic可以吗

2.试验结果

T(Model)
分类成员/属性数据多T数据少于T共有私有
简单类型1OK
objectNG
dynamicNG
普通对象int a;11NG
11NG
int a{set;get;}11OK
1OK
11OK
1OK
数据模型int a{set;get;}1OK
1NG
数据可以少于T单是主键不能少

通过上面的试验,可以确定 对应普通对象 只要是属性(int a{set;get;})无论是否共有都可以成功获取到数据,但是如果定义为了数据模型(DbSet<Tb1> Tb1s { set; get; }),那么数据不能少于T的内容。

3.试验代码

using MySql.Data.EntityFramework;
using System;
using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity;

namespace EF试验2
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine();
            Program p = new Program();
            p.mian();
            Console.ReadKey();
        }
        private void mian()
        {
            //test1();
            //test2();
            //test2_2();
            test2_2_1();
            //test2_1();
            //test3();
            //test4();
            //test5();
            //test6();
            //test6_1();
            //test6_1_1();
            //test7();
            //test8();
            //test9();
            //test9_1();
            //test9_1_1();
        }
        private void test1()
        {
            DBContentMy dBContentMy = new DBContentMy();
            Tb1 tb1 = new Tb1();
            tb1.v1 = 1;
            dBContentMy.Tb1s.Add(tb1);
            dBContentMy.SaveChanges();
        }
        private void test2()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<Tb1>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            //Console.WriteLine();
        }
        private void test2_2()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<Tb1>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            //Console.WriteLine();
        }
        private void test2_2_1()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<Tb1>("SELECT id,v1 FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            //Console.WriteLine();
        }
        private void test2_1()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<Tb1>("SELECT v1 FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            //Console.WriteLine();
        }
        /// <summary>
        /// 使用非引用类型 - 可以
        /// </summary>
        private void test3()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<int>("SELECT v1 FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            //Console.WriteLine();
        }
        /// <summary>
        /// 使用非引用类型+类型换行 - 可以
        /// </summary>
        private void test4()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<string>("SELECT v1 FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            //Console.WriteLine();
        }
        /// <summary>
        /// 使用dynamic/object 都不行
        /// 物料是但数据还是使用* 都不行
        /// </summary>
        private void test5()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<dynamic>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
        class A{
            int v1;
        }
        /// <summary>
        /// 使用 少于实际变量的类型 可以
        /// </summary>
        private void test6()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<A>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
        class A1
        {
            int v1 { set; get; }
        }
        /// <summary>
        /// 使用 少于实际变量的类型 可以
        /// </summary>
        private void test6_1()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<A1>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
        class A11
        {
            public int v1;
        }
        /// <summary>
        /// 使用 少于实际变量的类型 可以
        /// </summary>
        private void test6_1_1()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<A11>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
        class B
        {
            int v1;
            int v2;
        }
        /// <summary>
        /// 使用 多于实际变量的类型 可以
        /// </summary>
        private void test7()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<B>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
        
        /// <summary>
        /// 使用 多于实际变量的类型 可以
        /// </summary>
        private void test8()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<B>("SELECT v1 FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }

        class C
        {
            int v1;
            int id;
        }
        /// <summary>
        /// 使用 多于实际变量的类型 可以
        /// </summary>
        private void test9()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<C>("SELECT v1 FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
        class C1
        {
            int v1 { set; get; }
            int id { set; get; }
        }
        /// <summary>
        /// 使用 多于实际变量的类型 使用属性 可以
        /// </summary>
        private void test9_1()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<C1>("SELECT v1 FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
        /// <summary>
        /// 使用匹配的类型 使用属性 可以
        /// </summary>
        private void test9_1_1()
        {
            DBContentMy dBContentMy = new DBContentMy();
            var a = dBContentMy.Database.SqlQuery<C1>("SELECT * FROM tb1").FirstOrDefaultAsync();
            a.Wait();
            var b = a.Result;
            Console.WriteLine(b);
        }
    }
    [Table("Tb1")]
    public class Tb1
    {
        public int id { set; get; }
        public int v1 { set; get; }
    }
    [DbConfigurationType(typeof(MySqlEFConfiguration))]
    public class DBContentMy : DbContext
    {
        public DBContentMy() : base("DbConnStr")
        {
            Database.SetInitializer<DBContentMy>(null);
        }
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
        }


        public DbSet<Tb1> Tb1s { set; get; }
    }
}

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用 `JsonConvert.DeserializeObject<Data>(jsonData)` 方法返回 null 时,通常是由于 Json 字符串格式错误或者 C# 对象的结构不匹配导致的。 以下是一些可能导致返回 null 的原因: 1. Json 字符串格式错误。Json 字符串必须符合 Json 标准格式,例如属性名必须使用双引号包裹,属性名和属性值之间必须用冒号分隔,属性之间必须用逗号分隔等。如果 Json 字符串格式不正确,`JsonConvert.DeserializeObject<Data>(jsonData)` 方法将返回 null。 2. C# 对象的结构不匹配。C# 对象的结构必须和 Json 数据的格式相匹配,如果 C# 对象的结构不匹配,`JsonConvert.DeserializeObject<Data>(jsonData)` 方法将返回 null。 3. C# 对象中的属性名称和 Json 数据中的属性名称不匹配。C# 对象中的属性名称必须与 Json 数据中的属性名称一致,如果不一致,`JsonConvert.DeserializeObject<Data>(jsonData)` 方法将返回 null。 如果 `JsonConvert.DeserializeObject<Data>(jsonData)` 方法返回 null,可以通过以下方法进行调试: 1. 检查 Json 字符串的格式是否正确,可以使用在线 Json 格式化工具进行验证。 2. 检查 C# 对象的结构是否与 Json 数据的格式相匹配,确保属性名称和类型都正确。 3. 检查 C# 对象中的属性名称是否与 Json 数据中的属性名称一致,确保属性名称相同。 4. 使用 Debug.Log 打印出 Json 字符串和 C# 对象,查看它们之间的区别。 5. 使用 try-catch 语句捕获异常,输出异常信息,以便更好地定位问题。 总之,当 `JsonConvert.DeserializeObject<Data>(jsonData)` 方法返回 null 时,需要仔细检查 Json 数据和 C# 对象,确保它们之间的结构和属性名称、类型都匹配。同时,使用调试工具和技巧帮助我们更好地定位和解决问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值