Atitit.ati orm的设计and架构小结 适用于java c# php版
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Atitit.ati orm的设计and架构小结 适用于java c# php版,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3468字,纯文字阅读大概需要5分钟。
内容图文
![Atitit.ati orm的设计and架构小结 适用于java c# php版](/upload/InfoBanner/zyjiaocheng/226/7a2bc40ed2e345968b536579a11a590e.jpg)
Atitit.ati orm的设计and架构总结 适用于java c# php版
1. Orm的目标1
1.1. 动态obj1
1.2. Hb的api(meger,save,update,del)1
2. Orm的概念1
3. 动态obj2
4. 参考4
1. Orm的目标1.1. 动态obj
1.2. Hb的api(meger,save,update,del)
2. Orm的概念
saveOrUpdate后的对象会纳入session的管理,对象的状态会跟数据库同步,再次查询该对象会直接从session中取,merge后的对象不会纳入session的管理,再次查询该对象还是会从数据库中取。.
对于hibernate,它的对象有三种状态,transient、persistent、detached
下边是常见的翻译办法:
transient:瞬态或者自由态
persistent:持久化状态
detached:脱管状态或者游离态
脱管状态的实例可以通过调用save()、persist()或者saveOrUpdate()方法进行持久化。
persist和merge: 没有和数据库进行同步
save和update: 处理后的数据处于持久状态,换句话说,调用sql进行和数据库同步的步骤。
总的来说,对于长事务的处理,应该使用persist和merge。减少数据库交互
作者:: 老哇的爪子 Attilax 艾龙, EMAIL:[email protected]
转载请注明来源: http://blog.csdn.net/attilax
3. 动态obj
Proj.amazon .spider
public object hanlder(object obj, ClassLibrary1.com.attilax.lang.FilterFilterChain nextChain)
{
Dictionary<string, Object> ormObj = new Dictionary<string, object>();
ormObj.Add("table", "ecs_goods");
Dictionary<string, Object> flds_frm = (Dictionary<string, Object>)obj;
Dictionary<string, Object> flds = new Dictionary<string, object>();
flds.Add("goods_name", flds_frm["title"]);
flds.Add("goods_desc", "goods_descxxx");
// flds.Add("good_nam
ormObj.Add("fields", flds);
AtiOrmX ormx = (AtiOrmX)new IocX().getBean("ormx");
return ormx.save(ormObj);
}
-------code
public class AtiOrmX
{
public Ioc ioc;
public Object save(Object ormObj)
{
String sql = SqlX.getSql(ormObj);
Console.WriteLine("--orm sql:" + sql);
DbUtil dbx = (DbUtil)ioc.getBean("dbx");
return dbx.exec(sql);
}
}
public class SqlX
{
public static string getSql(object ormObj)
{
// throw new NotImplementedException();
Dictionary<String, Object> ormobjMap = ((Dictionary<String, Object>)ormObj) ;
Dictionary<String, Object> fldMap = (Dictionary<String, Object>)ormobjMap["fields"];
System.Collections.Generic.List<object> flds = new List<object>();
System.Collections.Generic.List<object> fld_vals = new List<object>();
foreach (var item in fldMap)
{
flds.Add(item.Key);
fld_vals.Add("'"+ item.Value+"'");
Console.WriteLine(item.Key + item.Value);
}
String fld_s = ListX.join(",", flds);
String v_s = ListX.join(",", fld_vals);
String sql = " insert into " + ormobjMap["table"] + "(@flds)values(@vs)";
sql = sql.Replace("@flds", fld_s); sql = sql.Replace("@vs", v_s);
return sql;
}
}
public class DbUtil
{
public Object exec(string sql)
{
MySqlConnection mysqlcon = this.getmysqlcon();
mysqlcon.Open();
MySqlCommand mysqlcom = new MySqlCommand(sql, mysqlcon);
int r = mysqlcom.ExecuteNonQuery();
mysqlcom.Dispose();
mysqlcon.Close();
mysqlcon.Dispose();
return r;
}
------ioc
facMap.Add("dbx", () =>
{<span style="background:rgb(255,255,255); col
内容总结
以上是互联网集市为您收集整理的Atitit.ati orm的设计and架构小结 适用于java c# php版全部内容,希望文章能够帮你解决Atitit.ati orm的设计and架构小结 适用于java c# php版所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。