重载的乐趣
菜鸟日记
一直感觉重载很舒服,但是这次是感受到它的冲击力了,想通的那刻爽的不得了。我这里头有两张对象表,两张分类表,相对应出现了四张关系表,一个关系类把他们都解决了,哈哈~这就是OO的魅力啊。
public class Relationship
{
DataClassesDataContext db;
public Relationship()
{
db = new DataClassesDataContext(Utils.cnn);
}
#region Add methods
public bool Add(oUrl url, tCategory category)
{
db.tUrlInCategory.InsertOnSubmit(new tUrlInCategory { Url_id = url.ID, Category_id = category.id });
db.SubmitChanges();
return true;
}
public bool Add(oUrl url, tDomain domain)
{
db.tUrlInDomain.InsertOnSubmit(new tUrlInDomain { Url_id = url.ID, Domain_id = domain.id });
db.SubmitChanges();
return true;
}
public bool Add(oPwd pwd, tCategory category)
{
db.tPwdInCategory.InsertOnSubmit(new tPwdInCategory { Pwd_id = pwd.id, Category_id = category.id });
db.SubmitChanges();
return true;
}
public bool Add(oPwd pwd, tDomain domain)
{
db.tPwdInDomain.InsertOnSubmit(new tPwdInDomain { Pwd_id = pwd.id, Domain_id = domain.id });
db.SubmitChanges();
return true;
}
#endregion
#region Get methods
public tUrlInCategory Get(oUrl url, tCategory category)
{
return (from c in UrlInCategory(url) where c.Category_id == category.id select c).First();
}
public tUrlInDomain Get(oUrl url, tDomain domain)
{
return (from c in UrlInDomain(url) where c.Domain_id == domain.id && c.Url_id == url.ID select c).First();
}
public tPwdInCategory Get(oPwd pwd, tCategory category)
{
return (from pc in db.tPwdInCategory where pc.tPwd.id == pwd.id && category.id == pc.tCategory.id select pc).First();
}
public tPwdInDomain Get(oPwd pwd, tDomain domain)
{
return (from pd in db.tPwdInDomain where pd.Domain_id == domain.id && pd.Pwd_id == pwd.id select pd).First();
}
public List<tUrlInCategory> UrlInCategory(oUrl url)
{
return (from c in db.tUrlInCategory where c.Url_id == url.ID select c).ToList();
}
public List<tUrlInDomain> UrlInDomain(oUrl url)
{
return (from c in db.tUrlInDomain where c.Domain_id == url.ID select c).ToList();
}
public List<tPwdInCategory> PwdInCategory(oPwd pwd)
{
return (from p in db.tPwdInCategory where p.tPwd.id == pwd.id select p).ToList();
}
public List<tPwdInDomain> pwdInDomain(oPwd pwd)
{
return (from p in db.tPwdInDomain where p.Pwd_id == pwd.id select p).ToList();
}
#endregion
#region Delete methods
public bool Delete(oUrl url, tCategory category)
{
db.tUrlInCategory.DeleteOnSubmit((Get(url, category)));
db.SubmitChanges();
return true;
}
public bool Delete(oUrl url, tDomain domain)
{
db.tUrlInDomain.DeleteOnSubmit(Get(url, domain));
db.SubmitChanges();
return true;
}
public bool Delete(oPwd pwd, tCategory category)
{
db.tPwdInCategory.DeleteOnSubmit(Get(pwd, category));
db.SubmitChanges();
return true;
}
public bool Delete(oPwd pwd, tDomain domain)
{
db.tPwdInDomain.DeleteOnSubmit (Get(pwd, domain));
db.SubmitChanges();
return true;
}
#endregion
}
作者:today4king
出处:https://www.cnblogs.com/jinzhao/archive/2008/12/13/1354306.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架