(转载)SQL Reporting Services (Expression Examples)
https://msdn.microsoft.com/en-us/library/ms157328(v=SQL.100).aspx
Expressions are used frequently in reports to control content and report appearance. Expressions are written in Microsoft Visual Basic, and can use built-in functions, custom code, global variables, report and group variables, and user-defined variables.
This topic provides examples of expressions that can be used for common tasks in a report.
- Visual Basic Functions Examples for date, string, conversion and conditional Visual Basic functions. 
- Report Functions Examples for aggregates and other built-in report functions. 
- Appearance of Report Data Examples for changing the appearance of a report. 
- Properties Examples for setting report item properties to control format or visibility. 
- Parameters Examples for using parameters in an expression. 
- Custom Code Examples of embedded custom code. 
For expression examples for specific uses, see the following topics:
For more information about simple and complex expressions, where you can use expressions, and the types of references that you can include in an expression, see topics under Working with Report Expressions. For more information about the context in which expressions are evaluated for calculating aggregates, see Calculating Totals and Other Aggregates (Reporting Services).
In addition, the expression editor includes a hierarchical view of built-in functions. When you select the function, a code example appears in the values pane. For more information, see Expression Dialog Box.
Many expressions in a report contain functions. You can format data, apply logic, and access report metadata using these functions. You can write expressions that use functions from the Microsoft Visual Basic run-time library, and from the System.Convert and System.Math namespaces. You can add references to functions from other assemblies or custom code. You can also use classes from the Microsoft .NET Framework, including System.Text.RegularExpressions. For more information about Visual Basic functions, see "Visual Basic Run-Time Library" at msdn.microsoft.com.
The .NET Framework provides many ways to specify custom formats, for example, for specific date formats. For more information, see Formatting Types on MSDN.
Visual Basic Functions
You can use Visual Basic functions to manipulate the data that is displayed in text boxes or that is used for parameters, properties, or other areas of the report. This section provides examples that demonstrate some of these functions. These examples specify Visual Basic constants as enumeration values, for example, DateInterval.Month. Although the expression editor does not support Intellisense for these values, they compile correctly in an expression.
For more information about Visual Basic functions, see the Visual Basic documentation.
Date Functions
- The Today function provides the current date. This expression can be used in a text box to display the date on the report, or in a parameter to filter data based on the current date. - =Today() 
- The DateAdd function is useful for supplying a range of dates based on a single parameter. The following expression provides a date that is six months after the date from a parameter of type System.DateTime that is named StartDate. - =DateAdd(DateInterval.Month, 6, Parameters!StartDate.Value) 
- The Year function displays the year for a particular date. You can use this to group dates together or to display the year as a label for a set of dates. This expression provides the year for a given group of sales order dates. The Month function and other functions can also be used to manipulate dates. For more information, see the Visual Basic documentation. - =Year(Fields!OrderDate.Value) 
String Functions
- Combine more than one field by using concatenation operators and Visual Basic constants. The following expression returns two fields, each on a separate line in the same text box: - =Fields!FirstName.Value & vbCrLf & Fields!LastName.Value 
- Format dates and numbers in a string with the Format function. The following expression displays values of the StartDate and EndDate parameters in long date format: - =Format(Parameters!StartDate.Value, "D") & " through " & Format(Parameters!EndDate.Value, "D") - If the text box contains only a date or number, you should use the Format property of the text box to apply formatting instead of the Format function within the text box. 
- The Right, Len, and InStr functions are useful for returning a substring, for example, trimming DOMAIN\username to just the user name. The following expression returns the part of the string to the right of a backslash (\) character from a parameter named User: - =Right(Parameters!User.Value, Len(Parameters!User.Value) - InStr(Parameters!User.Value, "\")) - The following expression results in the same value as the previous one, using members of the .NET Framework System.String class instead of Visual Basic functions: - =Parameters!User.Value.Substring(Parameters!User.Value.IndexOf("\")+1, Parameters!User.Value.Length-Parameters!User.Value.IndexOf("\")-1)
- Display the selected values from a multivalue parameter. The following example uses the Join function to concatenate the selected values of the parameter MySelection into a single string that can be set as an expression for the value of a text box in a report item: - = Join(Parameters!MySelection.Value) 
- The Regex functions from the .NET Framework RegularExpressions are useful for changing the format of existing strings, for example, formatting a telephone number. The following expression uses the Replace function to change the format of a ten-digit telephone number in a field from "nnn-nnn-nnnn" to "(nnn) nnn-nnnn": - =System.Text.RegularExpressions.Regex.Replace(Fields!Phone.Value, "(\d{3})[ -.]*(\d{3})[ -.]*(\d{4})", "($1) $2-$3") Note Note- Verify that the value for Fields!Phone.Value has no extra spaces and is of type System.String. 
Conversion Functions
You can use Visual Basic functions to convert a field from the one data type to a different data type. Conversion functions can be used to convert a the default data type for a field to the data type needed for calculations or to combine text.
- The following expression converts the constant 500 to type Decimal in order to compare it to a Transact-SQL money data type in the Value field for a filter expression. - =CDec(500) 
- The following expression displays the number of values selected for the multivalue parameter MySelection. - =CStr(Parameters!MySelection.Count) 
Decision Functions
- The Iif function returns one of two values depending on whether the expression is true or not. The following expression uses the Iif function to return a Boolean value of True if the value of LineTotal exceeds 100. Otherwise it returns False: - =IIF(Fields!LineTotal.Value > 100, True, False) 
- Use multiple IIF functions (also known as "nested IIFs") to return one of three values depending on the value of PctComplete. The following expression can be placed in the fill color of a text box to change the background color depending on the value in the text box. - =IIF(Fields!PctComplete.Value >= 10, "Green", IIF(Fields!PctComplete.Value >= 1, "Blue", "Red")) - Values greater than or equal to 10 display with a green background, between 1 and 9 display with a blue background, and less than 1 display with a red background. 
- A different way to get the same functionality uses the Switch function. The Switch function is useful when you have three or more conditions to test. The Switch function returns the value associated with the first expression in a series that evaluates to true: - =Switch(Fields!PctComplete.Value >= 10, "Green", Fields!PctComplete.Value >= 1, "Blue", Fields!PctComplete.Value = 1, "Yellow", Fields!PctComplete.Value <= 0, "Red",) - Values greater than or equal to 10 display with a green background, between 1 and 9 display with a blue background, equal to 1 display with a yellow background, and 0 or less display with a red background. 
- A third way to get the same functionality uses the Choose function. The Choose function uses the first parameter as an index to one of the remaining function parameters. The first parameter must be an integer. If the background color of a text box in a table is set to this expression, the value of MyIndex controls the color. - =Choose(Fields!MyIndex.Value,"Red","Green","Yellow") - For example, when MyIndex is 1, the background color is "Red". In the query result set, verify that the data for MyIndex does not exceed the range of the parameter list. 
- Test the value of the ImportantDate field and return "Red" if it is more than a week old, and "Blue" otherwise. This expression can be used to control the Color property of a text box in a report item: - =IIF(DateDiff("d",Fields!ImportantDate.Value, Now())>7,"Red","Blue")
- Test the value of the PhoneNumber field and return "No Value" if it is null (Nothing in Visual Basic); otherwise return the phone number value. This expression can be used to control the value of a text box in a report item. - =IIF(Fields!PhoneNumber.Value Is Nothing,"No Value",Fields!PhoneNumber.Value) 
- Test the value of the Department field and return either a subreport name or a null (Nothing in Visual Basic). This expression can be used for conditional drillthrough subreports. - =IIF(Fields!Department.Value = "Development", "EmployeeReport", Nothing) 
- Test if a field value is null. This expression can be used to control the Hidden property of an image report item. In the following example, the image specified by the field [LargePhoto] is displayed only if the value of the field is not null. - =IIF(IsNothing(Fields!LargePhoto.Value),True,False) 
Report Functions
Reporting Services provides additional report functions that you can use to manipulate data in a report. This section provides examples for two of these functions. For more information about report functions and examples, see Using Built-in Report and Aggregate Functions in Expressions (Reporting Services).
Sum
- The Sum function can total the values in a group or data region. This function can be useful in the header or footer of a group. The following expression displays the sum of data in the Order group or data region: - =Sum(Fields!LineTotal.Value, "Order") 
- You can also use the Sum function for conditional aggregate calculations. For example, if a dataset has a field that is named State with possible values Not Started, Started, Finished, the following expression, when placed in a group header, calculates the aggregate sum for only the value Finished: - =Sum(IIF(Fields!State.Value = "Finished", 1, 0)) 
RowNumber
- The RowNumber function, when used in a text box within a data region, displays the row number for each instance of the text box in which the expression appears. This function can be useful to number rows in a table. It can also be useful for more complex tasks, such as providing page breaks based on number of rows. For more information, see Page Breaks in this topic. - The scope you specify for RowNumber controls when renumbering begins. The Nothing keyword indicates that the function will start counting at the first row in the outermost data region. To start counting within nested data regions, use the name of the data region. To start counting within a group, use the name of the group. - =RowNumber(Nothing) 
You can use expressions to manipulate how data appears on a report. For example, you can display the values of two fields in a single text box, display information about the report, or affect how page breaks are inserted in the report.
Page Headers and Footers
When designing a report, you may want to display the name of the report and page number in the report footer. To do this, you can use the following expressions:
- The following expression provides the name of the report and the time it was run. It can be placed in a text box in the report footer or in the body of the report. The time is formatted with the .NET Framework formatting string for short date: - =Globals.ReportName & ", dated " & Format(Globals.ExecutionTime, "d") 
- The following expression, placed in a text box in the footer of a report, provides page number and total pages in the report: - =Globals.PageNumber & " of " & Globals.TotalPages 
The following examples describe how to display the first and last values from a page in the page header, similar to what you might find in a directory listing. The example assumes a data region that contains a text box named LastName.
- The following expression, placed in a text box on the left side of the page header, provides the first value of the LastName text box on the page: - =First(ReportItems("LastName").Value)
- The following expression, placed in a text box on the right side of the page header, provides the last value of the LastName text box on the page: - =Last(ReportItems("LastName").Value)
The following example describes how to display a page total. The example assumes a data region that contains a text box named Cost.
- The following expression, placed in the page header or footer, provides the sum of the values in the Cost text box for the page: - =Sum(ReportItems("Cost").Value)
|  Note | 
|---|
| You can refer to only one report item per expression in a page header or footer. Also, you can refer to the text box name, but not the actual data expression within the text box, in page header and footer expressions. | 
Page Breaks
In some reports, you may want to place a page break at the end of a specified number of rows instead of, or in addition to, on groups or report items. To do this, create a group that contains the groups or detail records you want, add a page break to the group, and then add a group expression to group by a specified number of rows.
- The following expression, when placed in the group expression, assigns a number to each set of 25 rows. When a page break is defined for the group, this expression results in a page break every 25 rows. - =CInt(Ceiling(RowNumber(Nothing)/25)) - To allow the user to set a value for the number of rows per page, create a parameter named RowsPerPage and base the group expression on the parameter, as shown in the following expression: - =CInt(Ceiling(RowNumber(Nothing)/Parameters!RowsPerPage.Value)) - For more information about setting page breaks for a group, see How to: Add a Page Break (Reporting Services). 
Expressions are not only used to display data in text boxes. They can also be used to change how properties are applied to report items. You can change style information for a report item, or change its visibility.
Formatting
- The following expression, when used in the Color property of a text box, changes the color of the text depending on the value of the Profit field: - =Iif(Fields!Profit.Value < 0, "Red", "Black") 
- The following expression, when used in the BackgroundColor property of a report item in a data region, alternates the background color of each row between pale green and white: - =Iif(RowNumber(Nothing) Mod 2, "PaleGreen", "White") - If you are using an expression for a specified scope, you may have to indicate the dataset for the aggregate function: - =Iif(RowNumber("Employees") Mod 2, "PaleGreen", "White")
|  Note | 
|---|
| Available colors come from the .NET FrameworkKnownColor enumeration. | 
Visibility
You can show and hide items in a report using the visibility properties for the report item. In a data region such as a table, you can initially hide detail rows based on the value in an expression.
- The following expression, when used for initial visibility of detail rows in a group, shows the detail rows for all sales exceeding 90 percent in the PctQuota field: - =Iif(Fields!PctQuota.Value>.9, False, True) 
- The following expression, when set in the Hidden property of a table, shows the table only if it has more than 12 rows: - =IIF(CountRows()>12,true,false) 
URLs
You can customize URLs by using report data and also conditionally control whether URLs are added as an action for a text box.
- The following expression, when used as an action on a text box, generates a customized URL that specifies the dataset field EmployeeID as a URL parameter. - ="http://adventure-works/MyInfo?ID=" & Fields!EmployeeID.Value - For more information, see How to: Add a Hyperlink to a URL (Reporting Services). 
- The following expression conditionally controls whether to add a URL in a text box. This expression depends on a parameter named IncludeURLs that allows a user to decide whether to include active URLs in a report. This expression is set as an action on a text box. By setting the parameter to False and then viewing the report, you can export the report Microsoft Excel without hyperlinks. - =IIF(Parameters!IncludeURLs.Value,"http://adventure-works.com/productcatalog",Nothing) 
Expressions can be used to manipulate the data that is used in the report. You can refer to parameters and other report information. You can even change the query that is used to retrieve data for the report.
Parameters
You can use expressions in a parameter to vary the default value for the parameter. For example, you can use a parameter to filter data to a particular user based on the user ID that is used to run the report.
- The following expression, when used as the default value for a parameter, collects the user ID of the person running the report: - =User!UserID 
- To refer to a parameter in a query parameter, filter expression, text box, or other area of the report, use the Parameters global collection. This example assumes that the parameter is named Department: - =Parameters!Department.Value 
- Parameters can be created in a report but set to hidden. When the report runs on the report server, the parameter does not appear in the toolbar and the report reader cannot change the default value. You can use a hidden parameter set to a default value as custom constant. You can use this value in any expression, including a field expression. The following expression identifies the field specified by the default parameter value for the parameter named ParameterField: - =Fields(Parameters!ParameterField.Value).Value - For more information, see Setting Parameter Properties for a Published Report. 
You can use custom code in a report. Custom code is either embedded in a report or stored in a custom assembly which is used in the report. For more information about custom code, see Using Custom Code References in Expressions (Reporting Services).
- The following example calls an embedded code method called ToUSD, which converts the StandardCost field value to a dollar value: - =Code.ToUSD(Fields!StandardCost.Value) 
- The following example shows how to define some custom constants and variables. - [Visual Basic] - Public Const MyNote = "Authored by Bob" 
 Public Const NCopies As Int32 = 2
 Public Dim MyVersion As String = "123.456"
 Public Dim MyDoubleVersion As Double = 123.456- Although custom constants and variables do not appear in the Expression Editor Constants view (which only displays built-in constants), you can add references to them from any expression, as shown in the following examples. These are treated as Variants. - [Visual Basic] - =Code.MyNote 
 =Code.NCopies
 =Code.MyVersion
 =Code.MyDoubleVersion
Another way to create custom constants or customize a value for an expression is to use a report variable or a group variable.
Using Group Variables for Custom Aggregation
You can initialize the value for a group variable that is local to a particular group scope and then include a reference to that variable in expressions. One of the ways that you can use a group variable with custom code is to implement a custom aggregate. For more information, see Using Group Variables in Reporting Services 2008 for Custom Aggregation.
For more information about variables, see Using Report and Group Variables Collection References in Expressions (Reporting Services).
Replacing Text in a Field at Run Time
The following example calls an embedded method called FixSpelling, which substitutes "Bicycle" for all occurrences of the text "Bike" in SubCategory.Value.
=Code.FixSpelling(Fields!SubCategory.Value)
The following code, when embedded in a report definition, shows an implementation of the FixSpelling method. This example shows you how to refer to the .NET Framework System.Text.StringBuilder class. For more information, see How to: Add Code to a Report (Reporting Services) and How to: Add an Assembly Reference to a Report (Reporting Services).
Suppressing Null or Zero Values at Run Time
Some values in an expression can evaluate to null or undefined at report processing time. This can create run-time errors that result in #Error displaying in the text box instead of the evaluated expression. The IIF function is particularly sensitive to this behavior because, unlike an If-Then-Else statement, each part of the IIF statement is evaluated (including function calls) before being passed to the routine that tests for true or false. The statement =IIF(Fields!Sales.Value is NOTHING, 0, Fields!Sales.Value) generates #Error in the rendered report if Fields!Sales.Value is NOTHING.
To avoid this condition, use one of the following strategies:
- Set the numerator to 0 and the denominator to 1 if the value for field B is 0 or undefined; otherwise, set the numerator to the value for field A and the denominator to the value for field B. - =IIF(Field!B.Value=0, 0, Field!A.Value / IIF(Field!B.Value =0, 1, Field!B.Value)) 
- Use a custom code function to return the value for the expression. The following example returns the percentage difference between a current value and a previous value. This can be used to calculate the difference between any two successive values and it handles the edge case of the first comparison (when there is no previous value) and cases whether either the previous value or the current value is null (Nothing in Visual Basic). - Public Function GetDeltaPercentage(ByVal PreviousValue, ByVal CurrentValue) As Object 
 If IsNothing(PreviousValue) OR IsNothing(CurrentValue) Then
 Return Nothing
 Else if PreviousValue = 0 OR CurrentValue = 0 Then
 Return Nothing
 Else
 Return (CurrentValue - PreviousValue) / CurrentValue
 End If
 End Function- The following expression shows how to call this custom code from a text box: - =Code.GetDeltaPercentage(Previous(Sum(Fields!Sales.Value),"ColumnGroupByYear"), Sum(Fields!Sales.Value)) 
| Updated content | 
|---|
| Examples added for the function Choose and for calculating custom aggregates by using group variables with custom code. | 
Community Additions
Font color expression does not work
=IIF(Fields!PctComplete.Value >= 10, "Green", IIF(Fields!PctComplete.Value >= 1, "Blue", "Red"))
I've run this in SSRS 2008 (with different fields obviously, but syntactically the same) and my report will not show blue. Where the blue condition is true, it only shows red. The first green condition shows correctly, but nothing beyond that. Anyone else having this problem? Reply by vivibit - The code is wrong, all of my color format work well. The range between 1-10 can have two colors. Maybe it is the reason, try it:
=Iif(Fields!PctComplete.Value < 1, "Red", Iif(Fields!PctComplete.Value >=10, "Green", "Blue") )
[tfl - 01 06 10] Hi - and thanks for your post. You should post questions like this to the MSDN Forums at http://forums.microsoft.com/msdn or the MSDN Newsgroups at http://www.microsoft.com/communities/newsgroups/en-us/. You are much more likely get a quicker response using the forums than through the Community Content. For specific help about: Visual Studio : http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public.vstudio%2C& SQL Server : http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public.sqlserver%2C& .NET Framework : http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public.dotnet.framework PowerShell : http://groups.google.com/group/microsoft.public.windows.powershell/topics?pli=1 All Public : http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public%2C&
 
            Reply to color format
 
            Please clarify
I am using the following exporession to hide a cell in the Matrix:
=iif(RowNumber("PeriodGroup") = 1, True, False)
No matter how I change this, I either get all cells shown, or all hidden.
[tfl - 20 09 09] Hi - and thanks for your post. You should post questions like this to the MSDN Forums at http://forums.microsoft.com/msdn or the MSDN Newsgroups at 
http://www.microsoft.com/communities/newsgroups/en-us/ . You are much more likely get a quicker response using the forums than through the Community Content. For specific help about: Visual Studio  :  http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public.vstudio%2C & Windows        :  http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public.windows%2C & SQL Server     :  http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public.sqlserver%2C & .NET Framework :  http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public.dotnet.framework
 PowerShell     :  http://groups.google.com/group/microsoft.public.windows.powershell/topics?pli=1
 All Public     :  http://groups.google.com/groups/dir?sel=usenet%3Dmicrosoft.public%2C &
(转载)SQL Reporting Services (Expression Examples)的更多相关文章
- Reporting Services 的伸缩性和性能表现规划(转载)
		简介 Microsoft? SQL Server? Reporting Services 是一个将集中管理的报告服务器具有的伸缩性和易管理性与基于 Web 和桌面的报告交付手段集于一身的报告平台.Re ... 
- Display Database Image using MS SQL Server 2008 Reporting Services
		原文 Display Database Image using MS SQL Server 2008 Reporting Services With the new release of MS SQL ... 
- [翻译]初识SQL Server 2005 Reporting Services Part 1
		原文:[翻译]初识SQL Server 2005 Reporting Services Part 1 构建和部署基本报表 如果曾经存在一项工作使得“真正的”开发者给他的上司泡蘑菇,那就是构建报表.毕竟 ... 
- Incorporating ASP.NET MVC and SQL Server Reporting Services, Part 1
		Your ASP.NET MVC application needs reports. What do you do? In this article, I will demonstrate how ... 
- 配置SQL Server 2008 R2 Reporting Services
		记录如何在本地配置SQL Server 2008 R2 Reporting Services,笔者环境为Windows 7 64位 + SQL Server 2008 R2 一.准备工作 其实准备工作 ... 
- [翻译]初识SQL Server 2005 Reporting Services Part 3
		原文:[翻译]初识SQL Server 2005 Reporting Services Part 3 这是关于SSRS文章中四部分的第三部分.Part 1提供了一个创建基本报表的递阶教程.Part 2 ... 
- [转]Creating Mailing Labels in SQL Server Reporting Services  (rdlc 数据1页 2竖排 显示)
		本文转自:http://blogs.wrox.com/article/creating-mailing-labels-in-sql-server-reporting-services/ Most wo ... 
- Integrating .NET Code and SQL Server Reporting Services
		SQL Server Reporting Services versions 2000 and 2005 (SSRS) has many powerful features. SSRS has a w ... 
- Incorporating ASP.NET MVC and SQL Server Reporting Services, Part 2
		In the last issue, I introduced you to the basics of incorporating SQL Server Reporting Services int ... 
随机推荐
- Cesium应用篇:1快速搭建
			范例中所有范例可以在Github中搜索:ExamplesforCesium Cesium ['siːzɪəm]是一款开源的JavaScript开源库,开发者通过Cesium,实现无插件的创建三维球和二 ... 
- Linux资源控制-CPU和内存
			主要介绍Linux下, 如果对进程的CPU和内存资源的使用情况进行控制的方法. CPU资源控制 每个进程能够占用CPU多长时间, 什么时候能够占用CPU是和系统的调度密切相关的. Linux系统中有多 ... 
- SqlServer基础之(触发器)
			概念: 触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触 ... 
- iOS 视图与视图层次结构(内容根据iOS编程)
			视图基础 视图是 UIView 对象,或者其子对象. 视图知道如何绘制自己. 视图可以处理事件,例如触摸(touch). 视图会按照层次结构排列,位于视图层次结构顶端的是应用窗口. 视图层次结构 任何 ... 
- Oracle 英文 非标准格式 日期 格式化
			最近在处理一张表的时候,需要按照日期排序,日期字段中日期的格式有两种. 格式一:07-Aug-2015 格式二:10/28/16 日期转化及格式化sql语句: select to_date('07-A ... 
- C# 之 DataReader 和 DataSet 的区别
			本文转载自:http://www.cnblogs.com/xinaixia/p/4920630.html 1. 获取数据的方式[1]DataReader 为在线操作数据, DataReader会一直占 ... 
- stm32 usart 异步传输示例
			STM32F103xE的USART异步数据传输示例 USART全称Universal Synchronous/Asynchronous Receiver/Transmitter,是一种可以进行同步/异 ... 
- Linux(二)__文件目录、常用命令
			一.linux下的文件目录 linux的文件系统是采用级层式的树状目录结构,在此结构中的最上层 是根目录"/",然后在此目录下再创建其他的目录 深刻理解linux文件目录是非常重要 ... 
- Xdebug文档(四)函数跟踪
			Xdebug能让你把所有函数调用,包括参数和返回值以不同的格式记录到文件中. 这些号称“函数跟踪”功能能帮助你面对一个新应用程序,亦或者在程序运行时你想弄清楚它在做什么.函数跟踪功能可以选择性地显示函 ... 
- Mvc与WebForm优缺点及Mvc的使用
			关于Mvc与WebForm的优缺点在网上的评论可谓不胜枚举,但脱离了我们的项目来谈这些意义就不大了.以我们这次改版来看,WebForm的优势有以下几点: 一,可以使用<#include>, ... 
