SELECT * FROM his_vn_his_pat_inhos_record WHERE dept_code =#{deptCode} AND DATE_FORMAT( enter_office_date, '%Y-%m-%d %H:%i:%s' ) > CASE WHEN NOW() < DATE_FORMAT(NOW(), '%Y-%m-%d 08:00:00') THEN DATE_SUB( DATE_FORMAT( NOW(), '%Y-%m-%d 07:00:00' ), INTERVAL 1 DAY ) ELSE DATE_FORMAT( NOW(), '%Y-%m-%d 07:00:00' ) END
时间: 2024-04-18 13:28:59 浏览: 10
这个 SQL 查询语句的目的是从 `his_vn_his_pat_inhos_record` 表中选取符合条件的记录。条件是 `dept_code` 字段等于给定的 `deptCode` 值,并且 `enter_office_date` 字段大于当前时间的某个特定时间。
特定时间的计算逻辑如下:
- 如果当前时间小于当天的08:00:00,则特定时间为当前时间的前一天的07:00:00;
- 否则特定时间为当天的07:00:00。
请注意,这个查询中使用了参数 `#{deptCode}`,你需要将其替换为实际的部门代码值。另外,这个查询使用了 MySQL 中的日期和时间函数,确保你所使用的数据库支持这些函数。
相关问题
优化sql SELECT DISTINCT rtr.rd_report_product_info_id AS rdReportProductInfoId , mar.machine_audit_result AS machineAuditResult,mar.machine_audit_result_desc AS machineAuditResultDesc FROM crm_rd_report_task_result rtr LEFT JOIN crm_rd_machine_audit_record mar ON rtr.dept_code = mar.dept_code AND rtr.belong_year = mar.belong_year AND rtr.belong_month = mar.belong_month WHERE mar.dept_code =#{deptCode} AND mar.belong_year = #{belongYear} AND mar.belong_month = #{belongMonth}
这是一条SQL查询语句,目的是从两个表中获取数据并进行优化。查询结果包括三个字段:rdReportProductInfoId、machineAuditResult和machineAuditResultDesc。其中,rdReportProductInfoId来自crm_rd_report_product_info表,而machineAuditResult和machineAuditResultDesc来自crm_rd_machine_audit_record表。这两个表通过LEFT JOIN连接起来,连接条件是dept_code、belong_year和belong_month。查询条件是mar.dept_code等于某个特定值。这条语句的目的是优化查询效率,提高查询速度。
写一个mysql8表值函数,传入字符串deptcode,返回sys_dept表中dept_code值为deptcode的结果集
CREATE FUNCTION getDeptByCode(deptcode VARCHAR(20))
RETURNS TABLE (dept_id INT, dept_name VARCHAR(50), dept_code VARCHAR(20))
BEGIN
RETURN SELECT * FROM sys_dept WHERE dept_code = deptcode;
END;