访问Access数据库(有多个数据库时 体现多态)

Posted 叶祖辉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了访问Access数据库(有多个数据库时 体现多态)相关的知识,希望对你有一定的参考价值。

如果想编写单机版MIS、小型网站等对数据库性能要求不高的系统,又不想安装SQLServer,可以使用Access(MDAC),只要一个mdb文件就可以了。
使用Access创建mdb文件,建表。
OleDbConnection、OleDbCommand……,用法和SqlServer差不多。和SQLServer的区别:
一些复杂的SQL函数、语法Access不支持。
参数化查询不使用@name占位符,而是使用?,new OleDbParameter("?", guid.ToString(),要按照SQL语句中?的顺序添加OleDbParameter。
name和password都是保留字,最好不要用做列名,用的话加上[]

技术分享
    string str = ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;
    string pName = ConfigurationManager.ConnectionStrings["connstr"].ProviderName;

    IDbConnection conn;
    if (pName == "SQLServer")
    {
      conn = new SqlConnection(str);
    }
    else if (pName == "Access")
    {
      conn = new OleDbConnection(str);
    }
    else
    {
      MessageBox.Show("无效的ProviderName!");
      return;
    }

    using (conn)    // 体现多态 ,谁也不知道conn是SQL的还是Access的
    {
      if (conn.State == ConnectionState.Closed)
      {
        conn.Open();
      }
    
      using (IDbCommand cmd = conn.CreateCommand())
      {
        cmd.CommandText = "Insert into T_Person(Name,Age) Values(‘" + txtName.Text + "‘," + Convert.ToInt32(txtAge.Text) + ")";
        if (Convert.ToInt32(cmd.ExecuteNonQuery()) > 0)
        {
          MessageBox.Show("增加成功!");
        }
      }
    }
技术分享

 






以上是关于访问Access数据库(有多个数据库时 体现多态)的主要内容,如果未能解决你的问题,请参考以下文章

十面向对象之多态

复用类即多态性的体现

python面向对象的三大特征--多态

java----基础(this,继承,多态,抽象类,接口)

多 态★★★★★(面向对象特征之三)

Java基础知识点总结