Web重温系列(一):SQLite+EF6实现本地化存储

  本来我们的产品有着复杂的层次结构,作为客户端的C# WinForm是不操作据库的。但是最近有个需求,需要将据本地保存。可选的方案很多,比如文本文件或者XML序列化和反序列化,或者如access、dbf等传统文件数据库。但是为了赶时髦,我们决定使用SQLite(其实也不时髦了:))。而且我们既然不习惯于操作数据库,我们就不想使用基本的ADO.Net写SQL语句来操作数据,于是ORM就是最好的选择了。EF是微软的实现,对于首次尝试ORM的我们,当然是第一选择。

  领导和同事给了很多指导和帮助,在此表示感谢。

  操作流程如下:

  1. 安装SQLite客户端

    客户端种类繁多,笛子安装的是DB Browser for SQLite();

  2. 创建数据库(文件)和数据表

    a. 利用客户端创建数据库文件(扩展名为.sqlite),一个数据库文件相当于一个database(单数据库);

    b. 执行创建数据库表Student的脚本(相当于表级别);

  3. 在VS中利用NuGet包管理器安装System.Data.SQLite

    会自动引用控件和修改App.config配置文件;

  4. 创建于表结构完全一样的类

  也可以不一样,然后通过Annotation标签,Table、Key、Column等映射到SQLite表中

  (也可以通过创建“ADO.Net数据模型实体”来自动生成,如果采取这种方式,5也不需要了)

[Table("Student")] public class Student { [Key] [Column("id")] public int Id {get;set;} [Column("name")] public string Name {get;set;} [Column("age")] public decimal Age {get;set;} }

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wspyyy.html