安装如下插件:
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下载
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
List students = data.GetEntityList();// 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 GetEntityList(this DataTable data) where TEntity:class, new(){// 用来装转换后的数据var list = new List();// 拿到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
List students = data.GetEntityList();// 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 GetEntityList(this DataTable data) where TEntity:class, new(){// 用来装转换后的数据var list = new List();// 拿到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){// 是否打了特性指定了ColumnNameif(prop.IsDefined(typeof(FieldNameAttribute), false)){var fieldNameAttribute = prop.GetCustomAttribute();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;}
}
有一些ORM你将对象传进一个函数,它就给你处理插入到数据库中,这是怎么弄的呢?
如:
var student = new Student{};
conn.Insert(student); //ORM怎么处理的?