文章详情页
java - sql性能和高并发的取舍问题
浏览:156日期:2023-11-25 11:16:25
问题描述
SELECT
S.carOwnerID ,S.name,S.mobile,S.coopName,S.VIN,s.policyNO,S.effectiveDate,S.expiryDate,s.plateNo,( CASE WHEN s.num > 1 THEN1 WHEN s.num = 1 THEN0 END) AS carState FROM( SELECTc.carOwnerID,c.name,c.mobile,c.coopName,c.VIN,p.policyNO,p.effectiveDate,p.expiryDate,c.plateNo,count(p.PlateNo) AS num FROMcustomer C LEFT JOIN policy P ON C.carOwnerID = P.carOwnerID WHEREdate_add( P.createTime, INTERVAL 11.5 HOUR) > NOW()) s WHEREs.num > 0;
简单的用多表关联是可以的,如果遇到高并发,性能缺陷立即就出来
问题解答
回答1:多表关联并不意味着sql高性能,太复杂的SQL效率损耗并不比外部锁等低,跟高并发也没什么冲突。
建议把语句拆成简单语句,使用锁和补偿机制来保障事务性。
标签:
java
相关文章:
1. 在应用配置文件 app.php 中找不到’route_check_cache’配置项2. 在mac下出现了两个docker环境3. PHP类属性声明?4. win下面的cmder中的vim . 中文乱码. 试了百度上的各种解决方式.. 还是没弄好5. pdo 写入到数据库的内容为中文的时候写入乱码6. html按键开关如何提交我想需要的值到数据库7. PHPExcel表格导入数据库怎么导入8. win10系统 php安装swoole扩展9. html5 - 两个宽高一样的盒子重叠后旋转一定角度,为什么会看到下面的盒子10. html - 关于bootstrap中container、row、col的应用
排行榜
