基于C#的自动拼接Sql语句思路

思路:

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

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

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

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

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

 1 private static Dictionary<string, string> GetDicKeyValue(Control controlBox)
 2         {
 3             //遍历容器获取控件的Name属性和Text属性,存放到键值中,用于以下的拼接sql
 4             Dictionary<string, string> dic = new Dictionary<string, string>();
 5             foreach (Control item in controlBox.Controls)
 6             {
 7                 if (item is Label || item is PictureBox)
 8                 {
 9                     continue;
10                 }
11                 if (item is TextBox)
12                 {
13                     dic.Add(item.Name.Substring(3, item.Name.Length - 3), item.Text.Trim());
14                     continue;
15                 }
16                 if (item is ComboBox)
17                 {
18                     dic.Add(item.Name.Substring(3, item.Name.Length - 3), item.Text);
19                     continue;
20                 }
21                 if (item is DateTimePicker)
22                 {
23                     dic.Add(item.Name.Substring(3, item.Name.Length - 3), item.Text);
24                     continue;
25                 }
26                 if (item is CheckBox)
27                 {
28                     string result = ((CheckBox)item).Checked ? "1" : "0";
29                     dic.Add(item.Name.Substring(3, item.Name.Length - 3), result);
30                     continue;
31                 }
32             }
33             return dic;
34         }

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

 1 private void button1_Click(object sender, EventArgs e)
 2         {
 3             Dictionary<string, string> dic = GetDicKeyValue(panel1);
 4             string autoMatchSql = string.Empty;
 5             StringBuilder Sb1 = new StringBuilder();
 6             StringBuilder Sb2 = new StringBuilder();
 7             foreach (KeyValuePair<string, string> item in dic)
 8             {
 9                 Sb1.Append(item.Key.Trim()).Append(",");
10                 Sb2.Append("‘").Append(item.Value.Trim()).Append("‘").Append(",");
11             }
12             autoMatchSql += "INSERT INTO 表名 ";
13             autoMatchSql += " (" + Sb1.ToString().Substring(0, Sb1.Length - 1) + ") VALUES ";
14             autoMatchSql += " (" + Sb2.ToString().Substring(0, Sb2.Length - 1) + ")";
15         }

原文地址:https://www.cnblogs.com/chenyanbin/p/10201465.html

时间: 2024-10-13 01:23:03

基于C#的自动拼接Sql语句思路的相关文章

SQL存储过程分页(通用的拼接SQL语句思路实现)

多表通用的SQL存储过程分页 USE [EmailCenter] GO /****** Object: StoredProcedure [dbo].[Common_PageList] Script Date: 2016/2/29 11:00:19 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE PROC [dbo].[Common_PageList] ( @tab nvarchar(200),---表名 @strFl

NO2:自动生成sql语句

SQL语句自动生成工具 大哉乾元 2016/2/26   作者原创转载请注明出处 前言 这个程序是几年前做成的,现在整理成文档和大家分享,当时参与的项目中大量使用的sql语句,所以SqL语句的代码输入占了较大的比例,为了提高sql语句的书写正确性和输入效率,做成了这个自动生成工具. 一:ADO.NET中执行sql文,对应的sql语句嵌入到vb.net的代码内,分析sql的语法格式个特点: 已检索语句为例分析: A:必须是已select开头 B:检索的字段名(一些系统函数:可选,例如max,sum

java用字符串拼接SQL语句的特殊字符转义问题

在实际的项目开发中,往往会根据用户在界面的文本框中输入的信息,去数据库中做模糊查询.如果使用的是原始的JDBC和SQL,往往需要对用户的输入进行转义,避免生成的sql语法错误,或者防止SQL注入.比如对输入的%和_和',就需要进行转义,因为这3个字符是SQL的特殊字符,如果不处理会导致sql出错或者是查询数据不正确. 假如有这样1个查询请求,模糊查询标题中包含a%b_cc'd的记录,正确的sql应该是下面这样的: select * from t_sch_work_info t where t.t

SQLSERVER 根据传入的参数拼接sql语句字符串,反馈结果集

ALTER PROCEDURE [dbo].[usp_visit_detail](@siteid BIGINT, @Startime VARCHAR(15), @Endtime  VARCHAR(15), @Aflag  INT = 10,                                    --初始值为10,非10,则表示有传入参数 @Area   VARCHAR(20) = 'N',               -- --初始值为N,非N,则表示有传入参数 @Nflag  

使用表达式避免拼接SQL语句

在SQL语句编写过程中,无论在存储过程中还是在程序中,有时为了使语句兼容全部情况与某字段的特殊情况,不得不拼接SQL字串 如下表 商品ID 类别ID 1 1 2 1 3 2 4 3 5 3 如果我们要写一个SQL,改SQL可通过类别ID获得该类别的商品ID,并且要求兼容传入类别ID为0时获得所有商品,我们不得不拼接SQL了 --@类别ID为传入的参数 DECLARE @Sql NVARCHAR(500) SET @Sql='SELECT * FROM 商品' IF(@类别ID!=0) SET @

sqlserver 存储过程中拼接sql语句 动态执行

ALTER PROC [dbo].[Student_Friend_Get] @startRowIndexId INT, @maxNumberRows INT, @schoolId INT, @gradeId INT, @cId INT, @keyWords NVARCHAR(100), @userName VARCHAR(50) AS BEGIN DECLARE @sqlfilter VARCHAR(max) SET @sqlfilter = ' ' IF(@schoolId <> -1) S

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

问题 在这里举一个例子,比如我要做一个多条件模糊查询,用户输入的时候有可能输入一个条件,也有可能输入两个条件,这时执行查询的sql语句就不确定了,但可以用动态拼接sql语句来解决这个问题. 解决方法 1.就拿我上面的那个多条件模糊查询为例,第一步是拼接sql语句,先定义一个通用的sql语句,String sql = "select * from user where 1 = 1 ";这里添加where 1= 1是一个小技巧,方便后面sql语句的拼接. String sql = &quo

关于拼接SQL语句sqlMap的使用方法

1.为什么使用? 主要还是为了代码中获取到值,然后带入SQL语句中拼接查询 2.怎么使用? 1)bean继承了BaseEntity类,该类中有 /** * 自定义SQL(SQL标识,SQL内容) */ protected Map<String, String> sqlMap; @JsonIgnore @XmlTransient public Map<String, String> getSqlMap() { if (sqlMap == null){ sqlMap = Maps.ne

动态拼接SQL语句

1.参考官方文档 ? if:字符判断 ? choose (when, otherwise):分支选择 ? trim (where, set):字符串截取:其中where标签封装查询条件,set标签封装修改条件 ? foreach 2.if案例 1)在EmployeeMapper接口中添加一个方法: //携带了哪个字段,查询条件就带上哪个字段的值 public List<Employee> getEmployeeByConditionIf(Employee employee); 2).如果要写下