150 lines
8.8 KiB
JSON
150 lines
8.8 KiB
JSON
{
|
|
"Name": "View_项目统计信息",
|
|
"Columns": [
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "bigint",
|
|
"MaxLength": -1,
|
|
"Name": "项目ID",
|
|
"ColumnType": "System.Int64, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"DatabaseColumnType": "nvarchar",
|
|
"MaxLength": -1,
|
|
"Name": "项目标题",
|
|
"ColumnType": "System.String, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"DatabaseColumnType": "float",
|
|
"MaxLength": -1,
|
|
"Name": "项目预算工时",
|
|
"ColumnType": "System.Double, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"DatabaseColumnType": "float",
|
|
"MaxLength": -1,
|
|
"Name": "项目预算费用",
|
|
"ColumnType": "System.Double, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"DatabaseColumnType": "varchar",
|
|
"MaxLength": -1,
|
|
"Name": "工时核定方式",
|
|
"ColumnType": "System.String, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "float",
|
|
"MaxLength": -1,
|
|
"Name": "总计划工时",
|
|
"ColumnType": "System.Double, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "float",
|
|
"MaxLength": -1,
|
|
"Name": "总实际工时",
|
|
"ColumnType": "System.Double, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "float",
|
|
"MaxLength": -1,
|
|
"Name": "总核定工时",
|
|
"ColumnType": "System.Double, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "float",
|
|
"MaxLength": -1,
|
|
"Name": "总成本",
|
|
"ColumnType": "System.Double, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "int",
|
|
"MaxLength": -1,
|
|
"Name": "项目成员数",
|
|
"ColumnType": "System.Int32, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "int",
|
|
"MaxLength": -1,
|
|
"Name": "总任务数量",
|
|
"ColumnType": "System.Int32, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "int",
|
|
"MaxLength": -1,
|
|
"Name": "已完成任务数",
|
|
"ColumnType": "System.Int32, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.BindingColumn, ServerDesignerCommon",
|
|
"Required": true,
|
|
"DatabaseColumnType": "int",
|
|
"MaxLength": -1,
|
|
"Name": "未完成任务数",
|
|
"ColumnType": "System.Int32, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.FormulaColumn, ServerDesignerCommon",
|
|
"Formula": "[已完成任务数]&\"/\"&[总任务数量]",
|
|
"Name": "任务完成情况",
|
|
"ColumnType": "System.String, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.FormulaColumn, ServerDesignerCommon",
|
|
"Formula": "IF([已完成任务数]=0,0,[已完成任务数]/[总任务数量])",
|
|
"Name": "任务完成进度",
|
|
"ColumnType": "System.Int32, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.FormulaColumn, ServerDesignerCommon",
|
|
"Formula": "[总实际工时]&\"/\"&[总计划工时]",
|
|
"Name": "工时情况",
|
|
"ColumnType": "System.String, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.FormulaColumn, ServerDesignerCommon",
|
|
"Formula": "[总成本]&\"/\"&[项目预算费用]",
|
|
"Name": "费用成本情况",
|
|
"ColumnType": "System.String, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
},
|
|
{
|
|
"$type": "Forguncy.Model.Tables.FormulaColumn, ServerDesignerCommon",
|
|
"Formula": "[总核定工时]&\"/\"&[项目预算工时]",
|
|
"Name": "工时成本情况",
|
|
"ColumnType": "System.String, System.Private.CoreLib, Version=6.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e"
|
|
}
|
|
],
|
|
"ExternalDatabaseInfo": {
|
|
"ConnectionId": "业务表",
|
|
"SourceTableName": "View_项目统计信息",
|
|
"SourceTableSchema": "dbo",
|
|
"CreateViewSql": "SELECT\r\n p.[ID] AS [项目ID],\r\n p.[项目名称] AS [项目标题],\r\n p.[项目预算工时],\r\n p.[项目预算费用],\r\n\t\tp.[工时核定方式],\r\n ISNULL(计划工时.总计划工时, 0) AS [总计划工时],\r\n ISNULL(实际工时.总实际工时, 0) AS [总实际工时],\r\n\t\t(CASE p.[工时核定方式]\r\n\tWHEN '计划' THEN ISNULL(计划工时.总计划工时, 0)\r\n\tELSE ISNULL(实际工时.总实际工时, 0)\r\nEND) as 总核定工时,\r\n ISNULL(总成本.总成本, 0) AS [总成本],\r\n ISNULL(项目成员.成员数量, 0) AS [项目成员数],\r\n ISNULL(任务统计.总任务数量, 0) AS [总任务数量],\r\n ISNULL(已完成任务.已完成任务数, 0) AS [已完成任务数],\r\n ISNULL(未完成任务.未完成任务数, 0) AS [未完成任务数]\r\nFROM\r\n [dbo].[项目表] p\r\nLEFT JOIN (\r\n SELECT\r\n 项目ID,\r\n SUM(工时) AS 总计划工时\r\n FROM\r\n [dbo].[任务工时表]\r\n WHERE\r\n 工时类型 = '计划'\r\n GROUP BY\r\n 项目ID\r\n) 计划工时 ON p.ID = 计划工时.项目ID\r\nLEFT JOIN (\r\n SELECT\r\n 项目ID,\r\n SUM(工时) AS 总实际工时\r\n FROM\r\n [dbo].[任务工时表]\r\n WHERE\r\n 工时类型 = '实际'\r\n GROUP BY\r\n 项目ID\r\n) 实际工时 ON p.ID = 实际工时.项目ID\r\nLEFT JOIN (\r\n SELECT\r\n 项目ID,\r\n SUM(工时 * 时薪单价 * 提成系数) AS 总成本\r\n FROM\r\n [dbo].[任务工时表]\r\n WHERE\r\n 工时类型 IN (SELECT 工时核定方式 FROM [dbo].[项目表] WHERE ID = 项目ID)\r\n GROUP BY\r\n 项目ID\r\n) 总成本 ON p.ID = 总成本.项目ID\r\nLEFT JOIN (\r\n SELECT\r\n 项目ID,\r\n COUNT(DISTINCT 执行人) AS 成员数量\r\n FROM\r\n [dbo].[任务工时表]\r\n GROUP BY\r\n 项目ID\r\n) 项目成员 ON p.ID = 项目成员.项目ID\r\nLEFT JOIN (\r\n SELECT\r\n 项目ID,\r\n COUNT(ID) AS 总任务数量\r\n FROM\r\n [dbo].[任务表]\r\n GROUP BY\r\n 项目ID\r\n) 任务统计 ON p.ID = 任务统计.项目ID\r\nLEFT JOIN (\r\n SELECT\r\n 项目ID,\r\n COUNT(ID) AS 已完成任务数\r\n FROM\r\n [dbo].[任务表]\r\n WHERE\r\n 任务状态 = 2\r\n GROUP BY\r\n 项目ID\r\n) 已完成任务 ON p.ID = 已完成任务.项目ID\r\nLEFT JOIN (\r\n SELECT\r\n 项目ID,\r\n COUNT(ID) AS 未完成任务数\r\n FROM\r\n [dbo].[任务表]\r\n WHERE\r\n 任务状态 < 2\r\n GROUP BY\r\n 项目ID\r\n) 未完成任务 ON p.ID = 未完成任务.项目ID;",
|
|
"ViewInfo": {
|
|
"ViewName": "View_项目统计信息",
|
|
"IsUpdatable": true,
|
|
"QueryColumns": [
|
|
"项目ID"
|
|
]
|
|
}
|
|
},
|
|
"Indexes": [],
|
|
"Relations": []
|
|
} |