实例介绍
本实例详细介绍了如何利用Entity Framework CodeFirst技术基于EdmModel创建SQLite数据库。这一过程对于.NET全框架和EF6以及.NET Core 3及以上版本尤其有用。如果你正在使用.NET Core 3或更高版本与EF Core,那么你可能不需要这个库,因为EF Core已经支持code first和迁移。但是,对于仍在使用EF 6的用户来说,这个库提供了一个实现SQLite code first的有效选项。
特点:
- 支持从类创建表(支持注解:Table)
- 支持从属性创建列(支持注解:Column, Key, MaxLength, Required, NotMapped, DatabaseGenerated, Index等)
- 主键约束、外键约束、非空约束、自增、唯一约束等
- 索引自动创建,支持自定义排序函数
- 支持SQL默认值设置
使用方法:
根据你的需求选择合适的初始化器,如SqliteCreateDatabaseIfNotExists、SqliteDropCreateDatabaseAlways或SqliteDropCreateDatabaseWhenModelChanges。通过继承并重写Seed方法,可以在数据库创建后填充核心或测试数据。
示例代码:
public class MyDbContext : DbContext { public MyDbContext() : base("ConnectionStringName") { } protected override void OnModelCreating(DbModelBuilder modelBuilder) { var sqliteConnectionInitializer = new SqliteCreateDatabaseIfNotExists<MyDbContext>(modelBuilder); Database.SetInitializer(sqliteConnectionInitializer); } }
本项目不仅适用于需要从代码直接创建SQLite数据库的场景,也为希望深入定制化数据库创建过程的开发者提供了灵活的工具和接口。
【实例截图】
【核心代码】
文件清单
└── SQLiteCodeFirst-14d91e749ea762f8679aa345a74f66a4a60e6631
├── ci_appveyor.yml
├── LICENSE
├── README.md
├── release_appveyor.yml
├── Shared
│ ├── SQLite.CodeFirst.ruleset
│ └── SQLite.CodeFirst.StrongNameKey.snk
├── SQLite.CodeFirst
│ ├── Internal
│ │ ├── AssemblyInfo.cs
│ │ ├── Builder
│ │ │ ├── ColumnStatementCollectionBuilder.cs
│ │ │ ├── CompositePrimaryKeyStatementBuilder.cs
│ │ │ ├── CreateDatabaseStatementBuilder.cs
│ │ │ ├── CreateIndexStatementBuilder.cs
│ │ │ ├── CreateTableStatementBuilder.cs
│ │ │ ├── ForeignKeyStatementBuilder.cs
│ │ │ ├── IStatementBuilder.cs
│ │ │ └── NameCreators
│ │ │ ├── ColumnNameCreator.cs
│ │ │ ├── IndexNameCreator.cs
│ │ │ ├── NameCreator.cs
│ │ │ └── SpecialChars.cs
│ │ ├── Convention
│ │ │ └── SqliteForeignKeyIndexConvention.cs
│ │ ├── Extensions
│ │ │ ├── DbModelBuilderExtensions.cs
│ │ │ ├── EdmPropertyExtensions.cs
│ │ │ ├── EntityTypeExtension.cs
│ │ │ └── ListExtensions.cs
│ │ ├── Statement
│ │ │ ├── ColumnConstraint
│ │ │ │ ├── CollateConstraint.cs
│ │ │ │ ├── ColumnConstraintCollection.cs
│ │ │ │ ├── DefaultValueConstraint.cs
│ │ │ │ ├── IColumnConstraintCollection.cs
│ │ │ │ ├── IColumnConstraint.cs
│ │ │ │ ├── MaxLengthConstraint.cs
│ │ │ │ ├── NotNullConstraint.cs
│ │ │ │ ├── PrimaryKeyConstraint.cs
│ │ │ │ └── UniqueConstraint.cs
│ │ │ ├── ColumnStatementCollection.cs
│ │ │ ├── ColumnStatement.cs
│ │ │ ├── CompositePrimaryKeyStatement.cs
│ │ │ ├── CreateDatabaseStatement.cs
│ │ │ ├── CreateIndexStatementCollection.cs
│ │ │ ├── CreateIndexStatement.cs
│ │ │ ├── CreateTableStatement.cs
│ │ │ ├── ForeignKeyStatement.cs
│ │ │ ├── IStatementCollection.cs
│ │ │ └── IStatement.cs
│ │ └── Utility
│ │ ├── AssociationTypeContainer.cs
│ │ ├── ConnectionStringParser.cs
│ │ ├── HashCreator.cs
│ │ ├── HistoryEntityTypeValidator.cs
│ │ ├── InMemoryAwareFile.cs
│ │ └── SqliteAssociationType.cs
│ ├── Public
│ │ ├── Attributes
│ │ │ ├── AutoincrementAttribute.cs
│ │ │ ├── CollateAttribute.cs
│ │ │ ├── OnConflictAction.cs
│ │ │ ├── SqlDefaultValueAttribute.cs
│ │ │ └── UniqueAttribute.cs
│ │ ├── Collation.cs
│ │ ├── CollationFunction.cs
│ │ ├── DbInitializers
│ │ │ ├── SqliteCreateDatabaseIfNotExists.cs
│ │ │ ├── SqliteDropCreateDatabaseAlways.cs
│ │ │ ├── SqliteDropCreateDatabaseWhenModelChanges.cs
│ │ │ └── SqliteInitializerBase.cs
│ │ ├── Entities
│ │ │ ├── History.cs
│ │ │ └── IHistory.cs
│ │ ├── IDatabaseCreator.cs
│ │ ├── ISqliteSqlGenerator.cs
│ │ ├── SqliteDatabaseCreator.cs
│ │ └── SqliteSqlGenerator.cs
│ └── SQLite.CodeFirst.csproj
├── SQLite.CodeFirst.Console
│ ├── App.config
│ ├── Entity
│ │ ├── Coach.cs
│ │ ├── CustomHistory.cs
│ │ ├── FooCompositeKey.cs
│ │ ├── Foo.cs
│ │ ├── FooRelationshipA.cs
│ │ ├── FooRelationshipB.cs
│ │ ├── FooSelf.cs
│ │ ├── FooStep.cs
│ │ ├── IEntity.cs
│ │ ├── Person.cs
│ │ ├── Player.cs
│ │ ├── Stadion.cs
│ │ └── Team.cs
│ ├── FootballDbContext.cs
│ ├── FootballDbInitializer.cs
│ ├── ModelConfiguration.cs
│ ├── Program.cs
│ └── SQLite.CodeFirst.Console.csproj
├── SQLite.CodeFirst.NetCore.Console
│ ├── Configuration.cs
│ ├── Entity
│ │ ├── Coach.cs
│ │ ├── CustomHistory.cs
│ │ ├── FooCompositeKey.cs
│ │ ├── Foo.cs
│ │ ├── FooRelationshipA.cs
│ │ ├── FooRelationshipB.cs
│ │ ├── FooSelf.cs
│ │ ├── FooStep.cs
│ │ ├── IEntity.cs
│ │ ├── Person.cs
│ │ ├── Player.cs
│ │ ├── Stadion.cs
│ │ └── Team.cs
│ ├── FootballDbContext.cs
│ ├── FootballDbInitializer.cs
│ ├── ModelConfiguration.cs
│ ├── Program.cs
│ └── SQLite.CodeFirst.NetCore.Console.csproj
├── SQLite.CodeFirst.sln
└── SQLite.CodeFirst.Test
├── app.config
├── IntegrationTests
│ ├── InMemoryDbCreationTest.cs
│ ├── InMemoryDbTest.cs
│ ├── SqlGenerationDefaultCollationTest.cs
│ └── SqlGenerationTest.cs
├── SQLite.CodeFirst.Test.csproj
└── UnitTests
├── Builder
│ └── NameCreators
│ ├── IndexNameCreatorTest.cs
│ └── NameCreatorTest.cs
├── Statement
│ ├── ColumnConstraint
│ │ ├── CollateConstraintTest.cs
│ │ ├── ColumnConstraintCollectionTest.cs
│ │ ├── DefaultValueConstraintTest.cs
│ │ ├── MaxLengthConstraint.cs
│ │ ├── NotNullConstraintTest.cs
│ │ ├── PrimaryKeyConstraintTest.cs
│ │ └── UniqueConstraintTest.cs
│ ├── ColumnStatementCollectionTest.cs
│ ├── ColumnStatementTest.cs
│ ├── CreateDatabaseStatementTest.cs
│ ├── CreateIndexStatementCollectionTest.cs
│ ├── CreateTableStatementTest.cs
│ ├── ForeignKeyStatementTest.cs
│ ├── PrimaryKeyStatementTest.cs
│ └── StatementTestBase.cs
└── Utility
├── ConnectionStringParserTest.cs
├── HashCreatorTest.cs
└── HistoryEntityTypeValidatorTest.cs
27 directories, 131 files
标签:
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论