Temporary TempDB Tables [AX 2012]

1 out of 4 rated this helpful - Rate this topic

Updated: November 5, 2013

Applies To: Microsoft Dynamics AX 2012 R2, Microsoft Dynamics AX 2012 Feature Pack, Microsoft Dynamics AX 2012

In Microsoft Dynamics AX, one type of temporary table is a TempDB table. We call them TempDB tables because their TableType property value is TempDB . This value comes from theTableType::TempDB enum value. The TableType property value can be set at AOT Data Dictionary Tables MyTempDBTable Properties TableType .

All types of temporary tables are automatically dropped by the system when the table variable in X++ goes out of scope. A TempDB table is not dropped when you set its record buffer variable to null .

TempDB tables are a different type of temporary table than InMemory tables. For more information, see Temporary InMemory Tables .

Capabilities of TempDB Tables

The following table describes the capabilities of TempDB tables.

Capability

Description

Can be joined .

你的X++ SQL 代码可以 join a TempDB table 到一个常规表,在单个调用中执行多行操作.

Can be either per company or global.

在TempDB表上的 SaveDataPerCompany 属性可以被设置为 Yes or No . 如果值为 No ,会成为全局表. For more information, see Table Properties .

可以通过 .NET Business Connector 从企业门户使用.

TempDB表可以用于窗体和X++代码,与任何用户界面没有关联.但是它可以直接被企业门户数据集使用.

Can have foreign key columns.

TempDB表可以引用其他表的主键作为自己的外间列.然而,它的主键不能作为其他表的外键.

TempDB tables可以从客户端或服务器层实例化.

TempDB表可以用于运行在客户端层或AOS层的逻辑.

Can have indexes columns.

TempDB可以在AOT中为它定义索引.

Can have methods, but cannot override .

你可以为TempDB表添加方法,然而,不能覆盖TempDB表中的任何方法.

Usable as a query How to: Add Multiple Data Sources to a Query .

在 AOT Queries 下的一个查询,可以引用TempDB作为他的数据源.

Transaction support .

底层数据库管理系统,为每个TempDB表的实例,提供事务支持,就像常规表一样. 每个实例都是一个单独的表,与其他实例是无关的,每个实例都短命.

No configuration key .

No configuration key is needed for you to use a TempDB table.

Limitations of TempDB Tables

The following table describes the limitations of TempDB tables.

Limitation

Descriptions

Cannot be a valid time state table(有效时间状态表) .

ValidTimeStateFieldType 属性被默认值 None 限制了. 这意味着系统在TempDB表中不能管理日期有效数据.

Cannot have any delete actions .

A TempDB table cannot have any delete actions defined under its DeleteActions node in the AOT.

No Record Level Security ( RLS ).

RLS is not applied to TempDB tables.

Cannot use the Table browser form .

要将记录添加到常规表,你可以在AOT中右键它的节点,点击 Open . 打开 Table browser form. 通过键入 Ctrl+N, 你可以添加记录. 然而, Table browser form 不支持TempDB表. 这是因为TempDB表仅存在于实例它的方法范围内.

Cannot be in a table collection .

任何临时表都不能在表集合中.

No view support.

AOT中的视图不能引用TempDB表.当一个视图通过 AOT Data Dictionary Views 创建并保存,视图会同步到底层数据库系统. 在那一刻,视图必须由数据库系统创建. 但是每个TempDB表是很少存在于数据库中,因为TempDB表仅存在于实例化表的方法期间. 因此,TempDB表通常不是在数据库中为任何数据库视图可以引用的.

Lifetime of TempDB Tables

当第一个SQL操作从AOS发送到数据库系统时,TempDB表在底层数据库管理系统中被实例化. SQL操作可以是select,insert,update,delete.

下面的表,描述了导致TempDB表被丢弃的情形.

Cause of drop

Description

Variable goes out of scope.(变量超出范围)

