欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c# 如何實(shí)現(xiàn)代碼生成器

 更新時(shí)間:2020年12月14日 08:36:42   作者:程序員ken  
這篇文章主要介紹了c# 如何實(shí)現(xiàn)代碼生成器,幫助大家更好的理解和使用c# 編程語言,感興趣的朋友可以了解下

做了2,3年的java-web,始終木有逃離所謂基礎(chǔ)業(yè)務(wù),增刪改查這些一成不變的東西寫起來浪費(fèi)大量時(shí)間,于是做了個(gè)簡(jiǎn)單的代碼生成器快速生成

代碼生成器的原理其實(shí)很簡(jiǎn)單,都是基于模板實(shí)現(xiàn)替換,模板基于是Nvelocity。

部分代碼展示:【目前只支持mysql 、oracle、sqlite 三種數(shù)據(jù)庫的連接 有需要 可以自己增加】

sing System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using personal_manage.Common.DAL;
using personal_manage.Common.dto;
using personal_manage.DAL.adapter;
using personal_manage.Models.entity;

namespace personal_manage.BLL.adapter
{
  public class DbBLL
  {
    public List<TableInfo> SelectTableList(CodeProjectDbConfigInfo codeProjectDbConfigInfo, string tableKeyword)
    {
      if (codeProjectDbConfigInfo.DbType == "Mysql" )
      {
       return DbAdapter.SelectTableNameByMySql(codeProjectDbConfigInfo.DbConnect, codeProjectDbConfigInfo.DbName, tableKeyword);
      }else if(codeProjectDbConfigInfo.DbType == "Oracle")
      {
        return DbAdapter.SelectTableNameByOracle(codeProjectDbConfigInfo.DbConnect, codeProjectDbConfigInfo.DbName, tableKeyword);
      }
      else if (codeProjectDbConfigInfo.DbType == "Sqlite")
      {
        return DbAdapter.SelectTableNameBySqlite(codeProjectDbConfigInfo.DbConnect, codeProjectDbConfigInfo.DbName, tableKeyword);
      }


      return null;
    }


    public List<TableFieldInfo> SelectTableFields(CodeProjectDbConfigInfo codeProjectDbConfigInfo, string tableName)
    {
      if (codeProjectDbConfigInfo.DbType == "Mysql")
      {
        return DbAdapter.SelectTableFieldsByMySql(codeProjectDbConfigInfo.DbConnect, codeProjectDbConfigInfo.DbName, tableName);
      }
      else if (codeProjectDbConfigInfo.DbType == "Oracle")
      {
        return DbAdapter.SelectTableFieldsByOracle(codeProjectDbConfigInfo.DbConnect, codeProjectDbConfigInfo.DbName, tableName);
      }
      else if (codeProjectDbConfigInfo.DbType == "Sqlite")
      {
        return DbAdapter.SelectTableFieldsBySqlite(codeProjectDbConfigInfo.DbConnect, codeProjectDbConfigInfo.DbName, tableName);
      }

      return null;
    }
  }
}

演示界面:
數(shù)據(jù)庫配置

模板配置:

生成:

內(nèi)置有一套java的模板,調(diào)用的是jar包 【需要安裝jdk,所有說是c# c++ java的文件存放位置 實(shí)際生成的后綴都是.java或.jsp .html】

源碼地址:https://gitee.com/ten-ken/per...

以上就是c# 如何實(shí)現(xiàn)代碼生成器的詳細(xì)內(nèi)容,更多關(guān)于c# 代碼生成器的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論