1. 概述

  本章介绍 数据库、Json和Xml、web services 三种介质上的数据操作。

2. 主要内容

  2.1 数据库

    ① 建立连接

      .net平台中的数据连接类都继承自DbConnection。DbConnection实现了IDisposable接口。

using (SqlConnection connection = new SqlConnection(connectionString))
{
    connection.Open();
    // Execute operations against the database
} // Connection is automatically closed.

      使用ConnectionStringBuilder 可以构建连接字符串。但是把连接字符串放到配置文件中是更好的选择

var sqlConnectionStringBuilder = new SqlConnectionStringBuilder(); 

sqlConnectionStringBuilder.DataSource = @”(localdb)\v11.”;
sqlConnectionStringBuilder.InitialCatalog = “ProgrammingInCSharp”; string connectionString = sqlConnectionStringBuilder.ToString();

      .net平台使用连接池来优化数据库连接操作。

    ② 读取数据 : 可以使用async/await来异步操作。

public async Task SelectDataFromTable()
{
    string connectionString = ConfigurationManager.
ConnectionStrings[“ProgrammingInCSharpConnection”].ConnectionString;
  using (SqlConnection connection = new SqlConnection(connectionString))
  {
      SqlCommand command = new SqlCommand(“SELECT * FROM People”, connection);
      await connection.OpenAsync();
      SqlDataReader dataReader = await command.ExecuteReaderAsync();
      
      while (await dataReader.ReadAsync())
      {
          string formatStringWithMiddleName = “Person ({}) is named {} {} {}”;
          string formatStringWithoutMiddleName = “Person ({}) is named {} {}”;
          if ((dataReader[“middlename”] == null))
          {
              Console.WriteLine(formatStringWithoutMiddleName, 
                  dataReader[“id”], 
                  dataReader[“firstname”], 
                  dataReader[“lastname”]);
          }
          else
          {
              Console.WriteLine(formatStringWithMiddleName, 
                  dataReader[“id”], 
                  dataReader[“firstname”], 
                  dataReader[“middlename”], 
                  dataReader[“lastname”]);
          }
      }
dataReader.Close();
  }
}

      使用DataReader的NextResultAsync,可以处理多个结果集。

public async Task SelectMultipleResultSets()
{
    string connectionString = ConfigurationManager.
ConnectionStrings[“ProgrammingInCSharpConnection”].ConnectionString;     using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlCommand command = new SqlCommand(“SELECT * FROM People; 
SELECT TOP  * FROM People ORDER BY LastName”, connection);
        await connection.OpenAsync();
        SqlDataReader dataReader = await command.ExecuteReaderAsync();
        await ReadQueryResults(dataReader);
        await dataReader.NextResultAsync(); // Move to the next result set
        await ReadQueryResults(dataReader);
       dataReader.Close();
    }
}
private static async Task ReadQueryResults(SqlDataReader dataReader)
{
    while (await dataReader.ReadAsync())
    {
        string formatStringWithMiddleName = “Person ({}) is named {} {} {}”;
        string formatStringWithoutMiddleName = “Person ({}) is named {} {}”;
        if ((dataReader[“middlename”] == null))
        {
            Console.WriteLine(formatStringWithoutMiddleName,
                dataReader[“id”],
                dataReader[“firstname”],
                dataReader[“lastname”]);
        }
        else
        {
            Console.WriteLine(formatStringWithMiddleName,
                dataReader[“id”],
                dataReader[“firstname”],
                dataReader[“middlename”],
                dataReader[“lastname”]);
        }
    }
}

    ③ 更新数据

public async Task UpdateRows()
{
    string connectionString = ConfigurationManager.
        ConnectionStrings[“ProgrammingInCSharpConnection”].ConnectionString;
    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlCommand command = new SqlCommand(
            “UPDATE People SET FirstName=’John’”,
            connection);         await connection.OpenAsync();
        int numberOfUpdatedRows = await command.ExecuteNonQueryAsync();
        Console.WriteLine(“Updated {} rows”, numberOfUpdatedRows);
    }
}

    ④ 使用参数

