oracle 非法变量名,ORACLE中的参数问题。非法的变量名

出错代码:

string cmd = "insert into TB_QUESTION(QUESTION_ID,QUESTION_CONTENT) values('1121',test2)";

OracleParameter paras1 = new OracleParameter("test2", OracleType.Clob);

paras1.Value = richTextBox2.Rtf;

using (OracleConnection con = new OracleConnection(SQLDAL.OracleHelper.connectionString))

{

con.Open();

using (OracleCommand com = new OracleCommand())

{

com.Connection = con;

com.CommandText = cmd;

com.Parameters.Add(paras1);

com.ExecuteNonQuery();

}

}

try

{

//     int i = SQLDAL.OracleHelper.ExecuteSql(cmd, paras);

}

catch (Exception e1)

{

MessageBox.Show(e1.ToString());

}

报错非法的参数和变量名。

解决办法:

在SQL语句中ORACLE变量名称前需要加上:,但是在new OracleParameter时,ParameterName只能使用参数的字符部分

一般常见出现此类问题的原因

1、Oracle的更新不能出现Parameters顺序跟传来的参数顺序不一直的问题 2、字段名太长,有的地方说是要小于32个字符,但我使用,它还要比32小,大家只能尽量控制字段名的长度 3、虽然在Sql 语句中使用 冒号“:”代表参数,但在创建OracleParameter时,指定的参数名称不能使用冒号,在new OracleParameter时,ParameterName只能使用参数的字符部分

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值