• oracle插入字符串数据时,字符串中有'单引号


    使用insert into(field1,field2...) values('val1','val2'...)时,若值中有单引号时会报错。

    处理方法:判断一下val1,val2中是否含有单引号,若含单引号,则将单引号'替换成两个单引号''。

    将字段与字段值组织到一个HashTable中,再抽象出一个组织sql语句的函数getSqlByHashTable():

    HashTable ht =new HashTable();
    ht.add(field1,val1);
    ht.add(field2,val2); 
    ht.add(field3,val3);
    。。。

      

    public string getSqlByHashTable(string tablename,HashTable ht){
       StringBuilder sb=new StringBuilder();
      sb.append("insert into "+tablename+"(");
      StringBuilder fsb=new StringBuilder();
      StringBuilder vsb=new StringBuilder();
      foreach(var key in ht.Keys)
      {
         fsb.append(key+",");
        string value=ht[key];
        if(value.trim()=="")
        {
          value="";
        }
        else
        {
          if(value.Contains("'"))
          {
            value=value.replace("'","''");
          }
          value="'"+value+"'";
        }
         vsb.append(value+",");
      }
      sb.append(fsb.toString().Substring(0,fsb.toString().length-1));
      sb.append(") values(");
      sb.append(vsb.toString().Substring(0,vsb.toString().length-1));
      sb.append(")");
      return sb.toString();
    
    }
    

    若对您有用,请赞助个棒棒糖~

  • 相关阅读:
    数论笔记
    微积分笔记
    洛谷P3835 【模板】可持久化平衡树
    洛谷P3385 【模板】负环
    洛谷 P3379 【模板】最近公共祖先(LCA)
    洛谷P3386 【模板】二分图匹配
    洛谷P3388 【模板】割点(割顶)
    洛谷P3373 【模板】线段树 2
    洛谷P3372 【模板】线段树 1
    Linux(CentOS 6.5) 下安装MySql 5.7.18 二进制版本粗浅攻略
  • 原文地址:https://www.cnblogs.com/shurun/p/6696478.html
Copyright © 2020-2023  润新知