clf.code.first
1.1.0
dotnet add package clf.code.first --version 1.1.0
NuGet\Install-Package clf.code.first -Version 1.1.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="clf.code.first" Version="1.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add clf.code.first --version 1.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: clf.code.first, 1.1.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install clf.code.first as a Cake Addin #addin nuget:?package=clf.code.first&version=1.1.0 // Install clf.code.first as a Cake Tool #tool nuget:?package=clf.code.first&version=1.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
code.first.mysql
代码到数据库存的工具
要求
- 代码对业务工程,无侵入。
- 以类的字段为主,数据库字段在类字段没有的一律删除
- 只有 Table 注解标注的类才表示数据库中有表
- 没有Columns 注解标记的数据表中不保存
始策略
开发模式:每一次启动(生成)处理
生主环境:通过配制版本号(更新或重装,重置)后处理
运行时机
宿主程序,主动调用;异步 运行 并报告进度信息
如果在 Debug 模式下,启动一次运行一次
#if DEBUG string connstring = "Server=127.0.0.1;Database=test;User Id=admin;Password=Bnhq@1234;pooling=false;CharSet=utf8;port=3306"; Assembly assembly = Assembly.GetExecutingAssembly(); MainWorker.Run(assembly, connstring, CollBack); #else
- 在 RELEASE 模式下
- 程序更新时,运行
- 配制数据库,储存时运行
- 在 RELEASE 模式下
处理规则
表
1.新加入的类,增加表 2.后加入的类,更新表 3.数据表中多余Table, 不处理
列
1.新加入的类Field,增加Column 2.后加入的类Field,更新表 Column 3.数据表中多余Colum 删除
Attributes 特性 同理 Annotation 注解
Table
- Name
- Comment
Id
1. AutoIncrement 2. Type
Columns
1.Name
- Type
- Length
- IsNull
- Default
- Comment
类型对应表
C# class Type | Len | Mysql DB Type | Len |
---|---|---|---|
bool | tinyint | ||
Int32 | int integer | ||
int64 | bigint | ||
Decmail | decmail | ||
Float Double | double | ||
String | varchar text | ||
其余的基本用不到 |
注意
- 主键 只会第一次构建时创建,一般是(id),后期修改主键无效。
优势
- 深度学习,得到提升
- 插件式项目,功能插件,可以自动生成数据库
- 可以不在同一台服务器
- 可以不是同一个数据库
- 插件的增加和删除,不影响原来的宿主项目
单独的 代码仓库管理
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
自动根据类,维护 Sqlite 和MySql 表结构,开发时只关注代码和编写,不关注数据结构的变化