解析用SQL Server处理物料清单规则_Mssql数据库教程
推荐:解析SQL Server 2000视图问题视图的好处,它可以横纵分割表,在视图上的可以执行与在表上一至的操作,如:Insert、Update、Delete。这些操作与在表上的相应操作大至相同,不过也有些不同之处。在视图上进行操作的列是只属于视图的列,这些列不一定包含对应表中的所有列,所以在执行Inser
你可以通过执行两个计数来解决这个问题。第一个计数简单的计算每一个食谱需要的原料;第二个计数先将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 2000触发器本文从定义入手仔仔细细的来讲解如何制定自己的触发器。 创建一个简单的触发器 触发器是一种特殊的存储过程,类似于事件函数,SQL Server? 允许为 INSERT、UPDATE、DELETE 创建触发器,即当在表中插入、更新、删除记录时,触发一个或一系列 T-SQL语句。 触发
- sql 语句练习与答案
- 深入C++ string.find()函数的用法总结
- SQL Server中删除重复数据的几个方法
- sql删除重复数据的详细方法
- SQL SERVER 2000安装教程图文详解
- 使用sql server management studio 2008 无法查看数据库,提示 无法为该请求检索数据 错误916解决方法
- SQLServer日志清空语句(sql2000,sql2005,sql2008)
- Sql Server 2008完全卸载方法(其他版本类似)
- sql server 2008 不允许保存更改,您所做的更改要求删除并重新创建以下表
- SQL Server 2008 清空删除日志文件(瞬间日志变几M)
- Win7系统安装MySQL5.5.21图解教程
- 将DataTable作为存储过程参数的用法实例详解
- 相关链接:
- 教程说明:
Mssql数据库教程-解析用SQL Server处理物料清单规则。