文本数据库ORM应用CodeFirst体验

简介:
还记得,旧旧前发布过一篇文章: 文本数据库--.Net界未来的一朵奇葩 引爆超过百条的评论,说明大伙对文本数据库,还是情有所属的。
经过多年的沉淀,在文本的操作上,已经有了些规模,因此,本文写出来和大伙分享一下。
 
一:Code First 开始:
 
2:解压就一个dll,项目添加引用即可。
3:既然是Code First,那我们就直接写实体类,示例如下:
    public class Users : CYQ.Data.Orm.OrmBase
    {
        public Users()
        {
            this.SetInit(this, "Users", "Txt Path={0}");
        }
        public int ID {get;set;}
        public string UserName {get;set;}
        public string Password {get;set;}
    }
 
说明两个点:
1,继承自OrmBase;
2,构造函数里指定表名“Users”和数据库链接(Txt Path={0})。
 
数据库链接说明({0}代表根目录):
文本数据库(json存储方式):Txt Path={0}
Xml数据库(xml存储方式) :Xml Path={0}
其它数据库,就是各数据库的链接了或配置项了。
 
OK,现在就可以实操增删改查了,下面轻轻的讲一下。
 
二:Code First 代码实例
 
1:插入与更新代码和图如下:
 
代码说明:
左侧是增加和更新的代码,右侧是一简单的示例操作winform界面,这里有两重点说明。

1:为啥实体类要用using包含操作?
对于文本的操作,内部机制是在内存操作的,直到调用Disponse,才写到文本,因此,用using就是为了结束时调用Disponse写到文件去的。
2:SetAutoParentControl是什么东东?
当控件名按约束起名:为3字母+属性名,如txtUserName,txtPassword时,可以采用自动取值法,
这样你拉N个控件上去,代码也不用改变的。
传进this就是form本身,orm会遍历form下的控件进行取值。
 
2:对于其它Orm功能,暂不详写了,下载里有api文档说明,这里仅列出接口:
 /// <summary>
    /// 数据操作公共接口
    /// </summary>
    /// <typeparam name="T"></typeparam>
    internal interface ICommon:IDisposable
    {
        bool Insert();
        bool Insert(InsertOp option);
        bool Insert(bool autoSetValue);
        bool Insert(bool autoSetValue, InsertOp option);
        

        bool Update();
        bool Update(object where);
        bool Update(object where, bool autoSetValue);
        bool Delete();
        bool Delete(object where);
     
        bool Fill(object where);
        MDataTable Select();
        MDataTable Select(string where);
        MDataTable Select(int topN, object where);
        MDataTable Select(int pageIndex, int pageSize, string where, out int count);
        int GetCount(string where);
        bool Exists(string where);
        #region UI接口
        void GetFrom(object control);
        void GetFrom(object control, object value);
        bool GetFromJson(string jsonOrFileName);
        void SetAutoParentControl(object parent, params object[] otherParent);
        void SetAutoPrefix(string autoPrefix, params string[] otherPrefix);
        void SetSelectColumns(params object[] columnNames);
        void SetTo(object control);
        void SetTo(object control, object value, bool isControlEnabled);
        void SetTo(object control, object value);
        void SetToAll(params object[] parentControls);
        #endregion
        string TableName { get; set; }
        string DebugInfo { get; }
    }
 
三:基础说明解答
 
1:表从哪来、数据存哪?
系统在初始化时,会根据表名和链接的地址,会根据属性名称自动生成相应的表结构在地址目录,并且以json或xml方式存储数据。
 
2:where支持sql?
支持的,不过对于txt,xml,内置实现了最基础的sql解析,可以满足>,>=,<,<=,=, is  null, is not  null,like,order by 等基本本询,不支持的有:函数,或group by等语句。
 
3:实用场景
 
有时候,数据并不大,用access太纠心,用sqlite服务器安全设置又不允许,用mssql又觉得杀牛不用牛刀,那txt,xml就该出手了。
场景一:比如一简单的配置文件,你写个实体类,就可以轻松的操作了,不用建啥数据库表 。
场景二:Code First的目的,当你需要快速构建代码时,直接就用txt就上了,然后业务代码就可以开始写了,不用等DBA建完库。
后期可根据需要,修改web.config的链接转到mssql,mysql,oracle等数据库,业务代码不变的哟。
当然了, this.SetInit( this" Users "" Conn ");应该这么写,对应webconfig的Conn配置项。
场景三:对于wp7开发,直接操作txt,还是很合理的。
 
 
4:多数据库兼容性
用过 
  CYQ.Data的朋友都知道,支持多数据库是非常轻松过度的,现在你玩txt,轻松换下链接就到mssql等其它数据库了,所以玩好一个,其它数据库同样是兼容的。


