SELECT TOP 10 tag_id, tag_code, RFID, storage_stock_id, material_id, material_code, data_status, material_name, spec, model, factory_name, supplier_id, supplier_name, lot_number, valid_to_date, material_type, pack_id, unit_code, unit, pack_type, sub_unit_code, sub_unit, dept_name, sub_conversion_rate, conversion_rate, status, original_barcode, udi, create_time, min_material_code, insurance_id, insurance_spec_code, order_in_code, order_in_id, is_used FROM ( SELECT ROW_NUMBER ( ) OVER ( ORDER BY create_time DESC ) PAGE_ROW_NUMBER, tag_id, tag_code, RFID, storage_stock_id, material_id, material_code, data_status, material_name, spec, model, factory_name, supplier_id, supplier_name, lot_number, valid_to_date, material_type, pack_id, unit_code, unit, pack_type, sub_unit_code, sub_unit, dept_name, sub_conversion_rate, conversion_rate, status, original_barcode, udi, create_time, min_material_code, insurance_id, insurance_spec_code, order_in_code, order_in_id, is_used FROM ( SELECT mt.tag_id, mt.tag_code, mt.RFID, mt.storage_stock_id, mss.material_id, mss.material_code, mt.data_status, mi.material_name, mi.spec, mi.model, mi.factory_name, mss.supplier_id, mss.supplier_name, mt.lot_number, mt.valid_to_date, mi.material_type, mss.pack_id, mss.unit_code, CASE WHEN mi.material_type = 'MAT-GZ' THEN mp.pack_unit ELSE mt.unit + '(' + CONVERT ( VARCHAR ( 10 ), mtd.quantity ) + mtd.unit + '/' + mt.unit + ')' END AS unit, mp.pack_type, mss.sub_unit_code, mss.sub_unit, sd.dept_name, mp.sub_conversion_rate, mp.conversion_rate, mt.status, mt.original_barcode, mt.udi, mt.create_time, mi.min_material_code, mi.insurance_id, mi.insurance_spec_code, mssd.order_in_code, mssd.order_in_id, mt.is_used FROM material_tag mt LEFT JOIN material_tag_detail mtd ON mtd.tag_id = mt.tag_id LEFT JOIN material_storage_stock_detail mssd ON mssd.stock_detail_id = mtd.stock_detail_id LEFT JOIN material_storage_stock mss ON mss.stock_id = mssd.storage_stock_id LEFT JOIN material_pack mp ON mp.pack_id = mss.pack_id LEFT JOIN material_info mi ON mi.material_id = mss.material_id LEFT JOIN sys_dept sd ON sd.dept_id = mss.store_dept_id LEFT JOIN material_storage_stock_batch mssb ON mssb.stock_id = mss.stock_id LEFT JOIN order_in oi ON oi.order_in_code = mssb.batch_no LEFT JOIN material_pack mpk ON mpk.material_id = mss.material_id AND mpk.is_purchase_unit = 1 WHERE mt.hospital_id = 1 AND mss.store_dept_id = 367 ) AS PAGE_TABLE_ALIAS ) AS PAGE_TABLE_ALIAS WHERE PAGE_ROW_NUMBER > 0 ORDER BY PAGE_ROW_NUMBER查询速度19秒如何添加索引
时间: 2024-04-07 16:28:08 浏览: 11
首先需要确定哪些字段经常被用作查询条件或者作为排序字段,可以根据实际情况来选择适合的字段添加索引。根据这个 SQL 查询语句,可以考虑添加以下索引:
1. `hospital_id`、`store_dept_id`、`status`、`create_time`:这几个字段都经常被用作查询条件,可以添加组合索引来提高查询速度。
2. `material_id`、`material_code`、`min_material_code`:这几个字段都涉及到物料信息,如果物料信息表很大,可以考虑单独为它们添加索引。
3. `tag_id`、`tag_code`、`RFID`:这几个字段都涉及到标签信息,如果标签信息表很大,可以考虑单独为它们添加索引。
4. `storage_stock_id`、`stock_detail_id`、`batch_no`、`order_in_id`、`order_in_code`:这几个字段都涉及到库存信息和订单信息,如果这些表很大,可以考虑单独为它们添加索引。
需要注意的是,添加索引会占用一定的磁盘空间和内存,还会对插入、更新和删除操作产生一定的影响,因此需要谨慎考虑。同时,如果添加了过多的索引,也会影响数据库性能,因此需要根据实际情况进行权衡和调整。
相关问题
select id from contract where sap_code = $,spa 哪里不对
这个 SQL 查询语句中,$ 和 spa 都是未定义的变量,应该在它们之前加上变量名或者具体的值。另外,如果 $ 是变量名,那么它应该用占位符 ? 替代,以避免 SQL 注入攻击。正确的 SQL 查询语句应该类似于:
```
SELECT id FROM contract WHERE sap_code = ?;
```
在执行查询之前,需要使用数据库驱动程序将占位符 ? 替换成具体的变量值。
select last_insert_id()用法
select last_insert_id() 是一个MySQL函数,用于获取最后插入的自增ID值。当我们向一个自增ID列插入一条新记录时,该函数可以返回该记录的自增ID值。例如,我们可以使用以下语句插入一条新记录并获取其自增ID值:
INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);
SELECT LAST_INSERT_ID();
这将返回最后插入记录的自增ID值。