虽然微软提供了T4模板,但是我感觉非常难用。哪儿比得上直接用脚本来写模板来的爽。

因为要给一个老项目做周边的工具,需要连接到数据库。

我习惯性用EntityFrameworkCore来做,因为毕竟从出道开始就一直在用的一个ORM。

EF6时代,vs提供了dbfirst,但是只是针对sqlserver好像。

因为这次的数据库是MySQL,所以vs很多东西都支持不够了。

但是支持不够就自己动手丰衣足食嘛。


我们使用ejs这个模板引擎来做生成器。

  1. npm install ejs

然后用查询出表结构:

  1. b.query('desc posts').then(res => {
  2.  
  3. })

然后编写模板,ejs的模板语法和aspx时代的时候的模板语法很相似,都是尖括号+百分号这样的风格<%%>,相信有aspx开发经验的老铁们对这个模板引擎还是很习惯的

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5.  
  6. namespace 你的命名空间
  7. {
  8. public class <%= table -%>
  9. {
  10. <% rows.forEach(function(row){ -%>
  11. <% if(row.Type.indexOf('bigint')!=-1){ -%>
  12. public long <%= row.Field %> { get; set; }
  13. <% } -%>
  14. <% if(row.Type.indexOf('datetime')!=-1){ -%>
  15. public DateTime <%= row.Field %> { get; set; }
  16. <% } -%>
  17. <% if(row.Type.indexOf('varchar')!=-1){ -%>
  18. public string <%= row.Field %> { get; set; }
  19. <% } -%>
  20. <% if(row.Type.indexOf('mediumtext')!=-1){ -%>
  21. public string <%= row.Field %> { get; set; }
  22. <% } -%>
  23. <% if(row.Type.indexOf('bit')!=-1){ -%>
  24. public bool <%= row.Field %> { get; set; }
  25. <% } -%>
  26. <% if(row.Type.indexOf('longtext')!=-1){ -%>
  27. public string <%= row.Field %> { get; set; }
  28. <% } -%>
  29. <% }); -%>
  30. }
  31. }

以上的模板中,针对不同的MySQL数据类型做了对应的C#类型映射。

然后使用ejs来渲染出一个文本,最后保存到文件夹中就ok了

  1. var tableName = '表名字'; //对应的模板中的class名字和生成的cs文件的名字
  2. ejs.renderFile('./template/posts.ejs', { rows: res.rows, 'table': tableName}, (err, str) => {
  3. if (err) {
  4. console.error(err);
  5. }
  6. else {
  7. let temp = path.join(__dirname, 'temp');
  8. var exist = fs.existsSync(temp)
  9. if (!exist) {
  10. fs.mkdirSync()
  11. }
  12. fs.writeFile(path.join(temp, tableName+'.cs'), str, (err) => {
  13. if (err) {
  14. console.error(err);
  15. } else {
  16. console.log('生成模板成功');
  17. }
  18. })
  19.  
  20. }
  21. })

使用node执行一下,就能生成出一个cs文件了。

因为我表不多,我就单个生成就行了。如果要扩展出整个数据库都生成,可以再写几行代码就能整个库都生成了!


需要交流的老铁们可以点击博客下边的链接或直接搜索群号加入QQ群:545594312