典型的例子是,一个方法为特定TempDB类型声明了一个变量.这个方法插入数据到TempDB表. 插入导致TempDB在数据库中被实例化.当方法结束,方法中的所有变量都超出范围. AOS告诉数据库系统,当TempDB表对应的变量超出范围,丢弃它.

Controlled restart of the AOS.

当你停止挺重启AOS,AOS会告诉数据库系统,丢弃所有的TempDB表.

Restart of the database system.

当数据库系统停止并重启,所有TempDB表的实例会被丢弃.

如果AOS服务短暂停止,比如硬件电源故障,TempDB表可以留在底层数据库中. 这里没有自动机制立即丢弃表.

Closure of the AX32.exe client.

假设你从 AX32.exe 客户端 AOT Jobs 启动一个 job from. Job会调用服务端方法实例化一个TempDb表.当你关闭你的 AX32.exe程序,服务端方法依然在运行.这将结束你的Microsoft Dynamics AX 会话, 并立即结束服务端方法.所有方法中声明的变量现在都超出了范围.因此,AOS告诉 数据库系统,丢弃TempDB表.

Online Users form.

The Online Users 窗体可以用于任何与还没有自动丢弃的TempDB表相关的Microsoft Dynamics AX会话. 窗体在内容面板 Administration Administration AreaCommon forms Online users 中可用.

TempDB Tables for Disabled Tables

你可以禁用一个常规持久化的数据库表,通过禁用 configuration key .禁用这个键会导致系统自动创建与数据库表字段和架构相匹配的TempDB类型的临时表. 这个临时表存在于底层SQL Server database ,并通过AOS管理.

自动创建TempDB表的目的是为了让被禁用的AOT对象继续变异和运行. configuration key被禁用后,依然能读写这些TempDB表.

所有表缓冲器变量都继承 xRecord 类的方法. 其中一个方法是 setTmp , 它创建一个与常规表拥有相同架构的InMemory临时表.然而, setTmp 方法不能从TempDB表创建InMemory表. 你可以调用 isTempDb 方法来确定 setTmp 方法是否可用.

X++ Code Example

The following X++ code example assumes that a TempDB table which is named MyTempdb has already been defined under AOT Data Dictionary Tables . The MyTempdb table has one column that is the same type as the AccountNum column on the CustTable table. The while select statement in the example contains a JOIN clause that cannot be used with temporary InMemory tables.

X++

server public
static
void main(Args _args)

{

MyTempdb xrecMyTempdb;

CustTable xrecCustTable;

TableType tableTypeEnum;

str stringWork;

Global::info("Start of main.");

xrecMyTempdb.AccountNum =
"4004";

xrecMyTempdb.doInsert();

xrecMyTempdb.AccountNum =
"4005";

xrecMyTempdb.doInsert();

tableTypeEnum = xrecMyTempdb.getTableType();

stringWork =
"MyTempdb.TableType is: "
+

enum2Str(tableTypeEnum); info(stringWork);

while select * from xrecCustTable

JOIN xrecMyTempdb where xrecMyTempdb.AccountNum == xrecCustTable.AccountNum

{

stringWork = xrecCustTable.AccountNum +

" , "
+

int2Str(xrecCustTable.MandatoryCreditLimit);

info(stringWork);

}

}
/*** Infolog outputMessage (05:21:28 pm) Start of

main. MyTempdb.TableType is: TempDB 4004 , 0 4005 , 1 ***/

 

See also

Temporary Tables and the TableType Property

Community Additions

