oracle插入字符串數據時字符串中有'單引號問題

使用insert into(field1,field2...) values('val1','val2'...)時,若值中有單引號時會報錯。

處理方法:判斷一下val1,val2中是否含有單引號,若含單引號,則將單引號'替換成兩個單引號''。

將字段與字段值組織到一個HashTable中,再抽象出一個組織sql語句的函數getSqlByHashTable():

     

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

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

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章