用node.js给C#写一个数据表的实体类生成工具的更多相关文章

  1. 用node.js从零开始去写一个简单的爬虫

    如果你不会Python语言,正好又是一个node.js小白,看完这篇文章之后,一定会觉得受益匪浅,感受到自己又新get到了一门技能,如何用node.js从零开始去写一个简单的爬虫,十分钟时间就能搞定, ...

  2. 使用Node.js原生API写一个web服务器

    Node.js是JavaScript基础上发展起来的语言,所以前端开发者应该天生就会一点.一般我们会用它来做CLI工具或者Web服务器,做Web服务器也有很多成熟的框架,比如Express和Koa.但 ...

  3. Node.js学习之TCP/IP数据通讯

    Node.js学习之TCP/IP数据通讯 1.使用net模块实现基于TCP的数据通讯 提供了一个net模块,专用于实现TCP服务器与TCP客户端之间的通信 1.1创建TCP服务器 在Node.js利用 ...

  4. 前端使用node.js的http-server开启一个本地服务器

    前端使用node.js的http-server开启一个本地服务器 在写前端页面中,经常会在浏览器运行HTML页面,从本地文件夹中直接打开的一般都是file协议,当代码中存在http或https的链接时 ...

  5. Node.js压缩与解压数据

    Node.js中提供了一个很好的库Zlib来压缩解压数据. 一.压缩缓冲区 Zlib中有下面几个函数方便解压缩缓冲区. gzip/gunzip:标准gzip压缩. deflate/inflate:基于 ...

  6. 使用node.js的http-server开启一个本地服务器

    用html写了一个网页,想要在手机上查看适配效果,但是苦于手机上没有直接查看HTML的.想到手机和电脑都在一个局域网内,能不能搭建一个局域网内的网页服务器呢? 1.下载 http-server 显然, ...

  7. npm 是node.js下带的一个包管理工具

    npm 是node.js下带的一个包管理工具          npm install -g webpack webpack是一个打包工具 gulp是一个基于流的构建工具,相对其他构件工具来说,更简洁 ...

  8. ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法

    ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法 语法 第一种: 通过使用Oracle语句块  --指定文档所有部门都能查看 declare cursor TABLE_DEPT and ...

  9. 自己写一个 Hash 表

    项目地址:  https://github.com/kelin-xycs/HashTableLib 为什么会想要自己写一个 Hash 表, 以前也想过 Hash 表 的 原理, 觉得很神奇, 不过最近 ...

随机推荐

  1. vue-router-next 通过hash模式访问页面不生效,直接刷新页面一直停留在根路由界面的解决办法

    vue3中,配合的vueRouter版本更改为vue-router-next通过 npm i vue-router@next 的方式进行引入添加,随后创建 router.js,在main.js里面引入 ...

  2. spring-dao.xml通常写法

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  3. GEKCTF2020-web

    GEKCTF [GKCTF2020]CheckIN97 <title>Check_In</title> <?php highlight_file(__FILE__); c ...

  4. SPJ方法

    https://www.cnblogs.com/ztz11/p/10657351.html luogu https://blog.csdn.net/qwerty1125/article/details ...

  5. 【CF1425H】Huge Boxes of Animal Toys 题解

    原题链接 题意简介: 已知分别处在 \((-\infty,-1]\) H.\((-1,0)\) .\((0,1)\) .\([1,\infty)\) 的实数的数量(下记为集合 \(A,B,C,D\) ...

  6. Go map相关

    map Go语言中的map是一种无序的,基于key-value的数据解构,在Go语言中map是引用类型,因此必须初始化后才能使用. 以下示例将展示如何声明一个map类型,以及如何简单使用. 需要注意的 ...

  7. 【小白学PyTorch】18 TF2构建自定义模型

    [机器学习炼丹术]的炼丹总群已经快满了,要加入的快联系炼丹兄WX:cyx645016617 参考目录: 目录 1 创建自定义网络层 2 创建一个完整的CNN 2.1 keras.Model vs ke ...

  8. html 网页美化--2

    html网页美化: 鼠标点击特效:爱心.爆炸烟花(有些特效在Chrome中无法实现,推荐使用edge) 背景樱花花瓣 鼠标滑动彩带 此代码也可以用于博客园主页美化(需要申请JS权限):复制到博客侧边栏 ...

  9. 在uniapp或者vue中单行文字或者符号无法换行的终极解决方案

    在VUE开发过程中,会出现比较诡异的情况. 比如常规的英文或中文显示都是很正常的,但是当出现了一些中文符号(比如,!等等)在文末的时候,总是会超出view的显示区域. 那么在遇到上面这种问题我们记得检 ...

  10. SHOI 2014 【概率充电器】

    加油,两道了,也就还剩那么二十来道吧,慢慢做...... 题目大意: 给你一颗树,树上的每一个节点都有一定的概率p[i]能冲上电,有电的点,可以通过树上的边,一定概率地将电传递到与它相邻的点,同时对于 ...