# K 快速上手 注意 请确保你的 `Visual Studio 2019` 版本 >= `16.4`。 ## 下载 Github(国际) 下载 [https://github.com/anjoy8/New_College](https://github.com/anjoy8/New_College) Gitee(国内) 下载 [https://gitee.com/laozhangIsPhi/New_College](https://gitee.com/laozhangIsPhi/New_College) ## 编译与运行 1、拿到项目后,双击 `New_College.sln` 解决方案; 2、首先 `F6` 编译,看是否有错误; 3、然后 `F5` 运行,调起 `8081` 端口,浏览器查看效果; 4、因为系统默认的是 `sqlite` 数据库,如果你想换其他数据库,请看下边; 5、注意:本系统是直接自动生成数据库和数据的,不用手动创建数据库; ## CodeFirst 与 DbFirst 1、项目同时支持两个常见开发模式:`CodeFirst` 和 `DbFirst`; 2、首先 如果你是第一次下载我的项目,肯定是想要浏览效果和直接使用对应的权限相关的内容,这个时候肯定需要用到数据库表结构,那就肯定需要 `CodeFirst` ,只需要在`appsettings.json` 里配置好数据库连接字符串(下文会说到如何配置),就能正确运行; 3、浏览器查看效果,或者配合 `Admin` 项目查看效果后,如果感觉项目可行,并打算在此基础上二次开发,那肯定会在你刚刚创建的数据库种去创建新的表结构,这个时候就需要使用 `DbFirst` 模式,来生成四层项目问题:Model+Service+Repository等; 4、你可以使用T4模板,但是我更建议使用 `/api/DbFirst/GetFrameFiles` 接口来生成,不仅支持多种类型的数据库,还支持同时多库模式的输出; 5、如果你不想用我的表结构和实体类,在项目启动的时候,把配置文件的 `SeedDBEnabled`节点设置成False即可,然后配置对应的你自己的数据库连接字符串,比如是商城的,然后使用 `/api/DbFirst/GetFrameFiles` 接口来生成你的数据库四层类文件; ## 如何配置数据库连接字符串 1、打开 `New_College` 项目下的 `appsettings.json` 文件; 2、修改 `DBS` 字节内容,配置对应的连接字符串,注意`DBType`对应不同的数据库类型; 3、把你想要运行的数据库 `Enabled` 为 `true` 即可,其他都要设置 `false`; 4、然后 `MainDB` 设置为下边你使用的指定 `ConnId`: ``` "MainDB": "WMBLOG_MSSQL", //当前项目的主库,所对应的连接字符串的Enabled必须为true "MutiDBEnabled": false, //是否开启多库 "DBS": [ { "ConnId": "WMBLOG_SQLITE", "DBType": 2,// sqlite数据库 "Enabled": true,// 设置为true,启用1 "Connection": "WMBlog.db" //只写数据库名就行 }, { "ConnId": "WMBLOG_MSSQL", "DBType": 1,// sqlserver数据库 "Enabled": true,// 设置为true,启用2 "Connection": "Server=.;Database=WMBlogDB;User ID=sa;Password=123;", "ProviderName": "System.Data.SqlClient" }, { "ConnId": "WMBLOG_MYSQL", "DBType": 0,// mysql "Enabled": false,// false 不启用 "Connection": "Server=localhost; Port=3306;Stmt=; Database=wmblogdb; Uid=root; Pwd=456;" }, { "ConnId": "WMBLOG_ORACLE", "DBType": 3,// Oracle "Enabled": false,// 不启用 "Connection": "Provider=OraOLEDB.Oracle; Data Source=WMBlogDB; User Id=sss; Password=789;" } ], ``` 5、如果你想多库操作,需要配置 ``` a:MainDB 设置为主库的 ConnId; b:MutiDBEnabled设置为true, c:把下边想要连接的多个连接字符串都设置为true ``` ## 如何配置项目端口号 1、在 `New_College` 层下的 `program.cs` 文件中,将 `8081`端口,修改为自己想要的端口号; 2、或者在 `launchSettings.json` 中设置; ## 如何项目重命名 1、双击项目根目录下的 `CreateYourProject.bat` 批处理文件; 2、根据提示,输入自己想要的项目名称即可; 3、在根目录会有一个 `.1YourProject` 文件夹,里边即你的项目; ## 新增实体模块后如何迁移到数据库 1、在 `New_College.Model` 项目目录下的 `Seed` 文件夹下,找到 `DBSeed` 类; 2、根据提示,找到生成table的地方 `myContext.CreateTableByEntity`; 3、添加进去你新增的实体类,当然也可以用下边的单独写法; 4、编译项目,没错后,运行,则数据库更新完毕; ## 新增实体,如何进行增删改查CURD操作 1、随便找一个含有业务逻辑的 `controller` 参考一下即可; 2、主要 `api` 是通过 `Service` 服务层提供业务逻辑; 3、然后服务层通过 `Repository` 仓储层封装持久化操作; 4、每一个表基本上对应一个仓储类,基本的操作都封装到了 `BaseRepository.cs` 基类仓储中; 5、添加完业务逻辑,记得要 `F6` 重新编译一下,因为项目间引用解耦了; 6、项目已经自动注入了,直接在控制器使用对应的服务层接口就行: `IxxxxService` ; ## 新增数据库表,如何反向生成四层文件 1、可以通过 `T4` 模板来生成,在 `New_College.FrameWork` 层,使用方法: [9757999.html](https://www.cnblogs.com/laozhang-is-phi/p/9757999.html#autoid-4-3-0) ; > 注意:这种方案,目前默认的只能是 `SqlServer` ,其他类型的数据库,可以看上边文章中的代码,或者群文件里对应的代码。 2、也可以通过 `Sqlsugar` 所带的方法来实现 `DbFirst`,具体查看 `Controller` 层下的 `DbFirstController.cs`; 3、总体操作过程,可以参考我的视频:[av77612407](https://www.bilibili.com/video/av77612407?p=2) ; ## 发布与部署 1、双击项目根目录下的 `New_College.Publish.bat`批处理文件; 2、执行完成后,根目录会有一个`.PublishFiles` 文件夹,就是发布后的项目; ## 如何更新项目模板 1、着急的话自己打包,不着急就提 `issue`,等我更新; 2、我的开源项目中,有个模板项目 `BlogCoreTempl` [地址](https://github.com/anjoy8/BlogCoreTempl),下载下来; 3、下载最新的 `New_College` 源代码; 4、将源代码拷贝到模板项目的 `content` 文件夹下; 5、双击 `Package.bat` 文件,就生成了最新的模板了;