ADO.Net——扩展属性和配置文件应用

Posted 这都不是事

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ADO.Net——扩展属性和配置文件应用相关的知识,希望对你有一定的参考价值。

一、扩展属性

处理:有外键关系时将代号化信息处理成原始文字,让用户可看懂的(粗略解释)

利用扩展属性

如:Info表中的民族列显示的是民族代号处理成Nation表中的民族名称

      需要在Info类里面扩展一个显示nation名称的属性

代码显示:

第一步:在NationDA里面构造一个代号换成名称的方法

 

public string NationName(string code)
        {
            _cmd.CommandText = "select Name from Nation where Code=@code";
            _cmd.Parameters.AddWithValue("@code",code);

            _conn.Open();
            _dr = _cmd.ExecuteReader();


            if (_dr.HasRows)
            {
                _dr.Read();
                return _dr[0].ToString();
            }
            else
            {
                return "汉族";
            }

            _conn.Close();

        }

 

第二步:

public class Info
    { 
        //扩展的名族名称属性
        public string NationName
        {
            get {
                NationDA da = new NationDA();
                return da.NationName(this.nation);//this关键字,该对象里面是不是有一个nation
            }
        }

二、配置文件(App.config)

换台电脑、数据库名不同时,为了让别的用户也可以运行,把数据连接写在配置文件中,方便修改

例:

App.config中:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
  //key 配置名称
  <appSettings>
    <add key="connstring" value="server=.;database=mydb;user=sa;pwd=123"/>
  </appSettings>
</configuration>

数据连接类中:

public class DBConnect
    {
        private static string connstring = System.Configuration.ConfigurationSettings.AppSettings["connstring"];
        
        public static SqlConnection Conn
        {
            get {
                return new SqlConnection(connstring);
            }
        }
    }

低版本可以用该方法,高版本可以根据提示更改:

用户修改方式:

首先找到如图第二个文件:

然后,用记事本打开修改即可。

 

以上是关于ADO.Net——扩展属性和配置文件应用的主要内容,如果未能解决你的问题,请参考以下文章

ADO.NET 提供程序“Oracle.ManagedDataAccess.Client”未在计算机或应用程序配置文件中注册,或者无法加载

具有不变名称“MySql.Data.MySqlClient”的 ADO.NET 提供程序未在机器或应用程序配置文件中注册

ADO.NET - Size 属性的大小为 0 无效

扩展ADO.net实现对象化CRUD(.net core/framework)

如何为 SQL Server 和 SQL Server Compact 编写相同的 ado.net 代码?

ado.net 和 dapper 之间的交集/联合是啥?