思路:

  1、想想插入语句,大概是这样的一个框架:INSERT INTO 表名 (数据库列名) values (值)

  2、这里要3个变量是不固定的,分别是:表名、数据库列名、值;

    a.表名我们这里很容易可以获取到

    b.数据库列名,我们可以遍历容器获取控件的Name属性

    c.值,我们可以遍历容器获取控件的Text属性

 private static Dictionary<string, string> GetDicKeyValue(Control controlBox)
{
//遍历容器获取控件的Name属性和Text属性,存放到键值中,用于以下的拼接sql
Dictionary<string, string> dic = new Dictionary<string, string>();
foreach (Control item in controlBox.Controls)
{
if (item is Label || item is PictureBox)
{
continue;
}
if (item is TextBox)
{
dic.Add(item.Name.Substring(, item.Name.Length - ), item.Text.Trim());
continue;
}
if (item is ComboBox)
{
dic.Add(item.Name.Substring(, item.Name.Length - ), item.Text);
continue;
}
if (item is DateTimePicker)
{
dic.Add(item.Name.Substring(, item.Name.Length - ), item.Text);
continue;
}
if (item is CheckBox)
{
string result = ((CheckBox)item).Checked ? "" : "";
dic.Add(item.Name.Substring(, item.Name.Length - ), result);
continue;
}
}
return dic;
}

好了,我们通过上面一个函数已经获取到控件的Name属性(即数据库列名)和Text属性(即值),下面开始组装Sql语句

 private void button1_Click(object sender, EventArgs e)
{
Dictionary<string, string> dic = GetDicKeyValue(panel1);
string autoMatchSql = string.Empty;
StringBuilder Sb1 = new StringBuilder();
StringBuilder Sb2 = new StringBuilder();
foreach (KeyValuePair<string, string> item in dic)
{
Sb1.Append(item.Key.Trim()).Append(",");
Sb2.Append("'").Append(item.Value.Trim()).Append("'").Append(",");
}
autoMatchSql += "INSERT INTO 表名 ";
autoMatchSql += " (" + Sb1.ToString().Substring(, Sb1.Length - ) + ") VALUES ";
autoMatchSql += " (" + Sb2.ToString().Substring(, Sb2.Length - ) + ")";
}

C#的自动拼接Sql语句Insert方法及思路的更多相关文章

  1. StringBuilder 拼接sql语句比较快

    StringBuilder 拼接sql语句比较快StringBuilder strBuilder = new StringBuilder();strSql += "insert into t ...

  2. sql语句判断方法之一

    sql语句判断方法之一CASE语句用法总结 背景: Case具有两种格式.简单Case函数和Case搜索函数. --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN ' ...

  3. ASP.NET实现列表页连接查询 拼接sql语句 绑定grivdView

    ASP.NET实现列表页连接查询 拼接sql语句 如图效果: 基本需求:1.当页面第一次加载的时候默认查询一个月时间(或者说是登陆者所属权限的所有数据)的数据绑定到gridView 2.添加查询条件时 ...

  4. thinkPHP框架中执行原生SQL语句的方法

    这篇文章主要介绍了thinkPHP框架中执行原生SQL语句的方法,结合实例形式分析了thinkPHP中执行原生SQL语句的相关操作技巧,并简单分析了query与execute方法的使用区别,需要的朋友 ...

  5. java动态拼接sql语句并且执行时给sql语句的参数赋值

    问题 在这里举一个例子,比如我要做一个多条件模糊查询,用户输入的时候有可能输入一个条件,也有可能输入两个条件,这时执行查询的sql语句就不确定了,但可以用动态拼接sql语句来解决这个问题. 解决方法 ...

  6. EFCore执行Sql语句的方法:FromSql与ExecuteSqlCommand

    前言 在EFCore中执行Sql语句的方法为:FromSql与ExecuteSqlCommand:在EF6中的为SqlQuery与ExecuteSqlCommand,而FromSql和SqlQuery ...

  7. 如何自动拼接 Update语句,仅Update已修改的字段

    我们通常使用update语句更新数据库记录,例如使用update user set username='001', nickname='Tom', age=18 where id = 1语句更新use ...

  8. 查询拼接SQL语句,多条件模糊查询

    多条件查询,使用StringBuilder拼接SQL语句,效果如下: 当点击按钮时代码如下: private void button1_Click(object sender, EventArgs e ...

  9. 查看 Laravel 的 SQL 语句的方法

    在使用 Laravel 的 Eloquent 进行数据查询的时候,很多小伙伴都想看到背后执行的 SQL 语句到底是什么样的,这小笔录就是解决这个小问题的: 在 Providers/AppService ...

随机推荐

  1. python网络-多进程(21)

    一.什么是进程 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础.在早期面向进程设计的计算机结构中,进程是程序的基本执行实 ...

  2. ECMAScript 6 学习(一)generator函数

    1.ES2017标准引入async函数,那么async函数到底是个什么函数呢? async 是一个generator函数的语法糖. 2.那么generator函数到底是什么函数ne? generato ...

  3. 『玩具装箱TOY 斜率优化DP』

    玩具装箱TOY(HNOI2008) Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊 ...

  4. [开源]快速构建一个WebApi项目

    项目代码:MasterChief.DotNet.ProjectTemplate.WebApi 示例代码:https://github.com/YanZhiwei/MasterChief.Project ...

  5. Python:机器学习三剑客之 NumPy

    一.numpy简介 Numpy是高性能科学计算和数据分析的基础包,机器学习三剑客之一.Numpy库中最核心的部分是ndarray 对象,它封装了同构数据类型的n维数组.部分功能如下: ndarray, ...

  6. 基于 Zookeeper 的分布式锁实现

    1. 背景 最近在学习 Zookeeper,在刚开始接触 Zookeeper 的时候,完全不知道 Zookeeper 有什么用.且很多资料都是将 Zookeeper 描述成一个“类 Unix/Linu ...

  7. 【ASP.NET Core快速入门】(四)在CentOS上安装.NET Core运行时、部署到CentOS

    下载.NET Core SDK 下载地址:https://www.microsoft.com/net/download/windows 第一步:Add the dotnet product feed( ...

  8. Docker系列03—Docker 基础入门

    本文收录在容器技术学习系列文章总目录 1.概念介绍 1.1 容器 1.1.1 介绍 容纳其它物品的工具,可以部分或完全封闭,被用于容纳.储存.运输物品.物体可以被放置在容器中,而容器则可以保护内容物. ...

  9. javascript基础修炼(4)——UMD规范的代码推演

    javascript基础修炼(4)--UMD规范的代码推演 1. UMD规范 地址:https://github.com/umdjs/umd UMD规范,就是所有规范里长得最丑的那个,没有之一!!!它 ...

  10. 【转】什么是.Net以及.Net的基本语法

    什么是.Net? 1. 通常意义所说的.net有5个组成部分,但最主要的部分是.NET Framework, .NET Framework实际上是运行在Windows操作系统的一个应用程序,一个可供二 ...