vs2017,sqlserver2017(localdb)调试通过。
在sqlserver中创建数据库d1,表t1如下:
录入数据如下:
在vs新建任意项目,此处以控制台为例。
添加数据模型Model1:
为了尽量少写代码,选择下图内容(该模式似乎没有迁移问题,挺好的):
说明:连接字符串可以在代码中自行设置,所以下面选了“否”并且没有勾选复选框。
选择需要使用的表:
完成
项目里自动添加Model1.cs和t1.cs。一个是数据库对象(含表),一个是表里的记录对象。
把Model1.cs当中的‘base("name=Model1")’改成用连接字符串
@"server=(localdb)mssqllocaldb;initial catalog=d1;user ID=sa;password=1;"
表示:
可以看到两个文件中声明的属性和类,一个表示表,一个是记录。
至此,完成模型和数据库部分,可以写主程序了。代码和效果如下:
static void Main(string[] args) { Model1 m = new Model1();//声明数据库对象m //利用linq语句筛选记录。类似于select * from t1 var students = from x in m.t1 select x; //利用lamda表达式筛选出符合条件的记录 t1 student = m.t1.First(x => x.nl > 18); foreach (var item in students) { Console.WriteLine($"{item.xm} {item.nl} {item.cj1} {item.xb}"); } Console.WriteLine($"{student.xm} {student.nl} {student.cj1} {student.xb}"); Console.ReadKey(); }