很久没有更新blog了。这几天在研究一个开源电子商务源码NopCommerce。
先来一张工程的图案片把
data:image/s3,"s3://crabby-images/272d9/272d91519f9e27a229bf912c1ce313624d8c8d6a" alt=""
基于3层的结构。所以很好理解。
用到了2个实体层。一个在DataAccess里,于数据库字段一一对应。还有一个在Common里,与业务相关的实体类。这2个实体层之间的互传在DataAccessSql里实现的。
下面是税率的源码:
public class DBTaxByCountry : BaseDBEntity
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
{
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
public DBTaxByCountry()
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
}
#endregion
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Properties#region Properties
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//// <summary>
/// Gets or sets the TaxByCountry identifier
/// </summary>
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int TaxByCountryID
{ get; set; }
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//// <summary>
/// Gets or sets the tax category identifier
/// </summary>
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int TaxCategoryID
{ get; set; }
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//// <summary>
/// Gets or sets the country identifier
/// </summary>
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int CountryID
{ get; set; }
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//// <summary>
/// Gets or sets the percentage
/// </summary>
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public decimal Percentage
{ get; set; }
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
#endregion
}
public abstract class DBTaxByCountryProvider : ProviderBase
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
{
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Fields#region Fields
private static bool s_Initialized;
private static Exception s_InitializeException;
private static object s_lock;
private static DBTaxByCountryProvider s_Provider;
private static DBTaxByCountryProviderCollection s_Providers;
#endregion
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Ctor#region Ctor
static DBTaxByCountryProvider()
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
s_lock = new object();
s_Initialized = false;
s_InitializeException = null;
}
#endregion
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Methods#region Methods
public abstract void DeleteTaxByCountry(int TaxByCountryID);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public abstract DBTaxByCountry GetByTaxByCountryID(int TaxByCountryID);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public abstract DBTaxByCountryCollection GetAllByCountryID(int CountryID);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public abstract DBTaxByCountry InsertTaxByCountry(int TaxCategoryID, int CountryID, decimal Percentage);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public abstract DBTaxByCountry UpdateTaxByCountry(int TaxByCountryID, int TaxCategoryID, int CountryID, decimal Percentage);
#endregion
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Utilities#region Utilities
private static DBTaxByCountryProviderSection GetSection()
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
return (DBTaxByCountryProviderSection)ConfigurationManager.GetSection("nopDataProviders/TaxByCountryProvider");
}
private static void Initialize()
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
if (s_Initialized)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
if (s_InitializeException != null)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
throw s_InitializeException;
}
}
else
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
if (s_InitializeException != null)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
throw s_InitializeException;
}
lock (s_lock)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
if (s_Initialized)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
if (s_InitializeException != null)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
throw s_InitializeException;
}
}
else
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
try
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
DBTaxByCountryProviderSection section = GetSection();
if (((section.DefaultProvider == null) || (section.Providers == null)) || (section.Providers.Count < 1))
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
throw new ProviderException("Default provider not specified");
}
s_Providers = new DBTaxByCountryProviderCollection();
if (HostingEnvironment.IsHosted)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
ProvidersHelper.InstantiateProviders(section.Providers, s_Providers, typeof(DBTaxByCountryProvider));
}
else
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
foreach (ProviderSettings settings in section.Providers)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
Type c = Type.GetType(settings.Type, true, true);
if (!typeof(DBTaxByCountryProvider).IsAssignableFrom(c))
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
throw new ArgumentException(string.Format("Provider must implement {0} type", new object[]
{ typeof(DBTaxByCountryProvider).ToString() }));
}
DBTaxByCountryProvider provider = (DBTaxByCountryProvider)Activator.CreateInstance(c);
NameValueCollection parameters = settings.Parameters;
NameValueCollection config = new NameValueCollection(parameters.Count, StringComparer.Ordinal);
foreach (string str2 in parameters)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
config[str2] = parameters[str2];
}
provider.Initialize(settings.Name, config);
s_Providers.Add(provider);
}
}
s_Provider = s_Providers[section.DefaultProvider];
if (s_Provider == null)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
throw new ConfigurationErrorsException(string.Format("Default provider not found. {0}. Line number: {1}", section.ElementInformation.Properties["defaultProvider"].Source, section.ElementInformation.Properties["defaultProvider"].LineNumber));
}
s_Providers.SetReadOnly();
}
catch (Exception exception)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
s_InitializeException = exception;
throw;
}
s_Initialized = true;
}
}
}
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
#endregion
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Properties#region Properties
public static DBTaxByCountryProvider Provider
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
get
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
Initialize();
return s_Provider;
}
}
public static DBTaxByCountryProviderCollection Providers
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
get
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
Initialize();
return s_Providers;
}
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
#endregion
}
public class SQLTaxByCountryProvider : DBTaxByCountryProvider
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
{
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Fields#region Fields
private string _sqlConnectionString;
#endregion
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Utilities#region Utilities
private DBTaxByCountry GetTaxByCountryFromReader(IDataReader dataReader)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
DBTaxByCountry taxByCountry = new DBTaxByCountry();
taxByCountry.TaxByCountryID = NopSqlDataHelper.GetInt(dataReader, "TaxByCountryID");
taxByCountry.TaxCategoryID = NopSqlDataHelper.GetInt(dataReader, "TaxCategoryID");
taxByCountry.CountryID = NopSqlDataHelper.GetInt(dataReader, "CountryID");
taxByCountry.Percentage = NopSqlDataHelper.GetDecimal(dataReader, "Percentage");
return taxByCountry;
}
#endregion
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
Methods#region Methods
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public override void Initialize(string name, NameValueCollection config)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
if (config == null)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
throw new ArgumentNullException("config");
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
base.Initialize(name, config);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
string connectionStringName = config["connectionStringName"];
if (String.IsNullOrEmpty(connectionStringName))
throw new ProviderException("Connection name not specified");
this._sqlConnectionString = NopSqlDataHelper.GetConnectionString(connectionStringName);
if ((this._sqlConnectionString == null) || (this._sqlConnectionString.Length < 1))
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
throw new ProviderException(string.Format("Connection string not found. {0}", connectionStringName));
}
config.Remove("connectionStringName");
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
if (config.Count > 0)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
string key = config.GetKey(0);
if (!string.IsNullOrEmpty(key))
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
throw new ProviderException(string.Format("Provider unrecognized attribute. {0}", new object[]
{ key }));
}
}
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public override void DeleteTaxByCountry(int TaxByCountryID)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
Database db = NopSqlDataHelper.CreateConnection(_sqlConnectionString);
DbCommand dbCommand = db.GetStoredProcCommand("Nop_TaxByCountryDelete");
db.AddInParameter(dbCommand, "TaxByCountryID", DbType.Int32, TaxByCountryID);
int retValue = db.ExecuteNonQuery(dbCommand);
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public override DBTaxByCountry GetByTaxByCountryID(int TaxByCountryID)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
DBTaxByCountry taxByCountry = null;
if (TaxByCountryID == 0)
return taxByCountry;
Database db = NopSqlDataHelper.CreateConnection(_sqlConnectionString);
DbCommand dbCommand = db.GetStoredProcCommand("Nop_TaxByCountryLoadByPrimaryKey");
db.AddInParameter(dbCommand, "TaxByCountryID", DbType.Int32, TaxByCountryID);
using (IDataReader dataReader = db.ExecuteReader(dbCommand))
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
if (dataReader.Read())
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
taxByCountry = GetTaxByCountryFromReader(dataReader);
}
}
return taxByCountry;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public override DBTaxByCountryCollection GetAllByCountryID(int CountryID)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
DBTaxByCountryCollection taxByCountryCollection = new DBTaxByCountryCollection();
if (CountryID == 0)
return taxByCountryCollection;
Database db = NopSqlDataHelper.CreateConnection(_sqlConnectionString);
DbCommand dbCommand = db.GetStoredProcCommand("Nop_TaxByCountryLoadAllByCountryID");
db.AddInParameter(dbCommand, "CountryID", DbType.Int32, CountryID);
using (IDataReader dataReader = db.ExecuteReader(dbCommand))
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
while (dataReader.Read())
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
DBTaxByCountry taxByCountry = GetTaxByCountryFromReader(dataReader);
taxByCountryCollection.Add(taxByCountry);
}
}
return taxByCountryCollection;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public override DBTaxByCountry InsertTaxByCountry(int TaxCategoryID, int CountryID, decimal Percentage)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
DBTaxByCountry taxByCountry = null;
Database db = NopSqlDataHelper.CreateConnection(_sqlConnectionString);
DbCommand dbCommand = db.GetStoredProcCommand("Nop_TaxByCountryInsert");
db.AddOutParameter(dbCommand, "TaxByCountryID", DbType.Int32, 0);
db.AddInParameter(dbCommand, "TaxCategoryID", DbType.Int32, TaxCategoryID);
db.AddInParameter(dbCommand, "CountryID", DbType.Int32, CountryID);
db.AddInParameter(dbCommand, "Percentage", DbType.Decimal, Percentage);
if (db.ExecuteNonQuery(dbCommand) > 0)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
int TaxByCountryID = Convert.ToInt32(db.GetParameterValue(dbCommand, "@TaxByCountryID"));
taxByCountry = GetByTaxByCountryID(TaxByCountryID);
}
return taxByCountry;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
public override DBTaxByCountry UpdateTaxByCountry(int TaxByCountryID, int TaxCategoryID, int CountryID, decimal Percentage)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
DBTaxByCountry taxByCountry = null;
Database db = NopSqlDataHelper.CreateConnection(_sqlConnectionString);
DbCommand dbCommand = db.GetStoredProcCommand("Nop_TaxByCountryUpdate");
db.AddInParameter(dbCommand, "TaxByCountryID", DbType.Int32, TaxByCountryID);
db.AddInParameter(dbCommand, "TaxCategoryID", DbType.Int32, TaxCategoryID);
db.AddInParameter(dbCommand, "CountryID", DbType.Int32, CountryID);
db.AddInParameter(dbCommand, "Percentage", DbType.Decimal, Percentage);
if (db.ExecuteNonQuery(dbCommand) > 0)
taxByCountry = GetByTaxByCountryID(TaxByCountryID);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
return taxByCountry;
}
#endregion
}
也没用来什么让人特别感兴趣的技术。
例子用到了provider模式,主要目的在于为税率
进行定义和实现分离。
下一篇就用LINQ改写它的客户资料数据访问层。其实主要是为了学习LINQ的。