public async Task InsertRowWithParameterizedQuery()
{
    string connectionString = ConfigurationManager.
        ConnectionStrings[“ProgrammingInCSharpConnection”].ConnectionString;     using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlCommand command = new SqlCommand(
            “INSERT INTO People([FirstName], [LastName], [MiddleName]) VALUES(@
firstName, @lastName, @middleName)”,
            connection);
        await connection.OpenAsync();
        
        command.Parameters.AddWithValue(“@firstName”, “John”);
        command.Parameters.AddWithValue(“@lastName”, “Doe”);
        command.Parameters.AddWithValue(“@middleName”, “Little”);         int numberOfInsertedRows = await command.ExecuteNonQueryAsync();
        Console.WriteLine(“Inserted {} rows”, numberOfInsertedRows);
    }
}

    ⑤ 使用事务

string connectionString = ConfigurationManager.
    ConnectionStrings[“ProgrammingInCSharpConnection”].ConnectionString;
using (TransactionScope transactionScope = new TransactionScope())
{
    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        connection.Open();         SqlCommand command1 = new SqlCommand(
            “INSERT INTO People ([FirstName], [LastName], [MiddleInitial])
VALUES(‘John’, ‘Doe’, null)”, 
            connection);
        SqlCommand command2 = new SqlCommand(
            “INSERT INTO People ([FirstName], [LastName], [MiddleInitial])
VALUES(‘Jane’, ‘Doe’, null)”, 
            connection);         command1.ExecuteNonQuery();
        command2.ExecuteNonQuery();
    }
    transactionScope.Complete();
}            

      *TransactionScope支持三种类型:Required, RequiresNew, Supress.

    ⑥ 使用 Object Relational Mapper(ORM)

      数据记录和表不符合面向对象的结构,手动写数据对象,创建和维护成本都很高。为了解决这个问题,出现了ORM。

      微软提供的ORM工具是 Entiry Framework(EF)。EF支持三种模式:数据库先行、模型先行、代码先行。

public class Person
{
    public int Id { get; set; }
    public string Name { get; set; }
} public class PeopleContext : DbContext
{
    public IDbSet<Person> People { get; set; }
} using (PeopleContext ctx = new PeopleContext())
{
    ctx.People.Add(new Person() { Id = , Name = “John Doe” });
    ctx.SaveChanges();
} using (PeopleContext ctx = new PeopleContext())
{
    Person person = ctx.People.SingleOrDefault(p => p.Id == );
    Console.WriteLine(person.Name);
}

  2.2 使用 web services

    创建一个Windows Comunication Service(WCF)服务

      WCF的ABC模型:

      ① Address:服务公开的终结点,实际调用的物理地址。

      ② Binding:配置了通信的协议和传输类型。

      ③ Contract:合约,定义了服务公开的操作。

  2.3 使用XML

    System.Xml下比较重要的类包括:

    ① XmlReader:速度较快

string xml = @”<?xml version=””1.0”” encoding=””utf-”” ?>
                <people>
                  <person firstname=””john”” lastname=””doe””>
                    <contactdetails>
                      <emailaddress>john@unknown.com</emailaddress>
                    </contactdetails>
                  </person>
                  <person firstname=””jane”” lastname=””doe””>
                    <contactdetails>
                      <emailaddress>jane@unknown.com</emailaddress>
                      <phonenumber></phonenumber>
                    </contactdetails>
                  </person>
                </people>”;
using (StringReader stringReader = new StringReader(xml))
{
    using (XmlReader xmlReader = XmlReader.Create(stringReader,
        new XmlReaderSettings() { IgnoreWhitespace = true }))
    {
        xmlReader.MoveToContent();
       xmlReader.ReadStartElement(“People”);         string firstName = xmlReader.GetAttribute(“firstName”);
        string lastName = xmlReader.GetAttribute(“lastName”);         Console.WriteLine(“Person: {} {}”, firstName, lastName);
        xmlReader.ReadStartElement(“Person”);         Console.WriteLine(“ContactDetails”);
        xmlReader.ReadStartElement(“ContactDetails”);
        string emailAddress = xmlReader.ReadString();         Console.WriteLine(“Email address: {}”, emailAddress);
    }
}

    ② XmlWriter:速度较快

