当前位置:Gxlcms > 数据库问题 > oracle插入字符串数据时,字符串中有'单引号

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

时间:2021-07-01 10:21:17 帮助过:96人阅读

使用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();

}

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

标签:value   sql语句   插入字符串   append   app   字符   build   判断   tab   

人气教程排行