Nuva 示例代码(每日一帖)之 模板示例(2)
2006-09-05 09:24
477 查看
<..======================================================== == == == Macrobject Nuva Samples == == == == Copyright (c) 2004-2006 Macrobject Software == == == == ALL RIGHTS RESERVED == == == == http://www.macrobject.com == == == ========================================================..> --------------------------------------------------------------------------- -- Drop constraints --------------------------------------------------------------------------- <.foreach(T = System.Data.DefaultSchema.Tables | T.IsEnabled).> <.foreach(P = T.ParentRelations | P.IsEnabled).> ALTER TABLE [dbo].[<.=T.Name.>] DROP CONSTRAINT [<.=P.Name.>] GO <./foreach.> <./foreach.> --------------------------------------------------------------------------- -- Drop tables --------------------------------------------------------------------------- <.foreach(T = System.Data.DefaultSchema.Tables | T.IsEnabled).> DROP TABLE [dbo].[<.=T.Name.>] GO <./foreach.>
<..
【简介】
本例是一个真正的模板,来自于 Macrobject CodeAuto (http://www.macrobject.com/cn/codeauto/index.htm) 附带的模板(位于 Templates\Microsoft SQL Server Scripts 的 DropTables.sql.nuva)。
本例的模板将能够生成数据库的删除表的 SQL 脚本(本例应用于 MS SQL Server)。
【看点】
1、本例的第一个循环就是循环默认的数据库表:System.Data.DefaultSchema.Tables
System.Data.DefaultSchema.Tables 等同于上例的 System.Tables,System.Tables 是其简便的写法,都是提供一个默认的数据库表集合,通过一个与示例程序文件名相同的 cfg 文件可以配置如何读取这样的表集合。
本例中我们的 "模板示例.cfg" 内容如下:
-xD:\Nuva-Samples\Northwind.xobject
-x 参数指定一个 XObject 架构文件,通过该架构文件可以读取相应的数据架构信息。
XObject 文件可以通过 Macrobject CodeAuto 从数据库提取(http://www.macrobject.com/cn/codeauto/index.htm)。也可以通过 Nuva 程序直接从数据库读取,将在以后演示。
cfg 文件中的参数可以在通过 Nuva 虚拟机执行时放入命令行作为其参数。
System.Tables 返回一个 ObjectSet 对象,该对象是一个 DataObject 的集合,具体可以参考 <<Nuva API>> 的 System.Data 的信息。
这里的集合内每一个对象都是 TableObject 对象(DataObject 子类),具体的属性包括在上面的示例代码中。(还有些以后再演示介绍)
上面这些介绍内容与上例相同。
2、foreach 的 | 后面的表达式是一个过滤表达式,只有符合这个表达式的枚举项才执行 foreach 内的代码。(本例中过滤 Enabled 不为 true 的项)
里面的循环是 TableObject.ParentRelations,表示该表的所有父关系。
这儿生成的 SQL 采用 ALTER 表的方式删除外键约束,其中 P.Name 是关系名称。
【扩展】
本例可以进一步扩展以增强其实用性,比如可以改为支持 Oracle、DB2 等。
..>
本例运行结果如下:
---------------------------------------------------------------------------
-- Drop constraints
---------------------------------------------------------------------------
ALTER TABLE [dbo].[CustomerCustomerDemo]
DROP CONSTRAINT [FK_CustomerCustomerDemo_Customers]
GO
ALTER TABLE [dbo].[CustomerCustomerDemo]
DROP CONSTRAINT [FK_CustomerCustomerDemo]
GO
ALTER TABLE [dbo].[Employees]
DROP CONSTRAINT [FK_Employees_Employees]
GO
ALTER TABLE [dbo].[EmployeeTerritories]
DROP CONSTRAINT [FK_EmployeeTerritories_Territories]
GO
ALTER TABLE [dbo].[EmployeeTerritories]
DROP CONSTRAINT [FK_EmployeeTerritories_Employees]
GO
ALTER TABLE [dbo].[Order Details]
DROP CONSTRAINT [FK_Order_Details_Products]
GO
ALTER TABLE [dbo].[Order Details]
DROP CONSTRAINT [FK_Order_Details_Orders]
GO
ALTER TABLE [dbo].[Orders]
DROP CONSTRAINT [FK_Orders_Shippers]
GO
ALTER TABLE [dbo].[Orders]
DROP CONSTRAINT [FK_Orders_Employees]
GO
ALTER TABLE [dbo].[Orders]
DROP CONSTRAINT [FK_Orders_Customers]
GO
ALTER TABLE [dbo].[Products]
DROP CONSTRAINT [FK_Products_Suppliers]
GO
ALTER TABLE [dbo].[Products]
DROP CONSTRAINT [FK_Products_Categories]
GO
ALTER TABLE [dbo].[Territories]
DROP CONSTRAINT [FK_Territories_Region]
GO
---------------------------------------------------------------------------
-- Drop tables
---------------------------------------------------------------------------
DROP TABLE [dbo].[Categories]
GO
DROP TABLE [dbo].[CustomerCustomerDemo]
GO
DROP TABLE [dbo].[CustomerDemographics]
GO
DROP TABLE [dbo].[Customers]
GO
DROP TABLE [dbo].[Employees]
GO
DROP TABLE [dbo].[EmployeeTerritories]
GO
DROP TABLE [dbo].[Order Details]
GO
DROP TABLE [dbo].[Orders]
GO
DROP TABLE [dbo].[Products]
GO
DROP TABLE [dbo].[Region]
GO
DROP TABLE [dbo].[Shippers]
GO
DROP TABLE [dbo].[Suppliers]
GO
DROP TABLE [dbo].[Territories]
GO
相关文章推荐
- Nuva 示例代码(每日一帖)之 模板示例(3)
- Nuva 示例代码(每日一帖)之 模板示例(1)
- Nuva 示例代码(每日一帖)之 模板示例(1)
- Nuva 示例代码(每日一帖)之 模板示例(3)
- Nuva 示例代码(每日一帖)之 模板示例(2)
- Nuva 示例代码(每日一帖)之 数据架构提取
- Nuva 示例代码(每日一帖)之 正则测试器
- Nuva 示例代码(每日一帖)之 生成网站地图
- Nuva 示例代码(每日一帖)之 正则测试器
- Nuva 示例代码(每日一帖)之 国际化界面
- Nuva 示例代码(每日一帖)之 ShowMessage
- Nuva 示例代码(每日一帖)之 语法兼容
- Nuva 示例代码(每日一帖)之 简单浏览器
- Nuva 示例代码(每日一帖)之 正则表达式(1)
- Nuva 示例代码(每日一帖)之 正则表达式(3)
- Nuva 示例代码(每日一帖)之 正则表达式(递归)
- Nuva 示例代码(每日一帖)之 添加版权信息
- Nuva 示例代码(每日一帖)之 生成网站地图
- Nuva 示例代码(每日一帖)之 正则表达式(1)
- Nuva 示例代码(每日一帖)之 源代码统计