感兴趣的朋友,可以玩一玩,过过Code First的瘾!!!




     本文转自cyq1162 51CTO博客,原文链接:http://blog.51cto.com/cyq1162/894380
,如需转载请自行联系原作者





相关文章
|
12天前
|
SQL 关系型数据库 MySQL
探索Gorm - Golang流行的数据库ORM框架
探索Gorm - Golang流行的数据库ORM框架
|
25天前
|
存储 安全 搜索推荐
酒店管理系统的数据库的应用以及选择
酒店管理系统数据库关乎运营效率和服务质量。数据库用于数据存储、管理、分析及客户关系管理,确保房态与预订精准。选择时重视性能稳定性、数据安全、易用性、可扩展性和成本效益。合适的数据库能提升酒店运营效率并优化客户体验。
25 2
|
25天前
|
存储 Oracle 搜索推荐
电子商务中数据库的应用以及选择
【4月更文挑战第10天】电子商务依赖数据库进行数据存储与管理,涵盖产品信息、订单、用户数据。数据库支持数据分析,揭示市场趋势,助力企业决策。在客户关系管理中,数据库帮助理解客户行为,实现个性化服务。订单处理也离不开数据库,确保操作准确高效。数据库系统如MySQL、Oracle满足不同业务需求,选择时要考虑性能、规模及管理特性。合适的数据库对电商业务的性能和稳定性至关重要。
33 4
|
5天前
|
存储 运维 Kubernetes
多态关联在数据库设计中的应用和解决方案
多态关联在数据库设计中的应用和解决方案
15 0
|
7天前
|
存储 算法 数据库
矢量数据库在图像识别与检索中的应用实践
【4月更文挑战第30天】本文探讨了矢量数据库在图像识别与检索中的应用,通过特征提取(如SIFT、SURF)、编码和相似度度量实现快速识别。在图像检索流程中,经过预处理、特征提取和编码后,矢量数据库用于查询相似特征,排序后展示给用户。实际案例显示,矢量数据库能提升电商平台的商品图像搜索效率和用户体验。随着技术发展,这一领域应用前景广阔。
|
7天前
|
机器学习/深度学习 搜索推荐 数据库
矢量数据库的未来发展趋势:新技术与应用展望
【4月更文挑战第30天】随着AI和机器学习的发展,矢量数据库在处理非结构化数据方面的重要性日益增强。预测到2028年,全球矢量数据库市场将从2023年的15亿美元增长至43亿美元。未来趋势包括:并行计算与分布式架构提升处理能力,硬件加速技术(如TPU和昇腾芯片)提高性能,自适应索引机制优化查询效率。应用领域将拓展至NLP、图像视频分析和推荐系统,为各行业带来更多创新和价值。
|
7天前
|
机器学习/深度学习 存储 人工智能
矢量数据库在机器学习领域的应用与前景
【4月更文挑战第30天】本文探讨了矢量数据库在机器学习领域的应用,包括特征存储、相似性搜索、模型训练与调优及实时分析。随着AI技术发展,矢量数据库将深度融合,提升扩展性和可伸缩性,增强智能化功能,并加强安全性与隐私保护。未来,矢量数据库将在机器学习领域扮演关键角色。
|
7天前
|
存储 数据可视化 关系型数据库
矢量数据库在地理空间数据处理中的应用
【4月更文挑战第30天】矢量数据库在地理空间数据处理中展现优势,高效存储管理高维向量数据,支持快速查询、空间分析与可视化。分布式处理能力适应大数据量需求,提供高效、灵活、可扩展及可视化支持,是处理地理空间数据的理想选择。随着技术进步,其应用将更加广泛。
|
8天前
|
API 数据库 Python
Python web框架fastapi数据库操作ORM(二)增删改查逻辑实现方法
Python web框架fastapi数据库操作ORM(二)增删改查逻辑实现方法
|
8天前
|
关系型数据库 MySQL API
Python web框架fastapi数据库操作ORM(一)
Python web框架fastapi数据库操作ORM(一)