asp.net Oracle 之Insert 与 Update 更新封闭代码
.net oracle 之insert 与 update 更新封闭代码
觉得我可以从的更新方法下手,于是有了下面这些尝试了。
在oracle 中insert 语句是可以使用 returning 返回新增的记录的。
于是我们的insert 语句就是这样了.
insert into tablename (uniquecolumn,othercolumns)
values(table_seq.nextval,values) returning uniquecolumn into :unique_id。
这样执行之后,我就可以通过out参数 unique_id 获取新增的记录的主键啦
public override object insert(editorparams pm)
{
if (pm != null && pm.editvalues.count > 0)
{
querysetting qs = configenginer.instance.datamodels[pm.modeltype];
string insertformart = @"insert into #oysterval:tablename# (#oysterval:uniquecolumn#,#oysterval:columns#)
values(#oysterval:tablename#_seq.nextval,#oysterval:values#) returning #oysterval:uniquecolumn# into :unique_id";dictionary
vals = new dictionary ();
listparms = new list (); vals.add("tablename", qs.tablename);
vals.add("uniquecolumn", qs.uniquecolumn.columnname);
vals.add("columns", pm.insertcolumns);
vals.add("values", pm.insertvalues);//system.nullable
var unqtype = qs.uniquecolumn.propertytype;
if (unqtype.fullname.contains("system.nullable"))
{
var types = unqtype.getgenericarguments();
if (types != null && types.length > 0)
{
unqtype = types[0];
}
}var pr = new oracleparameter(":unique_id", activator.createinstance(unqtype));
pr.direction = parameterdirection.inputoutput;
parms.add(pr);
parms.addrange(pm.dataparms);string sql = insertformart.tooystertemplate(vals);
pm.effectcount = dbenginer.instance.executenonquery(sql, parms.toarray());
pm.effectuniqueids.add(pr.value);
return pm.effectuniqueids[0];
}
else
{
throw new exception("请检查传入的editparams,更新列数据不能为空!");
}return null;
}
里面使用到的其他类型引用,以后会慢慢分享。
而update 则可以这样: uniquecolumn from tablename where condition for update。
将要更新的行select 出来,并且加上update 的锁。保证update按顺序执行,而不会错乱

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

OOBELANGUAGE錯誤Windows 11 / 10修復中出現問題的問題