StringWriter stream = new StringWriter(); 

using (XmlWriter writer = XmlWriter.Create(
    stream, 
    new XmlWriterSettings() { Indent = true }))
{
    writer.WriteStartDocument();
    writer.WriteStartElement(“People”);
    writer.WriteStartElement(“Person”);
    writer.WriteAttributeString(“firstName”, “John”);
    writer.WriteAttributeString(“lastName”, “Doe”);
    writer.WriteStartElement(“ContactDetails”);
    writer.WriteElementString(“EmailAddress”, “john@unknown.com”);
    writer.WriteEndElement();
    writer.WriteEndElement();
    writer.Flush();
}
Console.WriteLine(stream.ToString());

    ③ XmlDocument:灵活性高

XmlDocument doc = new XmlDocument(); 

doc.LoadXml(xml);
XmlNodeList nodes = doc.GetElementsByTagName(“Person”); // Output the names of the people in the document
foreach (XmlNode node in nodes)
{
    string firstName = node.Attributes[“firstName”].Value;
    string lastName = node.Attributes[“lastName”].Value;
    Console.WriteLine(“Name: {} {}”, firstName, lastName);
} // Start creating a new node
XmlNode newNode = doc.CreateNode(XmlNodeType.Element, “Person”, “”); XmlAttribute firstNameAttribute = doc.CreateAttribute(“firstName”);
firstNameAttribute.Value = “Foo”; XmlAttribute lastNameAttribute = doc.CreateAttribute(“lastName”);
lastNameAttribute.Value = “Bar”; newNode.Attributes.Append(firstNameAttribute);
newNode.Attributes.Append(lastNameAttribute); doc.DocumentElement.AppendChild(newNode);
Console.WriteLine(“Modified xml...”);
doc.Save(Console.Out); //Displays:
//Name: john doe
//Name: jane doe
//Modified xml...
//<?xml version=”1.0” encoding=”ibm850”?>
//<people>
// <person firstname=”john” lastname=”doe”>
// <contactdetails>
// <emailaddress>john@unknown.com</emailaddress>
// </contactdetails>
// </person>
// <person firstname=”jane” lastname=”doe”>
// <contactdetails>
// <emailaddress>jane@unknown.com</emailaddress>
// <phonenumber>001122334455</phonenumber>
// </contactdetails>
// </person>
// <person firstname=”Foo” lastname=”Bar” />
//</people>

      *XmlDocument实现了IXPathNavigable接口,可以使用XPathNavigator 对象遍历xml.

XmlDocument doc = new XmlDocument();
doc.LoadXml(xml); // Can be found in Listing 4-43 XPathNavigator nav = doc.CreateNavigator();
string query = “//People/Person[@firstName=’Jane’]”;
XPathNodeIterator iterator = nav.Select(query); Console.WriteLine(iterator.Count); // Displays 1 while(iterator.MoveNext())
{
    string firstName = iterator.Current.GetAttribute(“firstName”,””);
    string lastName = iterator.Current.GetAttribute(“lastName”,””);
    Console.WriteLine(“Name: {} {}”, firstName, lastName);
}

  2.4 使用Json

    可以使用第三方组件Newtonsoft.Json来处理Json数据。

3. 总结

  ① ADO.NET提供了provider模型来实现连接不同类型的数据源。

  ② 使用DbConnection对象来创建数据库连接。

  ③ 使用参数化的查询方式,可以避免sql注入。

  ④ 通过创建代理,可以使你的程序对外发布 web service 接口。

  ⑤ .net平台提供了处理Xml的相关类(XmlReader, XmlWriter, XPathNavigator, XmlDocument)。

  ⑥ 处理Json数据可以使用第三方的Newtonsoft.Json。

