一步一步教你使用AgileEAS.NET基础类库进行应用开发-基础篇-使用UDA操纵SQL语句

       上一篇文章基于AgileEAS.NET平台基础类库进行应用开发-总体说明及数据定义中对本案例所涉及的数据表及部分数据,本文开始将从最基本的业务,数据访问--SQL语句操纵开始。

       在AgileEAS.NET平台中,对数据访问进行了封装,称为UDA(统一数据访问),有关于AgileEAS.NET平台UDA的介绍请参考AgileEAS.NET之统一数据访问一文。

       在UDA中定义两个接口IDataConnection和IDataAccessor两个接口,IDataConnection提供了数据连接环境IDataAccessor提供了进行SQL语句操作的能力。

处理流程

       如果使用UDA进行数据库操作呢,请看下面的流程:

       我们转换程序代码即为:

    public void FullFlow()
    {
        string dbConnectiong = "";
        IDataConnection dataConnection = new OleDbConnection(dbConnectiong);
        IDataAccessor dataAccessor = dataConnection.CreateDataAccessor();

        dataConnection.Open();
        try
        {
            //Do ... 
        }
        finally
        {
            dataConnection.Close();
        }
    }

       IDataConnection对象内置了自动管理连接打开与关闭的功能,上功的流程刚可以简化为:

数据操作方法:

       IDataAccessor提供了Query和Execute两个不同重载的方法,Query用于实现数据查询业务,Execute用于实现操作更新修改业务,基于Query方法衍生了QueryScalar、QueryDataReader、QueryDataSet、QueryDataTable、QueryDictionary、QueryList说法,每一个衍生方法都对应于Query重载的某一种返回类型,在UDA中数据分别以Oject、IDataReader、DataSet、DataTable、IDictionary、IList返回,这里面有两个特殊的返回结果IDictionary、IList,IDictionary用于返回一条查询记录的键值对(字段名/字段值)、IList用于返回查询记录的第一列的值。Execute没有什么特殊的了。

案例介绍:

       本文附带的例子演示UDA业务中除事务处理之后的业务,针对每个数据操作说法,我都写一个具体的例子方法,下面我贴上Main方法代码:

    static void Main(string[] args)
    {
        System.Console.WriteLine("AgileEAS.NET平台UDA组件使用例子,按任务键开始...");
        System.Console.Read();
        System.Console.WriteLine("使用IDataReader的例子:");
        new UdaQuery().DemeGetDataReader();

        System.Console.WriteLine("按任务键开始...");
        System.Console.Read();
        System.Console.WriteLine("使用IDataSet的例子:");
        new UdaQuery().DemeGetDataSet();

        System.Console.WriteLine("按任务键开始...");
        System.Console.Read();
        System.Console.WriteLine("使用IDataTable的例子:");
        new UdaQuery().DemeGetDataTable();

        System.Console.WriteLine("按任务键开始...");
        System.Console.Read();
        System.Console.WriteLine("使用Dictionary的例子:");
        new UdaQuery().DemeGetDictionary();

        System.Console.WriteLine("按任务键开始...");
        System.Console.Read();
        System.Console.WriteLine("使用List的例子:");
        new UdaQuery().DemeGetList();

        System.Console.WriteLine("按任务键开始...");
        System.Console.Read();
        System.Console.WriteLine("使用Scalar的例子:");
        new UdaQuery().DemeGetScalar();

        System.Console.WriteLine("按任务键开始...");
        System.Console.Read();
        System.Console.WriteLine("数据更新的例子:");
        new UdaExecute().DemeExecute();

        System.Console.WriteLine("按任务键结束。");
        System.Console.Read();
    }

    其他参考请参考源码的UdaQuery和UdaExecute两个类,例子运行效果如下:

           本文例子就到这,在下文我将介绍AgileEAS.NET平台中的UDA的高级应用DataReader委托和事务委托。

          有关本例子所涉及的数据表结构请参考基于AgileEAS.NET平台基础类库进行应用开发-总体说明及数据定义一文,有关数据对象模型定义文件、文档、DDL脚本请下载:http://files.cnblogs.com/eastjade/demo.db.doc.sql.rar,本文代码下载:UDA.Demo1.rar

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏草根专栏

使用两种方法让 ASP.NET Core 实现遵循 HATEOAS 结构的 RESTful API

HATEOAS(Hypermedia as the engine of application state)是 REST 架构风格中最复杂的约束,也是构建成熟 ...

588110
来自专栏岑玉海

C#向excel中写入数据的三种方式

第一种:将DataGrid中的数据以流的形式写到excel中,格式以html的形式存在             Response.Clear();       ...

32440
来自专栏GreenLeaves

C#核编之System.Environment类

      在前面的例子中用来了Environment.GetCommandLineArgs()这个方法,这个方法就是获取用户的命令行输入,是Environme...

25970
来自专栏智能大石头

老瓶装新酒 - C#调用WM手机发送短信(源码)

一些系统,需要能够发送短信,量很小,平均每日10条。 运营商平台太贵,白名单很严格,小额只能发省内; 各短信平台有各种限制,大事件前后会关闭; 飞信以前可以用W...

25050
来自专栏跟着阿笨一起玩NET

Linq to XML 读取XML 备忘笔记

本文转载:http://www.cnblogs.com/infozero/archive/2010/07/13/1776383.html

10100
来自专栏圣杰的专栏

Parallel线程安全问题

废话不多说,上代码: using System; using System.Collections.Generic; using System.Threadin...

33050
来自专栏blackheart的专栏

[C#6] 8-异常增强

0. 目录 C#6 新增特性目录 1. 在catch和finally块中使用await 在C#5中引入一对关键字await/async,用来支持新的异步编程模型...

20650
来自专栏博客园

使用异步操作时的注意要点(翻译)

在使用异步方法中最好不要使用void当做返回值,无返回值也应使用Task作为返回值,因为使用void作为返回值具有以下缺点

13720
来自专栏草根专栏

用VSCode开发一个基于asp.net core 2.0/sql server linux(docker)/ng5/bs4的项目(3)

由于本文主要是讲VSCode开发等, 所以相关等一些angular/.net core的知识就相对少讲点. 我把需求改一下, 如图: ? 由于efcore目前还...

39290
来自专栏jessetalks

由浅入深表达式树(完结篇)重磅打造 Linq To 博客园

  一个多月之后,由浅入深表达式系列的最后一篇终于要问世了。想对所有关注的朋友说声:“对不起,我来晚了!” 希望最后一篇的内容对得起这一个月时间的等待。在学习完...

46460

扫码关注云+社区

领取腾讯云代金券