在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
虽然微软提供了T4模板,但是我感觉非常难用。哪儿比得上直接用脚本来写模板来的爽。 因为要给一个老项目做周边的工具,需要连接到数据库。 我习惯性用EntityFrameworkCore来做,因为毕竟从出道开始就一直在用的一个ORM。 EF6时代,vs提供了dbfirst,但是只是针对sqlserver好像。 因为这次的数据库是MySQL,所以vs很多东西都支持不够了。 但是支持不够就自己动手丰衣足食嘛。 我们使用ejs这个模板引擎来做生成器。 npm install ejs 然后用查询出表结构: b.query('desc posts').then(res => { }) 然后编写模板,ejs的模板语法和aspx时代的时候的模板语法很相似,都是尖括号+百分号这样的风格<%%>,相信有aspx开发经验的老铁们对这个模板引擎还是很习惯的 using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; namespace 你的命名空间 { public class <%= table -%> { <% rows.forEach(function(row){ -%> <% if(row.Type.indexOf('bigint')!=-1){ -%> public long <%= row.Field %> { get; set; } <% } -%> <% if(row.Type.indexOf('datetime')!=-1){ -%> public DateTime <%= row.Field %> { get; set; } <% } -%> <% if(row.Type.indexOf('varchar')!=-1){ -%> public string <%= row.Field %> { get; set; } <% } -%> <% if(row.Type.indexOf('mediumtext')!=-1){ -%> public string <%= row.Field %> { get; set; } <% } -%> <% if(row.Type.indexOf('bit')!=-1){ -%> public bool <%= row.Field %> { get; set; } <% } -%> <% if(row.Type.indexOf('longtext')!=-1){ -%> public string <%= row.Field %> { get; set; } <% } -%> <% }); -%> } } 以上的模板中,针对不同的MySQL数据类型做了对应的C#类型映射。 然后使用ejs来渲染出一个文本,最后保存到文件夹中就ok了 var tableName = '表名字'; //对应的模板中的class名字和生成的cs文件的名字 ejs.renderFile('./template/posts.ejs', { rows: res.rows, 'table': tableName}, (err, str) => { if (err) { console.error(err); } else { let temp = path.join(__dirname, 'temp'); var exist = fs.existsSync(temp) if (!exist) { fs.mkdirSync() } fs.writeFile(path.join(temp, tableName+'.cs'), str, (err) => { if (err) { console.error(err); } else { console.log('生成模板成功'); } }) } }) 使用node执行一下,就能生成出一个cs文件了。 因为我表不多,我就单个生成就行了。如果要扩展出整个数据库都生成,可以再写几行代码就能整个库都生成了! 以上就是如何用nodejs给C#写一个数据表的实体类生成工具的详细内容,更多关于nodejs的资料请关注极客世界其它相关文章! |
请发表评论