文章目录
- 一、使用vscode开发.net core程序
- 二、创建解决方案
- 三、反射
- 3.1 反射应用场景一
- 3.2 反射应用场景二
一、使用vscode开发.net core程序
安装如下插件:
1、vscode-solution-explorer
2、.NET Core Extension Pack
3、搜索nuget工具包并安装
二、创建解决方案
图形化创建
通过命令行创建
dotnet new sln -n "study001"
创建asp.net core webapi
创建webapi的时候.net 5和.net 6创建出来的程式代码写法是不一样的,我们安装.net 6 sdk
.net 6 sdk下载
三、反射
3.1 反射应用场景一
using System.Data;
// 1: 构建虚拟数据
var data = new DataTable();
data.Columns.AddRange(new DataColumn[3]
{
new DataColumn("Id"),
new DataColumn("Name"),
new DataColumn("NickName")
});
data.Rows.Add(1, "张三", "小张子");
data.Rows.Add(1, "李四", "小李子");
data.Rows.Add(1, "王五", "小五子");
// 2:给DataTable加一个扩展方法,直接从中获取到List<Student>
List<Student> students = data.GetEntityList<Student>();
// 3:我们定义的对象属性不一定和数据库里的字段一致,加一些特性
foreach(Student student in students)
{
Console.WriteLine($"{student.Id}--{student.Name}--{student.NickName}");
}
public class Student
{
public int Id { get; set; }
public string Name { get; set; }
public string NickName { get; set; }
}
// 扩展方法必须定在静态类中
public static class DataTableExtensions
{
public static List<TEntity> GetEntityList<TEntity>(this DataTable data) where TEntity:class, new()
{
// 用来装转换后的数据
var list = new List<TEntity>();
// 拿到TEntity的所有属性
var properties = typeof(TEntity).GetProperties();
foreach(DataRow row in data.Rows)
{
var entity = new TEntity();
// 为这个entity赋值
foreach(var prop in properties)
{
// 数据中的所有字段
foreach(DataColumn column in data.Columns)
{
if(prop.Name.Equals(column.ColumnName, StringComparison.OrdinalIgnoreCase))
{
// 将实体中取出来的值的类型转换成对象TEntity的属性类型
var value = Convert.ChangeType(row[column], prop.PropertyType);
prop.SetValue(entity, value);
}
}
}
list.Add(entity);
}
return list;
}
}
带特性Attribute的反射
using System.Data;
using System.Reflection;
// 1: 构建虚拟数据
var data = new DataTable();
data.Columns.AddRange(new DataColumn[3]
{
new DataColumn("t_id"),
new DataColumn("t_name"),
new DataColumn("t_nickname")
});
data.Rows.Add(1, "张三", "小张子");
data.Rows.Add(1, "李四", "小李子");
data.Rows.Add(1, "王五", "小五子");
// 2:给DataTable加一个扩展方法,直接从中获取到List<Student>
List<Student> students = data.GetEntityList<Student>();
// 3:我们定义的对象属性不一定和数据库里的字段一致,加一些特性
foreach(Student student in students)
{
Console.WriteLine($"{student.Id}--{student.Name}--{student.NickName}");
}
// 定义特性,其实也是一个类
public class FieldNameAttribute : Attribute
{
public FieldNameAttribute(string fieldName)
{
FieldName = fieldName;
}
public string FieldName { get; }
}
public class Student
{
[FieldName("t_id")]
public int Id { get; set; }
[FieldName("t_name")]
public string Name { get; set; }
[FieldName("t_nickname")]
public string NickName { get; set; }
}
// 扩展方法必须定在静态类中
public static class DataTableExtensions
{
public static List<TEntity> GetEntityList<TEntity>(this DataTable data) where TEntity:class, new()
{
// 用来装转换后的数据
var list = new List<TEntity>();
// 拿到TEntity的所有属性
var properties = typeof(TEntity).GetProperties();
foreach(DataRow row in data.Rows)
{
var entity = new TEntity();
// 为这个entity赋值
foreach(var prop in properties)
{
// 数据中的所有字段
foreach(DataColumn column in data.Columns)
{
// 是否打了特性指定了ColumnName
if(prop.IsDefined(typeof(FieldNameAttribute), false))
{
var fieldNameAttribute = prop.GetCustomAttribute<FieldNameAttribute>();
if(fieldNameAttribute.FieldName.Equals(column.ColumnName, StringComparison.OrdinalIgnoreCase))
{
var value = Convert.ChangeType(row[column], prop.PropertyType);
prop.SetValue(entity, value);
}
}
else if(prop.Name.Equals(column.ColumnName, StringComparison.OrdinalIgnoreCase))
{
// 将实体中取出来的值的类型转换成对象TEntity的属性类型
var value = Convert.ChangeType(row[column], prop.PropertyType);
prop.SetValue(entity, value);
}
}
}
list.Add(entity);
}
return list;
}
}
3.2 反射应用场景二
有一些ORM你将对象传进一个函数,它就给你处理插入到数据库中,这是怎么弄的呢?
如:
var student = new Student{};
conn.Insert(student); //ORM怎么处理的?