我对petshop4的简单理解![通俗易懂]

我对petshop4的简单理解![通俗易懂]petshop4充分体现了面向接口编程的思想,就是给你一个接口你别管我是怎么实现的,你只管用别说其他的。namespacePetShop.BLL{   ///   ///Abusinesscomponenttomanageproducts   ///   publicclassProduct{       //Getaninstan

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

petshop4充分体现了面向接口编程的思想,就是给你一个接口你别管我是怎么实现的,你只管用别说其他的。

namespace PetShop.BLL {

    /// <summary>     /// A business component to manage products     /// </summary>     public class Product {

        // Get an instance of the Product DAL using the DALFactory         // Making this static will cache the DAL instance after the initial load         private static readonly IProduct dal = PetShop.DALFactory.DataAccess.CreateProduct();

在bll层,这里使用创建Produce的接口,你只管调用他的方法。

namespace PetShop.IDAL{    /// <summary>  /// Interface for the Product DAL  /// </summary>  public interface IProduct{     /// <summary>   /// Method to search products by category name   /// </summary>   /// <param name=”category”>Name of the category to search by</param>         /// <returns>Interface to Model Collection Generic of search results</returns>   IList<ProductInfo> GetProductsByCategory(string category); 

  /// <summary>   /// Method to search products by a set of keyword   /// </summary>   /// <param name=”keywords”>An array of keywords to search by</param>   /// <returns>Interface to Model Collection Generic of search results</returns>         IList<ProductInfo> GetProductsBySearch(string[] keywords);

  /// <summary>   /// Query for a product   /// </summary>   /// <param name=”productId”>Product Id</param>   /// <returns>Interface to Model ProductInfo for requested product</returns>   ProductInfo GetProduct(string productId);  }

这里是定义了Product接口和他的虚方法。

namespace PetShop.SQLServerDAL {

    public class Product : IProduct {

        //Static constants         private const string SQL_SELECT_PRODUCTS_BY_CATEGORY = “SELECT Product.ProductId, Product.Name, Product.Descn, Product.Image, Product.CategoryId FROM Product WHERE Product.CategoryId = @Category”;         private const string SQL_SELECT_PRODUCTS_BY_SEARCH1 = “SELECT ProductId, Name, Descn, Product.Image, Product.CategoryId FROM Product WHERE ((“;         private const string SQL_SELECT_PRODUCTS_BY_SEARCH2 = “LOWER(Name) LIKE ‘%’ + {0} + ‘%’ OR LOWER(CategoryId) LIKE ‘%’ + {0} + ‘%'”;         private const string SQL_SELECT_PRODUCTS_BY_SEARCH3 = “) OR (“;         private const string SQL_SELECT_PRODUCTS_BY_SEARCH4 = “))”;         private const string SQL_SELECT_PRODUCT = “SELECT Product.ProductId, Product.Name, Product.Descn, Product.Image, Product.CategoryId FROM Product WHERE Product.ProductId  = @ProductId”;         private const string PARM_CATEGORY = “@Category”;         private const string PARM_KEYWORD = “@Keyword”;         private const string PARM_PRODUCTID = “@ProductId”;

        /// <summary>         /// Query for products by category         /// </summary>         /// <param name=”category”>category name</param>          /// <returns>A Generic List of ProductInfo</returns>         public IList<ProductInfo> GetProductsByCategory(string category) {

            IList<ProductInfo> productsByCategory = new List<ProductInfo>();

这里是实现Product接口的类,

namespace PetShop.DALFactory {

    /// <summary>     /// This class is implemented following the Abstract Factory pattern to create the DAL implementation     /// specified from the configuration file     /// </summary>     public sealed class DataAccess {

        // Look up the DAL implementation we should be using         private static readonly string path = ConfigurationManager.AppSettings[“WebDAL”];         private static readonly string orderPath = ConfigurationManager.AppSettings[“OrdersDAL”];                 private DataAccess() { }

        public static PetShop.IDAL.ICategory CreateCategory() {             string className = path + “.Category”;             return (PetShop.IDAL.ICategory)Assembly.Load(path).CreateInstance(className);         }

这里是利用工厂模式来映射你需要你想创建哪一个。

后面还有一些消息队列MSMQMessage利用cache缓存以后达到异步处理购物车里订单的功能!

刚开始看应先从先从Product入口,关于Product的一些操作串联起来看一遍!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/183808.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SqlTransaction 类[通俗易懂]

    SqlTransaction 类[通俗易懂](事务详解)SqlTransaction类表示要在SQLServer数据库中处理的Transact-SQL事务。应用程序通过在SqlConnection对象上调用BeginTransaction来创建SqlTransaction对象。对SqlTransaction对象执行与该事务关联的所有后续操作(例如提交或中止该事务)。注意在提交或回滚SqlTran

    2022年6月10日
    31
  • centos8.2内核版本_centos发行版本和内核版本

    centos8.2内核版本_centos发行版本和内核版本文章目录1.查看当前内核版本2.使用ELRepo仓库3.安装最新版内核4.设置以新的内核启动5.生成grub配置文件并重启系统6.验证新内核7.查看系统中已安装的内核8.删除旧内核9.参考文献1.查看当前内核版本使用的系统版本,当前日期CentOS最新版:1$cat/etc/redhat-release2CentOSLinuxrelease8.2.2004(Co…

    2022年8月23日
    16
  • bzero简介[通俗易懂]

    bzero简介[通俗易懂]bzero简介 头文件:#include<string.h>bzero()会将内存块(字符串)的前n个字节清零,其原型为:voidbzero(void*s,intn);【参数】s为内存(字符串)指针,n为需要清零的字节数。bzero()会将参数s所指的内存区域前n个字节,全部设为零值。实际上,bzero(v…

    2022年10月13日
    3
  • 华为OD(外包)社招技术二面,总结复盘

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:沉夢志昂丶 blog.csdn.net/GOLOJO/article/details/105689366 一、…

    2021年6月26日
    124
  • CubieBoard 简单入门

    CubieBoard 简单入门大约一个月之前折腾的部分记录,当时没有完全完成,就着手其他事情了,这是存在LiveWriter中的草稿,先发出来吧,后来花了一段时间移植Qt,一直遇到了点问题,并没有完全跑通,后续估计也没有时间再继

    2022年7月4日
    23
  • C++ Template 基础篇(一):函数模板[通俗易懂]

    C++Template基础篇(一):函数模板Template所代表的泛型编程是C++语言中的重要的组成部分,我将通过几篇blog对这半年以来的学习做一个系统的总结,本文是基础篇的第一部分。CTemplate基础篇一函数模板为什么要有泛型编程函数模板定义普通函数模板成员函数模板为什么成员函数模板不能是虚函数virtual实参推断如何使用当返回值类型也是参数时实参推断时的自动类

    2022年4月16日
    60

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号