oracle插入字符串?dāng)?shù)據(jù)時字符串中有'單引號問題
使用insert into(field1,field2...) values('val1','val2'...)時,若值中有單引號時會報錯。
處理方法:判斷一下val1,val2中是否含有單引號,若含單引號,則將單引號'替換成兩個單引號''。
將字段與字段值組織到一個HashTable中,再抽象出一個組織sql語句的函數(shù)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插入字符串?dāng)?shù)據(jù)時字符串中有'單引號問題,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的,在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Oracle數(shù)據(jù)庫常用語句總結(jié)大全
SQL是結(jié)構(gòu)化查詢語言,用于管理關(guān)系型數(shù)據(jù)庫系統(tǒng),本指南涵蓋了創(chuàng)建和刪除數(shù)據(jù)庫、表以及其他高級表操作如增加、修改、刪除字段,還介紹了主鍵、索引、視圖操作和數(shù)據(jù)DML操作,需要的朋友可以參考下2024-09-09
Oracle導(dǎo)出文本文件的三種方法(spool,UTL_FILE,sqluldr2)
這篇文章主要介紹了Oracle導(dǎo)出文本文件的三種方法(spool,UTL_FILE,sqluldr2),需要的朋友可以參考下2023-05-05
Oracle用PLSQL導(dǎo)出導(dǎo)入dmp表詳細(xì)圖解
dmp是二進(jìn)制文件,可跨平臺還能包含權(quán)限,效率好,這篇文章主要給大家介紹了關(guān)于Oracle用PLSQL導(dǎo)出導(dǎo)入dmp表的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11

