码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2017-04-12 03:21:46      阅读:238      评论:0      收藏:0      [点我收藏+]

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

使用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   

原文地址:http://www.cnblogs.com/shurun/p/6696478.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!