[SQL Server2008]MDX²éѯÓï¾ä
ÔÚEssbaseÖÐʹÓÃMDXÖ»ÄÜÓÃÓÚ²éѯ£¬Éв»ÄÜÀ´²Ù×÷Cube£¨MS SSASÖпÉÒÔʹÓÃMDXÀ´²Ù×÷CubeµÄ£©£¬ËùÒÔÕâÀïֻѧϰMDXµÄSelectÓï¾ä¡£
ÔÚѧϰµÄ¹ý³ÌÖУ¬ÎÒ¾õµÃ×îÓÐÄѶȵĵط½ÓÐÁ½¸ö¡£
Ò»ÊÇ£¬¶ÔOLAP¶àάµÄÀí½â¡£ÈçͬѧϰSQLÒ»Ñù£¬SQL×÷ÓõĶÔÏóÊÇ±í£¬±íµÄ½á¹¹¶¼ÊǶþάµÄ£¬±êʶÐÐÁм´¿É£»µ«ÊÇMDX×÷ÓõĶÔÏóÊǶàάÊý¾Ý¿â£¬ÄÇô¾ÍµÃÀí½â¶àάÊý¾Ý¿âµÄά¶È£¬²ã¼¶£¬³ÉÔ±£¬ÒÔ¼°ÈçºÎÔÚ¶àάÊý¾Ý¿âÖж¨Î»²»Í¬²ã¼¶µÄ³ÉÔ±¡£
¶þÊÇ£¬Àí½âMDX²éѯÓï¾äµÄ½á¹¹¼°ÊõÓïµÄº¬Ò塣ѧϰSQLʱ£¬ÎÒÃdz£Ìáµ½±í£¬×ֶΣ¬ÄÇôMDXÖÐÄØ£¬Ïë±ØÕâЩÊõÓï±ØÐëÀí½â£¬ÀýÈ磺Cube£¬Slice£¬Axis£¬Set£¬Tuple£¬Members
ÎÒµÄѧϰ¾ÀúÊÇÕâÑùµÄ£¬Ê×ÏÈÁ˽âMDXÓï¾äµÄÌØµã¼°¹¦Óá£
“MDXÈ«³ÆÊÇMutil-Dimensional Expressions£¬¼´¶àΪ±í´ïʽ¡£MDXÊÇÒ»ÖÖºÍSQLÀàËÆµÄÓïÑÔ£¬ËüÒ²¿ÉÒÔÓÃÓÚ²éѯ¡¢¼ÆËãºÍ¶¨ÒåһЩԪÊý¾Ý¡£Ö»²»¹ýSQLÊÇ»ùÓÚOLTPµÄ£¬¶øMDXÊÇ»ùÓÚOLAPµÄ£¬Ò²¾ÍÊÇ˵£¬MDXÊǶԶàάÊý¾Ý½øÐвéѯµÄ¡£ºÍÆäËüµÄOLAPÓïÑÔ²»Í¬£¬MDX²¢²»ÍêÈ«ÊÇÒ»ÖÖ±¨¸æÐÎʽÓïÑÔ¡£µ«ÓÃMDX²éѯ³öÀ´µÄ½á¹ûÈÔÈ»¿ÉÒÔÔÚ¿Í»§¶Ë³ÌÐòÖÐÒÔ±í¸ñÐÎʽ½øÐÐÕ¹ÏÖ¡£MDXºÍSQLÒ»Ñù£¬Ò²Óкܶ಻ͬ¹¦ÄܵÄAPIÀ´Ö§³ÖMDX£¬×î³£Óõ½µÄ¾ÍÊÇXML API¡£”
ÉÏÃæµÄÒ»¶Î»°ÊÇ´ÓÍøÉÏժ¼À´µÄ£¬¸øMDX×öÁËÒ»¸ö¶¨Òå¡£
½ÓÏÂÀ´Ñ§Ï°MDX²éѯÓï¾äµÄ½á¹¹¼°×é³É¡£
[<with_section>]
SELECT [<axis_specification>
[, <axis_specification>...]]
[from [<cube_specification>]]
[WHERE [<slicer_specification>]]
Õâ¸ö½á¹¹¾ÍÊÇMDX²éѯÓï¾äµÄͨÓýṹ£¬´ÓÖÐÒªÀí½âÄÄЩÊǹؼü×ÖÒÔ¼°¹Ø¼ü×ÖµÄ˳Ðò£¬WITH section¡¢Axis¡¢Cube¡¢SlicerµÄλÖá£ÕâЩ¶¼ÊÇMDXµÄÓï·¨¹æ¶¨£¬ËùÒÔÒªÀμǸ÷×ÔµÄλÖá£
È»ºóѧϰµÄÊÇÒÔÉÏMDXÓï¾ä½á¹¹Öи÷¸öλÖõĺ¬Òå¡£
<with_section>µÄλÖÃÓÃÓÚÉ趨×Ô¶¨ÒåµÄ¼ÆËã¡£ÓÐÁ½ÖÖÔËÓã¬WITH SET…,WITH MEMBER…£¬ÔÚ¸´ÔÓµÄMDX²éѯÓï¾äÖо³£±»Óõ½¡£
<axis_specification>µÄλÖÃÓÃÓÚÉ趨Öá¡£Õâ¸öÖáÊÇ·´Ó³ÔÚMDXÓï¾äµÄÊä³ö±¨±íÉϵġ£³£ÓõľÍÊÇÁС¢ÐС¢Ò³£¬ÈçÏÂͼËùʾ£º
<cube_specification>λÖÃÓÃÓÚÖ¸¶¨²éѯÓõÄCube£¬Ö»ÄÜÖ¸¶¨Ò»¸ö¡£
<slicer_specification>λÖÃÓÃÓÚÖ¸¶¨ÏÞÖÆÌõ¼þ£¬¿ÉÒÔÊǶà¸öÏÞÖÆÌõ¼þ£¬·´Ó³ÔÚCubeÖгÆÎªÇÐÆ¬¡£
&n
Ïà¹ØÎĵµ£º
ÔÚ¹ÜÀí¹¤¾ßÀïÃæÓÐÊý¾ÝÔ´ Ñ¡ÔñsqlÊý¾ÝÔ´
ÔÚ´úÂëÖУº
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@page import="java.sql.*"%>
<html>
<head>
<meta http-equiv="Content-Type" content= ......
½ñÌì´ÓÊý¾Ý¿âÖвéѯ³öxml£¬Í¬Ê±Ìí¼ÓÒ»¸ö¸ù½Úµã
×öÁËÈçϲâÊÔ£º
create table TestXmlQuery(
ID int identity(1,1) not null,
Name varchar(10)
)
go
insert into [TestXmlQuery] (Name) values('²âÊÔ1')
insert into [TestXmlQuery] (Name) values('²âÊÔ2')
insert into [TestXmlQuery] (Name) values('²âÊÔ3')
......
1 Âß¼Êý¾Ý¿âºÍ±íµÄÉè¼Æ
Êý¾Ý¿âµÄÂß¼Éè¼Æ¡¢°üÀ¨±íÓë±íÖ®¼äµÄ¹ØÏµÊÇÓÅ»¯¹ØÏµÐÍÊý¾Ý¿âÐÔÄܵĺËÐÄ¡£Ò»¸öºÃµÄÂß¼Êý¾Ý¿âÉè¼Æ¿ÉÒÔΪ
ÓÅ»¯Êý¾Ý¿âºÍÓ¦ÓóÌÐò´òÏÂÁ¼ºÃµÄ»ù´¡¡£
±ê×¼»¯µÄÊý¾Ý¿âÂß¼Éè¼Æ°üÀ¨ÓöàµÄ¡¢ÓÐÏ໥¹ØÏµµÄÕ±íÀ´´úÌæºÜ¶àÁеij¤Êý¾Ý±í¡£ÏÂÃæÊÇһЩʹÓñê×¼»¯
±íµÄһЩºÃ´¦¡£
A:ÓÉÓÚ±íÕ£¬Òò´Ë¿ÉÒÔʹŠ......
ÓÉÓÚÍøÕ¾ÊDZðÈ˵Ä
sql server 2000 ²»Äܵ¼Èë2005 µÄÊý¾Ý¿âÎļþ ÎÒÖ»ºÃ°´ÕÕÊéÉÏÖØÐ½¨Á¢µÄÊý¾Ý¿âÎļþ
È»ºóÔÚvisual studio 2005ÖÐÒ»¸öÒ»¸öµÄ¸´ÖÆ´æ´¢¹ý³Ìµ½sql server 2000
ÕâÑù¾Í²»ÓÃÏÂÔØ sql server 2005 ÁË
Èç¹ûÓÐsql server 2005 µÄ»°Ö®¼ÊÉú³É ½Å±¾¾ÍÒ»ÖÂÐÔµ¼Èë¾ÍokÁË ......