Вызов строки подключения из файла connection.cs
Есть ли проблемы с кодом? Это не работает и выбрасывает объект исключения ref. не задано для экземпляра объекта. Исключение составляет файл datageneric.cs со строкой строки кода DbConnectionString = Connection.ConnectionString;
connection.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Configuration;
public static class Connection
{
private static string constr = "server=.;database=foood;";
public static string ConnectionString
{
get
{
return constr;
}
set
{
constr = value;
}
}
public static string ProviderName { get; set; }
static Connection()
{
ConnectionString =WebConfigurationManager.ConnectionStrings["constring"].ConnectionString;
ProviderName = WebConfigurationManager.ConnectionStrings["constring"].ProviderName;
}
}
DataGeneric.cs
public static DbCommand CreateCommand()
{
DbCommand cmd=null;
try
{
string DbConnectionString = Connection.ConnectionString;
string DbProviderName = Connection.ProviderName;
DbProviderFactory factory = DbProviderFactories.GetFactory(DbProviderName);
DbConnection conn = factory.CreateConnection();
conn.ConnectionString = DbConnectionString;
cmd = conn.CreateCommand();
cmd.CommandType = CommandType.Text;
}
catch (Exception ex) { }
return cmd;
}
GetData.cs
public static DataTable gimmedata()
{
string Query = "select * from [slider]";
DbCommand cmd = DataGeneric.CreateCommand();
cmd.CommandText = Query;
DataTable dt = DataGeneric.ExecuteSelectCommand(cmd);
return dt;
}
Default.aspx.cs
protected void Page_Load(object sender, EventArgs e)
{
DataTable dt = GetData.gimmedata();
GridView1.DataSource = dt;
GridView1.DataBind();
}
1 ответ
Ваш класс соединения public static
, Чтобы использовать его переменные, создайте его object
в DataGeneric.cs
а затем получить доступ к этому классу через этот объект.
Connection con = new Connection();
string DbConnectionString = con.ConnectionString;
Надеюсь, что это работает.