Temporary TempDB Tables [AX 2012]的更多相关文章

  1. Temporary InMemory Tables [AX 2012]

    Temporary InMemory Tables [AX 2012] This topic has not yet been rated - Rate this topic Updated: Oct ...

  2. Temporary Tables and the TableType Property [AX 2012]

    Temporary Tables and the TableType Property [AX 2012] 1 out of 1 rated this helpful - Rate this topi ...

  3. Table Properties [AX 2012]

    Table Properties [AX 2012] 1 out of 2 rated this helpful - Rate this topic Updated: July 20, 2012 Ap ...

  4. Select Statement Syntax [AX 2012]

    Applies To: Microsoft Dynamics AX 2012 R3, Microsoft Dynamics AX 2012 R2, Microsoft Dynamics AX 2012 ...

  5. View Properties [AX 2012]

    View Properties [AX 2012] Other Versions This topic has not yet been rated - Rate this topic Updated ...

  6. Understanding the RelationshipType Enumeration [AX 2012]

    Understanding the RelationshipType Enumeration [AX 2012] 3 out of 3 rated this helpful - Rate this t ...

  7. Table Groups [AX 2012]

    Table Groups [AX 2012] 0 out of 1 rated this helpful - Rate this topic Updated: February 21, 2012 Ap ...

  8. Dynamics AX 2012 的工业物联网解决方案

    Dynamics AX 2012 的工业物联网解决方案 物联网 物联网的概念在这两年非常火,包括近期很火的共享单车初创公司--摩拜单车,在产品中运用了Azure Iot物联网技术.但是,物联网并不是一 ...

  9. Dynamics AX 2012 在BI分析中建立数据仓库的必要性

    AX系统已有的BI分析架构 对于AX 的BI分析架构,相信大家都了解,可以看Reinhard之前的译文[译]Dynamics AX 2012 R2 BI系列-分析的架构 . AX 的BI分析架构的优势 ...

随机推荐

  1. NPOI 导入,导出EXCEL

    代码: public static class NPOIExcelHelper { /// <summary> /// DataTable导出到Excel文件 /// </summa ...

  2. Android Framework框架_转

    选自<Android内核剖析> Framework定义了客户端组件和服务端组件功能及接口.包含3个主要部分:服务端,客户端和Linux驱动. (一)服务端 服务端主要包含两个重要类,分别是 ...

  3. Fluentd安装——通过rpm方式

    0. td-agent是何物 为了灵活性,fluentd用Ruby写的,其中一些性能敏感的部件使用c写的.普通的用户直接安装和使用Ruby进程可能有困难,这样就把它封装成Fluentd的稳定版本——t ...

  4. Django 学习

    urls.py 路由系统 from django.conf.urls import url,includefrom django.contrib import adminfrom web import ...

  5. Formatting Domain Names--域名可以由哪些字符串组成

    the domain name can include any of the following printable ASCII characters (excluding spaces): a-z ...

  6. Angular.js+Bootstrap实现表格分页

    最近一直学习Angular.js,在学习过程中也练习了很多的Demo,这里先贴一下表格+分页. 先上图看看最终结果: 不得不说Angular.js代码风格很受人欢迎,几十行代码清晰简洁的实现了上面的功 ...

  7. MAXFLOAT

    CGSizeMake(300, MAXFLOAT),是计算宽和高的,里面的MAXFLOAT通俗点说就是最大的数值,代表你的label的宽和高是随着你label内容而变化,不用担心因为label内容过长 ...

  8. swift语言实战晋级-1 Swift开发环境的搭建

    想要进行Swift的学习,必须要有个开发环境.简单的说就是装好了Xcode的Mac系统.那么接下来我们就简单了解一下这方面的内容. 1.1 下载Xcode Xcode是苹果公司出的编程工具,类似于微软 ...

  9. 锋利的jQuery

    今天总要找点东西学习,其实有很多东西要记录,慢慢写,今天看书吧,这几天把这本书看完,这里记一些要点 从头开始记吧 第一章 认识jQuery $就是jQuery的简写 $(function(){}) 就 ...

  10. JavaScript----marquee滚动标签 图片无缝滚动 插入百度地图

    页面的自动滚动效果,可由javascript来实现, 但是有一个html标签 - <marquee></marquee>可以实现多种滚动效果,无需js控制. 使用marquee ...