SQL Table 自动生成Net底层-生成数据操作Repository

生成接口类

        public static string DataTableToBaseIService(string tableName, string nameSpace, string className){var table = SqlTableHelper.GetSQLTableInfo(tableName);StringBuilder reval = new StringBuilder();reval.AppendFormat(@"       
using System;
using System.Collections.Generic;
using System.Data;
using {0}.Mapping;namespace {0}.IService
{{public partial interface {1}{{     /// <summary>/// 保存/// </summary>          int Save({2} model);/// <summary>/// 获取数据(分页)/// </summary>/// <param name=""filterSql"">查询条件</param>/// <param name=""pageIndex"">页码</param>/// <param name=""pageSize"">每页显示数量</param>/// <param name=""total"">总行数</param>/// <param name=""sort"">排序条件</param>/// <returns>返回DataTable</returns>         DataTable PageData(string filterSql,int pageIndex,int pageSize,out int total,string sort="""");/// <summary>/// 获取数据(不分页)/// </summary>         /// <param name=""filterSql"">查询条件</param>/// <param name=""sort"">排序条件</param>/// <returns>返回DataTable</returns>          DataTable PageData(string filterSql,string sort="""");/// <summary>/// 获取单条数据/// </summary>/// <param name=""filterSql"">查询条件</param>/// <returns>返回DataTable</returns>   DataTable GetSingle(string filterSql);/// <summary>/// 删除/// </summary>          int Delete({3} {4});}}
}}", nameSpace, className, tableName, SqlTableToMapping.ChangeType(table.Rows[0]["数据类型"].ToString()), table.Rows[0]["列名"]);return reval.ToString();}public static string DataTableToUserIService(string nameSpace, string className){StringBuilder reval = new StringBuilder();reval.AppendFormat(@"       
using System;
using System.Collections.Generic;
using System.Data;
using {0}.Mapping;namespace {0}.IService
{{public partial interface {1}{{     }}
}}", nameSpace, className);return reval.ToString();}
View Code

实现接口

        #region 生成基础类public static string DataTableToBaseRepository(DataTable dt, string className, string nameSpace){string key = dt.Rows[0]["列名"].ToString();string tableName = dt.Rows[0]["表名"].ToString();StringBuilder reval = new StringBuilder();reval.AppendFormat(@"       
using System;
using System.Collections.Generic;
using System.Data;
using System.Text;
using System.Data.SqlClient;
using {0}.Mapping;
using {0}.IRepository;
using {0}.Common;namespace {0}.Repository
{{public partial class {1}:I{1}{{public int Save({2} model){{StringBuilder sb = new StringBuilder();   {3}{4}         }}", nameSpace, className, tableName, GetMaxKey(dt), GetAddMethod(dt, key, tableName));//生成分页方法reval.AppendFormat(@"/// <summary>/// 获取数据(分页)/// </summary>/// <param name=""filterSql"">查询条件</param>/// <param name=""pageIndex"">页码</param>/// <param name=""pageSize"">每页显示数量</param>/// <param name=""total"">总行数</param>/// <param name=""sort"">排序条件</param>/// <returns>返回DataTable</returns>   public DataTable PageData(string filterSql, int pageIndex, int pageSize, out int total, string sort = """"){{{0}}}", GetPageMethod(tableName));reval.AppendFormat(@"/// <summary>/// 获取数据(分页)/// </summary>/// <param name=""filterSql"">查询条件</param>/// <param name=""sort"">排序条件</param>/// <returns>返回DataTable</returns>   public DataTable PageData(string filterSql, string sort = """"){{{0}}}", GetListMethod(tableName));reval.AppendFormat(@"/// <summary>/// 获取单条数据/// </summary>/// <param name=""filterSql"">查询条件</param>/// <returns>返回DataTable</returns>   public DataTable GetSingle(string filterSql){{{0}}}", GetSingleMethod(tableName));reval.AppendFormat(@"/// <summary>/// 删除数据/// </summary>/// <param name=""key"">主键</param>/// <returns>返回DataTable</returns>   public int Delete({2} {0}){{{1}}}", key, GetDeleteMethod(tableName, key), SqlTableToMapping.ChangeType(dt.Rows[0]["数据类型"].ToString()));reval.AppendFormat(@"}}
}}");return reval.ToString();}private static string GetMaxKey(DataTable dt){StringBuilder sb = new StringBuilder();sb.AppendFormat(@"sb.AppendFormat("" declare @{0} {1} "");", dt.Rows[0]["列名"], dt.Rows[0]["数据类型"]);sb.AppendFormat(@" sb.AppendFormat("" select @{0}=isnull(max({0}),0)+1 from {1}"");", dt.Rows[0]["列名"], dt.Rows[0]["表名"]);return sb.ToString();}private static string GetAddMethod(DataTable dt, string key, string tableName){StringBuilder sb = new StringBuilder();//新增语句StringBuilder sbAddMethod = new StringBuilder();sbAddMethod.AppendFormat(@"sb.AppendFormat("" insert into {0} (", tableName);//修改语句StringBuilder sbEditMethod = new StringBuilder();sbEditMethod.AppendFormat(@"sb.AppendFormat("" set @{0}=model.{0} "");", key);sbEditMethod.AppendFormat(@" sb.AppendFormat("" update {0} set "");", tableName);StringBuilder sbColumns = new StringBuilder();StringBuilder sbColumnValues = new StringBuilder();//参数StringBuilder sbPara = new StringBuilder();sbPara.AppendFormat(@" var paras = new List<SqlParameter>();");for (var i = 0; i < dt.Rows.Count; i++){sbColumns.AppendFormat(" {0},", dt.Rows[i]["列名"]);if (i == 0){sbColumnValues.AppendFormat(" @{0},", key);}else{sbColumnValues.AppendFormat(" @{0},", dt.Rows[i]["列名"]);sbPara.AppendFormat(@" paras.Add(new SqlParameter(""@{0}"",model.{0}));", dt.Rows[i]["列名"]);}if (i == dt.Rows.Count - 1){sbEditMethod.AppendFormat(@"  sb.AppendFormat("" @{0}={{0}}"",model.{0});", dt.Rows[i]["列名"]);}else{sbEditMethod.AppendFormat(@"  sb.AppendFormat("" @{0}={{0}},"",model.{0});", dt.Rows[i]["列名"]);}}sbColumns = new StringBuilder(sbColumns.ToString().Substring(0, sbColumns.Length - 1));sbColumns.Append(@""");");sbAddMethod.Append(sbColumns);sbAddMethod.AppendFormat(@" sb.AppendFormat("" select @{0},", key);sbColumnValues = new StringBuilder(sbColumnValues.ToString().Substring(0, sbColumnValues.Length - 1));sbColumnValues.Append(@""");");sbAddMethod.Append(sbColumnValues);sbEditMethod.AppendFormat(@" sb.AppendFormat("" where {0}={{0}},"",model.{0});", key);sb.AppendFormat(@"if(model.{0}==0){{{1}}}else{{{2}}}", key, sbAddMethod, sbEditMethod);sb.Append(sbPara);sb.AppendFormat(@" return DbHelperSQL.ExecuteSql(sb.ToString(),paras.ToArray());");return sb.ToString();}private static string GetPageMethod(string tableName){StringBuilder sb = new StringBuilder();sb.AppendFormat(@" string cmdText = ""Proc_UP_Pagination"";DataTable dt = null;SqlParameter[] paras = new SqlParameter[] {{ new SqlParameter(""@TableName"",""{0}""),new SqlParameter(""@Fields"",""*""),new SqlParameter(""@OrderField"",sort),new SqlParameter(""@sqlWhere"",filterSql),new SqlParameter(""@pageSize"",pageSize),new SqlParameter(""@pageIndex"",pageIndex),new SqlParameter(""@Total"",SqlDbType.Int,11),}};paras[6].Direction = ParameterDirection.Output; dt = DbHelperSQL.RunProcedure(cmdText, paras,""{0}"").Tables[0];total = Convert.ToInt32(paras[6].Value);return dt;", tableName);return sb.ToString();}public static string GetListMethod(string tableName){StringBuilder sb = new StringBuilder();sb.AppendFormat(@"string cmdText = string.Empty;DataTable dt = null;cmdText = string.Format(""SELECT * FROM {0} WHERE 1=1"");if (!string.IsNullOrEmpty(filterSql))cmdText += string.Format(""  AND "" + filterSql);if (!string.IsNullOrEmpty(sort))cmdText += string.Format(""  ORDER BY "" + sort);dt = DbHelperSQL.Query(cmdText).Tables[0];return dt;", tableName);return sb.ToString();}public static string GetSingleMethod(string tableName){StringBuilder sb = new StringBuilder();sb.AppendFormat(@"string cmdText = string.Empty;DataTable dt = null;cmdText = string.Format(""SELECT TOP 1 * FROM {0} WHERE 1=1"");if (!string.IsNullOrEmpty(filterSql))cmdText += string.Format(""  AND "" + filterSql);dt = DbHelperSQL.Query(cmdText).Tables[0];return dt;", tableName);return sb.ToString();}public static string GetDeleteMethod(string tableName, string key){StringBuilder sb = new StringBuilder();sb.AppendFormat(@"string cmdText = string.Empty;cmdText = string.Format(""DELETE FROM {0} WHERE {1}=@{1}"");SqlParameter[] paras = new SqlParameter[] {{ new SqlParameter(""@{1}"",{1}),}};var iret = DbHelperSQL.ExecuteSql(cmdText);return iret;", tableName, key);return sb.ToString();}#endregion#region 生成自定义类public static string DataTableToUserRepository(string className, string nameSpace){StringBuilder reval = new StringBuilder();reval.AppendFormat(@"       
using System;
using System.Collections.Generic;
using System.Data;
using System.Text;
using System.Data.SqlClient;
using {0}.Mapping;namespace {0}.Repository
{{public partial class {1}{{}}", nameSpace, className);return reval.ToString();}#endregion
View Code

 生成Autofac注入类

        public static string AutofaceClass(string nameSpace, DataTable dt){StringBuilder sb = new StringBuilder();sb.AppendFormat(@"
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Autofac;
using {0}.Mapping;
using {0}.IRepository;
namespace {0}.Repository
{{public class RepositoryModule : Module{{protected override void Load(ContainerBuilder builder){{", nameSpace);for (var i = 0; i < dt.Rows.Count; i++){sb.AppendFormat(@"builder.RegisterType<{0}>().As<{1}>();", dt.Rows[i]["name"] + "Repository", "I" + dt.Rows[i]["name"] + "Repository");}sb.Append(@"base.Load(builder);}}
}");return sb.ToString();
View Code

 

转载于:https://www.cnblogs.com/plming/p/8033720.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/368479.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CSS3扁平化Loading动画特效

效果预览&#xff1a;http://hovertree.com/texiao/css3/42/ 代码如下&#xff1a; <!doctype html><html><head><meta charset"utf-8"><title>css3旋转加载效果_何问起</title><style>body {background: #263238;backgro…

自定义Spring命名空间使JAXB更容易

首先&#xff0c;让我大声说出来&#xff1a; Spring不再是XML繁重的了 。 事实上&#xff0c;如今&#xff0c;您可以使用大量注释&#xff0c; Java配置和Spring Boot来编写几乎没有XML或根本没有XML的Spring应用程序。 认真地停止谈论Spring和XML&#xff0c;这已经成为过去…

sublime text3运行python不显示内容_sublime text 运行python无法出结果

一、python和sublime text 已经安装完毕。二、用sublime text运行python程序得时候出现三、配置Python环境1、打开Tools > Build System > New Build System..2、点击New Build System后&#xff0c;会生成一个空配置文件&#xff0c;在这个配置文件内覆盖配置信息&#…

利用锚点再点事吧丨

上图 接着HTML代码&#xff1a; <div id"color"> <div id"red">红</div> <div id"yellow">黄</div> <div id"black">黑</div> <div id"green">绿</div> </div>…

JavaScript变量声明与提升

一直以来对变量提升都是比较模糊的&#xff0c;今天特地看了一下这个知识点&#xff0c;总结一下。 1、举个最简单的例子来说一下什么是变量提升吧。  function foo(){console.log(x); // undefinedvar x 12;console.log(x) // 12 } foo(); 由于变量声明提升&#xff0c;其…

javaweb笔记1

转载于:https://www.cnblogs.com/webdev8888/p/9164291.html

重复运行JUnit测试而没有循环

最近&#xff0c;我遇到了一个问题&#xff0c;我不得不编写一种方法的测试&#xff0c;该方法需要计算在一定可能性范围内的随机分布值1 。 更准确地说&#xff0c;如果您假设签名看起来像 interface RandomRangeValueCalculator {long calculateRangeValue( long center, lo…

以太网数据帧的报尾封装字段是什么_16、90秒快速“读懂”数据包的封装、解封装...

数据转发过程概述数据包在相同网段内或不同网段之间转发所依据的原理基本一致。一、数据帧封装TCP封装(四层)当主机建立了到达目的地的TCP连接后&#xff0c;便开始对应用层数据进行封装。主机A会对待发送的应用数据首先执行加密和压缩等相关操作&#xff0c;之后进行传输层封装…

MVP模式在Android实际项目中的应用和优化

注&#xff1a;本文阅读需要对MVP模式有基本了解。 MVP模式已经出现有很长一段时间了&#xff0c;但是火起来是这两年的事情。 关于MVP的概览&#xff0c;介绍&#xff0c;乃至于教程&#xff0c;Demo&#xff0c;实例&#xff0c;网上都有很多&#xff0c;我也有一篇文章专门收…

将训练集构建成ImageNet模型

以下程序实现将训练集构建为ImageNet模型&#xff0c;训练集图片为56个民族 import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.PrintWriter;public class createTxt {public static void createClassInd(){//56个…

CSS基本知识(慕课网)

1、注释 注解&#xff1a;CSS中注释/*这里是注释的文字*/ HTML中注释<!--这里是注释的文字--> 2、外部式css样式&#xff0c;写在单独的一个文件中 注解&#xff1a; 外部式css样式(也可称为外联式)就是把css代码写一个单独的外部文件中&#xff0c;这个css样式文件以“…

JMS和Spring:有时很重要的小事情

JmsTemplate和DefaultMessageListenerContainer是用于访问JMS兼容MOM的Spring帮助器。 他们的主要目标是在JMS API之上形成一层&#xff0c;并处理诸如事务管理/消息确认之类的基础结构&#xff0c;并隐藏JMS API的某些重复和笨拙的部分&#xff08;保留在那里&#xff1a; JMS…

python 音速_webpack多页应用架构系列(十一):预打包Dll,实现webpack音速编译

前言上文说到我们利用webpack来打包一个可配置的bootstrap&#xff0c;但文末留下一个问题&#xff1a;由于bootstrap十分庞大&#xff0c;因此每次编译都要耗费大部分的时间在打包bootstrap这一块&#xff0c;而换来的仅仅是配置的便利&#xff0c;十分不划算。我也并非是故意…

whereis 命令

可以用来查看命令的路径&#xff0c;安装在哪里 whereis命令是定位可执行文件、源代码文件、帮助文件在文件系统中的位置 [rootsalt-server-192 a]# whereis mysql mysql: /usr/bin/mysql /usr/lib64/mysql /usr/share/mysql /usr/share/man/man1/mysql.1.gz 转载于:https://ww…

css实现3D立方体旋转特效

先来看运行后出来的效果 它是在不停运行的一个立方体 先来看html部分的代码 <div class"rect-wrap"> <!--舞台元素&#xff0c;设置perspective&#xff0c;让其子元素获得透视效果。--><div class"container"> <!-- 容器&#…

Eclipse中的Tomcat:6个流行的“如何”问题

学习新技术总是一个艰难的过程。 当您尝试学习将要相互交互的两种技术时&#xff0c;此过程将变得更加困难。 Tomcat和Eclipse是Java EE开发中最流行的先决条件。 因此&#xff0c;要成为一名专业的开发人员&#xff0c;您需要知道如何使用此对执行最需要的操作以及如何进行一些…

adc分辨率和精度的区别_科普 | 传感器的灵敏度、分辨率和精度三者之间有何区别?...

传感器作为一种检测装置&#xff0c;具有微型化、数字化、智能化、多功能化、系统化、网络化的特点。在现代工业生产尤其是自动化生产过程中&#xff0c;需要各种传感器来监视和控制生产过程中的各个参数&#xff0c;使设备工作在正常状态或最佳状态&#xff0c;并使产品达到最…

Node08 - 配置模板引擎 -(route)

1、配置模板引擎 &#xff08;01&#xff09;、输出什么东西        //view engine&#xff1a;视图模板引擎(以何种方式呈现给用户) > 指定输出html           server.set(view engine, html); &#xff08;02&#xff09;、模板文件放在哪 //views: 指定好…

for循环与foreach的区别

for循环与foreach的区别 foreach 依赖 IEnumerable. 第一次 var a in GetList() 时 调用 GetEnumerator 返回第一个对象 并 赋给a, 以后每次再执行 var a in GetList() 的时候 调用 MoveNext.直到循环结束. 期间GetList()方法只执行一次. 1 2 3 4 5 6 7 8 9 10 11 12 13 fo…

SVN 定时 更新代码 Demo

1. 涉及技术&#xff1a;Winservice: 用system身份后台跑&#xff1b; Quartz&#xff1a;定时任务&#xff1b; SVN 2. 思路&#xff1a;Quartz定时调用cmd 程序,执行SVN update 命令,整个程序寄宿在Winservice3. 步骤&#xff1a;1&#xff09;service 用local system账户安…