第十九章 数据访问(In .net4.5) 之 处理数据的更多相关文章

  1. “全栈2019”Java第六十九章:内部类访问外部类成员详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  2. 第十九章——使用资源调控器管理资源(1)——使用SQLServer Management Studio 配置资源调控器

    原文:第十九章--使用资源调控器管理资源(1)--使用SQLServer Management Studio 配置资源调控器 本系列包含: 1. 使用SQLServer Management Stud ...

  3. 第十九章 Django的ORM映射机制

    第十九章 Django的ORM映射机制 第一课 Django获取多个数据以及文件上传 1.获取多选的结果(checkbox,select/option)时: req.POST.getlist('fav ...

  4. Gradle 1.12用户指南翻译——第三十九章. IDEA 插件

    本文由CSDN博客万一博主翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  5. 【C++】《C++ Primer 》第十九章

    第十九章 特殊工具与技术 一.控制内存分配 1. 重载new和delete new表达式的工作机理: string *sp = new string("a value"); //分 ...

  6. Python之路【第十九章】:Django进阶

    Django路由规则 1.基于正则的URL 在templates目录下创建index.html.detail.html文件 <!DOCTYPE html> <html lang=&q ...

  7. Gradle 1.12用户指南翻译——第四十九章. Build Dashboard 插件

    本文由CSDN博客貌似掉线翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  8. Gradle 1.12翻译——第十九章. Gradle 守护进程

    有关其他已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或访问:http://gradledoc.qiniudn.com ...

  9. Gradle 1.12用户指南翻译——第二十九章. Checkstyle 插件

    其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Github上的地址: https://g ...

随机推荐

  1. [ CodeVS冲杯之路 ] P1165

    不充钱,你怎么AC? 题目:http://codevs.cn/problem/1165/ 题目很简单,代码最好写朴实一点,不要想着哪些情况可以合并在一起啊等等 老老实实一个个判断,不然很容易出错 细节 ...

  2. TFS客户端登录用户修改

    1.操作环境: Windows 10 Pro Visual Studio 2013 TFS客户端 2.操作背景 安装完成TFS系统后,使用administrator在客户端进行登陆测试(已勾选保存用户 ...

  3. OpenStack-Mitaka 一键安装测试环境脚本

    说明:这个脚本是采用Bash Shell编写,这个版本还只能作为测试环境搭建使用. 此脚本原形的发起人是网友:WuYuLiang.这里有他的博客链接:   第一版的链接: http://blog.cs ...

  4. 慕课网-安卓工程师初养成-4-9 Java循环语句之 for

    来源:http://www.imooc.com/code/1425 Java 的循环结构中除了 while 和 do...while 外,还有 for 循环,三种循环可以相互替换. 语法: 执行过程: ...

  5. 无法定位程序输入点ucrtbase.

    转:http://tieba.baidu.com/p/3848709732 后的解决方法是需要安装VC 2015 Redistributable,请自己选择相应的版本.百度云盘共享地址:http:// ...

  6. iOS copy&mutableCopy理解

    Copy&mutableCopy   通过copy方法可以创建可变或不可变对象的不可变副本,通过mutableCopy可以创建可变或不可变对象的可变副本. 拷贝分为浅拷贝和深拷贝: 浅拷贝:指 ...

  7. Java之注解

    package com.demo.test; import java.lang.annotation.Documented; import java.lang.annotation.ElementTy ...

  8. Dynamics AX 4.0 多表looup

    project rar:http://files.cnblogs.com/files/sxypeace/PrivateProject_MutilTableLookupOnCtronl.rar 在AX ...

  9. Delphi Form的释放和隐藏:free,hide,close

    form.Free   -   释放Form占用的所有资源.Free后,Form指针不能再使用,除非对Form重新赋值.   form.Hide   -   隐藏Form.可以调用form.Show再 ...

  10. 对于不是特别擅长Photoshop的人来说,熟悉和运用Photoshop工具提供的各类便捷的快捷键,是有帮助的。

    应用程序菜单快捷键之文件   应用程序菜单快捷键之编辑   应用程序菜单快捷键之图像图层   应用程序菜单快捷键   应用程序菜单快捷键之视图     Ctrl + H  取消参考线     调板菜单 ...