IT猫扑网:您身边最放心的安全下载站! 最新更新| 软件分类| 专题汇总| 手机版

您当前所在位置:IT猫扑网 > 数据库 > MSSQL > 实例解析用SQL Server处理物料清单规则

实例解析用SQL Server处理物料清单规则

时间:2015-06-28 00:00 来源:IT猫扑网|http://www.itmop.com/ 作者:网管联盟 我要评论(0)

你可以通过执行两个计数来解决这个问题。第一个计数简单的计算每一个食谱需要的原料;第二个计数先将RecipeIngredients表与Ingredients表连接起来,再计数。从食品室中取出任何所需要的原料后都要降低这个计数,再通过比较这个计数,你就能拒绝那些你不能得到所有原料的食谱,也可以接受符合条件的食谱。我在Listing A 中提供了一个例子。(Listing A中的数据库比我们现在讨论的复杂一点点,它有一些查询表和一些没有提到的列。)

既然有两个计数(需要的和可得到的),那么我们必须对它们进行简单的比较。我一般采取原子对分子查询,所以我将每一条声明都保留在视图中(IngredientsAvailable_By_Recipe_vue 和IngredientsRequired_By_Recipe_vue)。然后,我用RecipeID字段做连接条件创建了第三个视图,增加了一个条件那就是可得到的(Available)必须等于需要的(Required)。为了使这个列表更吸引人,我把Recipes表也加到里面去了,所以我能获得食谱的名字。你可以查看Listing B。你也可以去掉这个逻辑来查看食谱,你可以将WHERE语句的条件改成Required > Available,但这样并不会简化操作。

ListingA:

/* count the ingredients required */SELECT

[Recipe Ingredients].RecipeID,

Count([Recipe Ingredients].IngredientID) AS RequiredFROM

[Recipe Ingredients]GROUP BY

[Recipe Ingredients].RecipeID;

/* count the ingredients available */SELECT

[Recipe Ingredients].RecipeID,

Count(Pantry.IngredientID) AS AvailableFROM Pantry

RIGHT JOIN [Recipe Ingredients]

ON Pantry.IngredientID

= [Recipe Ingredients].IngredientIDGROUP BY

[Recipe Ingredients].RecipeID;

ListingB:

SELECT

IngredientsRequired_by_Recipe_qs.RecipeID,

Recipes.RecipeNameFROM

(IngredientsAvailable_By_Recipe_qs

INNER JOIN IngredientsRequired_by_Recipe_qs

ON IngredientsAvailable_By_Recipe_qs.RecipeID = IngredientsRequired_by_Recipe_qs.RecipeID)

INNER JOIN Recipes

ON IngredientsRequired_by_Recipe_qs.RecipeID

= Recipes.RecipeIDWHERE (([Available]>=[Required]));

按照早期的规定,我假定在食品室中出现的任意数量都表示这种原料是充足的。在RecipeIngredients表中需要一个Quantity列,在Pantry表中也需要一个Quantity列。(这样会使例子变得更复杂;例如,我买了盐,它的单位磅还是千克,食谱要求的一勺是大勺还是小勺呢?)

如果你有Quantity这个列的话,一个新的挑战出现了:如果你想请朋友们吃午餐的话,你的菜单中用到了鳄梨酱、墨西哥沙拉和啤酒。现在的任务是比较需要的品种与食品室中现有的品种,然后再创建一个需要购买的清单。我把这问题留给感兴趣的读者去实现。

注意:你也可以先下载一个.NET executable程序,然后再创建数据库,并在数据库中创建你感兴趣的对象,包括表中的数据。你需要安装了.NET和sql server 2005才能执行这些代码。这个程序是一个winrar文件,但是里面是.NET executable。代码可以通过Red Gate Software的SQL Packager来创建,但是你不需要Red Gate就可以运行。(T006)

关键词标签:SQL Server

相关阅读 sql server系统表损坏的解决方法 SQL Server asp.net 数据提供程序连接池 SqlServer2005对现有数据进行分区具体步骤 一个Access数据库数据传递的实例方法 为导入文件加上时间戳标记的两种方法 SQL Server 2005 在不允许远程连接的情况下的破解

文章评论
发表评论

热门文章 sql server系统表损坏的解决方法 sql server系统表损坏的解决方法 SqlServer2005对现有数据进行分区具体步骤 SqlServer2005对现有数据进行分区具体步骤 解决SQL Server中Group无法实现的问题 解决SQL Server中Group无法实现的问题 SQL Server 2005降级到2000的正确操作步骤 SQL Server 2005降级到2000的正确操作步骤 手把手教你学会SQL Server镜像操作 手把手教你学会SQL Server镜像操作 实战手记:让百万级数据瞬间导入SQL Server 实战手记:让百万级数据瞬间导入SQL Server

相关下载

人气排行 配置和注册ODBC数据源-odbc数据源配置教程 如何远程备份(还原)SQL2000数据库 SQL2000数据库远程导入(导出)数据 SQL2000和SQL2005数据库服务端口查看或修改 修改Sql Server唯一约束教程 SQL Server 2005降级到2000的正确操作步骤 sql server系统表损坏的解决方法 浅谈JSP JDBC来连接SQL Server 2005的方法 SQL Server创建表语句介绍 MS-SQL2005服务器登录名、角色、数据库用户、角色、架构的关系 如何使用SQL Server中的客户端配置工具 SQL Server 分布式查询:OLE DB连接(一)