oracle插入字符串数据时字符串中有'单引号问题
使用insertinto(field1,field2...)values('val1','val2'...)时,若值中有单引号时会报错。
处理方法:判断一下val1,val2中是否含有单引号,若含单引号,则将单引号'替换成两个单引号''。
将字段与字段值组织到一个HashTable中,再抽象出一个组织sql语句的函数getSqlByHashTable():
HashTableht=newHashTable();
ht.add(field1,val1);
ht.add(field2,val2);
ht.add(field3,val3);
。。。
publicstringgetSqlByHashTable(stringtablename,HashTableht){
StringBuildersb=newStringBuilder();
sb.append("insertinto"+tablename+"(");
StringBuilderfsb=newStringBuilder();
StringBuildervsb=newStringBuilder();
foreach(varkeyinht.Keys)
{
fsb.append(key+",");
stringvalue=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(")");
returnsb.toString();
}
以上所述是小编给大家介绍的oracle插入字符串数据时字符串中有'单引号问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对毛票票网站的支持!