AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX Blogs
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 11.09.2007, 05:42   #1  
Blog bot is offline
Blog bot
Участник
 
25,643 / 848 (80) +++++++
Регистрация: 28.10.2006
Issues concerning X++: SQL improvements in the next version of Dynamics AX
Источник: http://blogs.msdn.com/x/archive/2007...t-version.aspx
==============

I'd like to share with you a description of some of the features that we've finished for the next release. The features described in this blog post are improvements and additions to the X++ data access statements. One deals with ordering and grouping data, another expands the possibilities of the update statement by allowing join clauses; The third feature involves allowing values (or more precisely, constants that are not field related) into the selection that is inserted into a table in an insert_recordset statement.

Ordering and grouping Data
Previously, the order by and group by clauses acted on the table in the current join or select clause. So, the following
X++:
1: CustTable ct;
2: CustTrans transactions;
3: 
4:  select  *  from ct  order by AccountNum
5:  join transactions  order by AmountCur
6:  where ct.AccountNum == transactions.AccountNum;
would order by the account number, then on the amount. Note that the order by syntax doesn't include the table to which the field belongs, because it is implicit in the order by clauses position. This way of doing things works fine so long as you do not have requirements to order in a different order than what is mandated by the join structure. For instance, if you wanted to order by amount and then by accountnum you'd have to reverse the select/join hierarchy. To get rid of these problems, we have introduced a way of specifying an order by (and a group by) list that is not tied to a particular place in the join hierarchy. This is done by specifying a list of qualified names of fields in a single order by or group by clause:
X++:
1:  select *  from ct
2:  join transactions
3:  order by transactions.AmountCur, ct.AccountNum
4:  where ct.AccountNum == transactions.AccountNum;
There can be only one such augmented order by clause in a selection.

Improvements to the update statement
The update statement may now have a join clause attached to it, as shown in the code snippet below:
X++:
1: // Three Table Join 
2: update_recordset salestable
3: setting currencycode = 'USD'
4: join custtable
5: where  custtable.accountnum = salesTable.custaccount
6: join custgroup
7: where custgroup.name == 'Retail' && custgroup.custgroup == custTable.custgroup;
We have also added some diagnostics that will cause the compiler to complain if the user tries to use the value of fields coming from tables that are given in exists and non exists joins (The database backend is not required to fetch values for these, merely to find out if there are matching records or not).
The Insert statement.

The insert statement is generally used to insert data from one table into another. The programmer typically writes a selection of fields matching the fields to insert into the target table and delimits the data by using suitable where and join clauses:
X++:
1: insert_recordset MyTargetTable(targetField1, targetField2)
2:     select sourceField1, sourceField2 from MySourceTable where ...
3:
This is indeed suitable for the case where all the data to be inserted into the target table is already stored in the source table, but that is not always the case. The new feature allows the user to insert values that are given by variable references, not field references.
How does this feature work?

Consider the case where a company has decided to make it mandatory for all customers in Italy to have a credit limit. Isaac would write:
X++:
1: Boolean mandatory = true;
2: CustTable custTable;
3: insert_recordset CustTable (MandatoryCreditLimit)
4:     select mandatory from CustTable where CustTable.Countryname == "Italy";
Note that the value to be inserted is specified in the form of a variable reference, mandatory in casu. The non-field values to be inserted must be variables, not expressions.

Источник: http://blogs.msdn.com/x/archive/2007...t-version.aspx
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
Старый 11.09.2007, 06:20   #2  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Короткий комментарий:
= запросы улучшают
= код сильно рефакторят под групповые операторы
= вложенных select'ов в условии where в следующей версии не ожидается.
= having'а тоже не ожидается.
__________________
полезное на axForum, github, vk, coub.
Старый 11.09.2007, 14:49   #3  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,953 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от mazzy Посмотреть сообщение
1: Boolean mandatory = true;
2: CustTable custTable;
3: insert_recordset CustTable (MandatoryCreditLimit)
4: select mandatory from CustTable where CustTable.Countryname == "Italy";
Не понял это место.
т.е. они фактически берут значение переменной mandatory и подставляют его значение во вставляемые записи.

Если это так, то как же защита от опечаток на этапе компиляции ?
Старый 13.09.2007, 13:08   #4  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от Logger Посмотреть сообщение
Не понял это место.
т.е. они фактически берут значение переменной mandatory и подставляют его значение во вставляемые записи.

Если это так, то как же защита от опечаток на этапе компиляции ?
Пока сам не очень понимаю.
Может другие что скажут.
__________________
полезное на axForum, github, vk, coub.
Старый 25.09.2007, 19:40   #5  
Blog bot is offline
Blog bot
Участник
 
25,643 / 848 (80) +++++++
Регистрация: 28.10.2006
Dynamics AX: X++ Team Blog Entry - SQL Imporvements in next version
Источник: http://dynamics-ax.blogspot.com/2007...ements-in.html
==============
In review of some other Dynamics AX and X++ blogs I came back across the X++ development team blog. When I did, I came across a very interesting article on improvements for X++ SQL in the next major release of Dynamics AX 5.0. Check out the link below:

X++ Team, SQL Improvements write up

With this, we can see some good moves, that will really help X++ developers work with more T-SQL like statements from within X++. The thing that is always a little scary about these types of changes is backwards compatability. So hopefully they are taking the time with these improvements to make sure that the upgrade takes care of this, or that it will still work in the old fashion. Either way though, I believe this is a good move, and a great resource of a blog!

check back soon!


Find a job at: www.DynamicsAXJobs.comFind a job at: DynamicsAXJobs.com, also post a job for only $99.00!


==============
Источник: http://dynamics-ax.blogspot.com/2007...ements-in.html
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
axStart: Microsoft Dynamics AX 2009 Hot Topics Web Seminar Series Blog bot DAX Blogs 0 06.08.2008 12:05
Dynamics AX: Dynamics AX 2009 & SQL Server 2008 Blog bot DAX Blogs 0 10.06.2008 21:08
Inside Dynamics AX 4.0: Usage Scenarios Blog bot DAX Blogs 0 04.10.2007 05:15
Dynamics AX: What version of SQL Server for a new install? Blog bot DAX Blogs 1 20.07.2007 10:25
Dynamics AX: SQL Server, Heart of Dynamics AX Blog bot DAX Blogs 0 13.07.2007 18:00

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 22:40.