id, deleted, created, modified, name, order_id, financial, allot_type, client_manager_id, principal_id, department_id, assets_business_gener, entrust_again, clientele_type, clientele_id, clientele_sub_id, clientele_contact_id, security, significant_assets_reorganization, state_assets, foreign_assets_involved, dispense_benefit, bailor, bailor_address, bailor_contact_name, bailor_contact_tel, terminal_clientele_id, terminal_clientele_type, terminal_clientele_contact_id, members, remark SELECT (@i := @i + 1) AS id, assets.id AS assetsId, CASE WHEN reportInfo.assets_name IS NOT NULL THEN reportInfo.assets_name WHEN (SELECT assets_name FROM assets_production WHERE assets_production.production_no = nodeInfo.business_sub_id) IS NOT NULL THEN (SELECT assets_name FROM assets_production WHERE assets_production.production_no = nodeInfo.business_sub_id) ELSE assets.name END AS name, assets.order_id, assets_business_gener, allot_type, (SELECT production_no FROM assets_production WHERE assets_production.production_no = nodeInfo.business_sub_id) AS statementNo, (SELECT production_type FROM assets_production WHERE assets_production.production_no = nodeInfo.business_sub_id) AS productionType, reportInfo.production_no AS reportNo, reportInfo.repertory_state AS reportRepertoryState, reportInfo.delivery AS reportDelivery, reportInfo.assets_name AS reportName, clientele_id, customer.name AS customerName, bailor, bailor_contact_name, bailor_contact_tel, assets.created, ( SELECT SUM(estimated_value) FROM assets_evaluation_target WHERE assets_evaluation_target.assets_id = assets.id ) AS estimated_value, fund.id AS orderFundId, fund.should_amount, fund.real_amount, fund.discount, pFund.id AS productionFundId, pFund.standard_amount, pFund.production_should_amount, pFund.real_amount AS productionRealAmount, # invoice.real_amount AS invoiceRealAmount, (SELECT SUM(real_amount) FROM finance_invoice WHERE order_fund_id = fund.id AND finance_invoice.production_fund_id = pFund.id AND deleted = 0) AS invoiceRealAmount, #查询客户经理 (SELECT name FROM user WHERE id = assets.client_manager_id) AS clientManagerName, #查询项目负责人 (SELECT name FROM user WHERE id = assets.principal_id) AS principalName, #查询业务来源(即子级客户) (SELECT customer_company.name FROM customer_company WHERE customer_company.id = clientele_sub_id) AS customerSubName, nodeInfo.businessId, nodeInfo.currentNodeName, nodeInfo.currentNodeCode, nodeInfo.handlerName, nodeInfo.recordId, nodeInfo.currentNodeId, nodeInfo.handlerId FROM (SELECT @i := 0) AS sort,assets LEFT JOIN user ON user.id = assets.principal_id LEFT JOIN customer_company AS customer ON customer.id = assets.clientele_id LEFT JOIN order_fund AS fund ON fund.business_id = assets.id AND business_type = 'ASSET_BUSINESS' # LEFT JOIN finance_invoice AS invoice ON invoice.order_fund_id = fund.id #查询当前进行的节点信息 LEFT JOIN (SELECT nodeInstance.id AS currentNodeId, user.name AS handlerName, node.name AS currentNodeName, node.code AS currentNodeCode, nodeInstance.business_id AS businessId, nodeInstance.business_sub_id, nodeInstance.business_min_id, record.id AS recordId, record.handler_id AS handlerId FROM work_flow_node_instance AS nodeInstance, work_task_record AS record, user, work_node AS node WHERE (state = 'PENDING' OR( state = 'FINISHED' AND node.`code` = 'BUSINESS_ARCHIVING' )) AND nodeInstance.node_id = node.id AND record.handler_id = user.id AND nodeInstance.deleted = 0 AND record.instance_id = nodeInstance.id AND nodeInstance.business_type = 'ASSET_BUSINESS' ) AS nodeInfo ON nodeInfo.businessId = assets.id LEFT JOIN production_fund AS pFund ON pFund.order_fund_id = fund.id AND pFund.production_no = nodeInfo.business_min_id LEFT JOIN(SELECT production_no,repertory_state,production_type,delivery,assets_name FROM assets_production) AS reportInfo ON reportInfo.production_no = nodeInfo.business_min_id WHERE assets.deleted = 0 AND assets.client_manager_id = #{assetsSelectDTO.clientManagerId} #送达状态查询 AND reportInfo.delivery = #{assetsSelectDTO.delivery} #项目负责人查询 AND assets.principal_id = #{assetsSelectDTO.principalId} #关键字模糊查询 AND ( assets.order_id LIKE CONCAT('%',#{assetsSelectDTO.keyWord},'%') OR assets.name LIKE CONCAT('%',#{assetsSelectDTO.keyWord},'%') OR nodeInfo.business_sub_id LIKE CONCAT('%',#{assetsSelectDTO.keyWord},'%') OR nodeInfo.business_min_id LIKE CONCAT('%',#{assetsSelectDTO.keyWord},'%') OR customer.name LIKE CONCAT('%',#{assetsSelectDTO.keyWord},'%') ) AND assets.created BETWEEN #{assetsSelectDTO.startTime} AND #{assetsSelectDTO.endTime} AND assets.department_id = #{assetsSelectDTO.departmentId} ORDER BY assets.created DESC INSERT INTO business_number(id, take_type, business_type, year, month, next_no) VALUE (NULL, #{takeType}, #{businessType}, #{year}, #{month}, #{nextNo}) UPDATE business_number SET month = #{month}, next_no = #{nextNo} WHERE id = #{id} UPDATE assets SET name = #{assets.name}, assets_business_gener = #{assets.assetsBusinessGener}, entrust_again = #{assets.entrustAgain}, security = #{assets.security}, significant_assets_reorganization = #{assets.significantAssetsReorganization}, state_assets = #{assets.stateAssets}, foreign_assets_involved = #{assets.foreignAssetsInvolved}, dispense_benefit = #{assets.dispenseBenefit}, bailor = #{assets.bailor}, bailor_address = #{assets.bailorAddress}, bailor_contact_name = #{assets.bailorContactName}, bailor_contact_tel = #{assets.bailorContactTel} WHERE id = #{assets.id} AND deleted = 0