iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么用nodejs给C#写一个数据表的实体类生成工具
  • 524
分享到

怎么用nodejs给C#写一个数据表的实体类生成工具

2023-06-15 00:06:53 524人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关怎么用nodejs给C#写一个数据表的实体类生成工具,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。虽然微软提供了T4模板,但是我感觉非常难用。哪儿比得上直接用脚本来写模板来的爽

这篇文章将为大家详细讲解有关怎么用nodejsC#写一个数据表的实体类生成工具,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

虽然微软提供了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#写一个数据表的实体类生成工具”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: 怎么用nodejs给C#写一个数据表的实体类生成工具

本文链接: https://www.lsjlt.com/news/276251.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql毫秒时间戳转时间怎么实现
    在MySQL中,可以使用FROM_UNIXTIME()函数将毫秒时间戳转换为时间。需要注意的是,FROM_UNIXTIME()函数接...
    99+
    2024-05-14
    mysql
  • mysql创建序列的方法是什么
    MySQL并没有内置的序列功能,但可以通过创建一个表来模拟序列的功能。以下是一种创建序列的方法: 创建一个表来存储序列的当前值: ...
    99+
    2024-05-14
    mysql
  • mysql怎么修改自增列的初始值
    要修改MySQL表中自增列的初始值,可以使用ALTER TABLE语句。以下是一个示例: ALTER TABLE table_nam...
    99+
    2024-05-14
    mysql
  • MySQL如何设置自增初始值
    在MySQL中,可以使用AUTO_INCREMENT关键字来设置自增初始值。可以使用以下语法来设置自增初始值: ALTER TABL...
    99+
    2024-05-14
    mysql
  • oracle怎么设置主键自增
    在Oracle数据库中,可以通过序列(Sequence)和触发器(Trigger)来实现设置主键自增的功能。 首先,需要创建一个序列...
    99+
    2024-05-14
    oracle
  • pgsql删除索引的方法是什么
    要删除一个索引,可以使用以下SQL语句: DROP INDEX index_name; 其中index_name是要删除的索引的名...
    99+
    2024-05-14
    pgsql
  • db2表空间状态0x4000怎么解决
    表空间状态0x4000表示该表空间为“冻结”状态,这可能是由于一些异常情况导致的。要解决这个问题,可以尝试以下几种方法: ...
    99+
    2024-05-14
    db2
  • mysql大文本字段优化的方法是什么
    在MySQL中,大文本字段(如TEXT、BLOB类型)的优化方法有以下几种: 使用合适的数据类型:根据实际需求选择合适的数据类型...
    99+
    2024-05-14
    mysql
  • oracle更改字符集的方法是什么
    要更改Oracle数据库的字符集,可以通过以下步骤来实现: 确保在更改字符集之前备份数据库,以防发生意外情况。 确定当前数据...
    99+
    2024-05-14
    oracle
  • 怎么更改oracle数据库字符集
    要更改Oracle数据库的字符集,可以按照以下步骤操作: 确保备份数据:在进行字符集更改之前,务必备份数据库以防止数据丢失。 ...
    99+
    2024-05-14
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作