方法一:
sql = "select {xxx} from student A,class B where A.class_id=B.id and A.id in {xxxx}" res = excute(sql)
方法二:
sql = "select * from student where id in {xxxx}" res = excute(sql) foreach(res as v){ sql2 = "select {xxx} from class where id = v[class_id]"; res2 = excute(sql2) res[xxx] = res2[xxx] }
很初级的问题,不过还是问一下
我之前对这种情况都是用方法一的,觉得没商量;
但最近发现有人用第二种方法,内部系统,访问量小,所以也没啥影响,但他说第一种会增加mysql压力,可能会造成mysql故障,我就怀有迟疑态度了。
请比较熟悉的人帮我分析一下,谢谢
回复内容:
方法一:
sql = "select {xxx} from student A,class B where A.class_id=B.id and A.id in {xxxx}" res = excute(sql)
方法二:
sql = "select * from student where id in {xxxx}" res = excute(sql) foreach(res as v){ sql2 = "select {xxx} from class where id = v[class_id]"; res2 = excute(sql2) res[xxx] = res2[xxx] }
很初级的问题,不过还是问一下
我之前对这种情况都是用方法一的,觉得没商量;
但最近发现有人用第二种方法,内部系统,访问量小,所以也没啥影响,但他说第一种会增加mysql压力,可能会造成mysql故障,我就怀有迟疑态度了。
请比较熟悉的人帮我分析一下,谢谢
这种问题的原则基本上就是如果能很简单地用 SQL 算,就在数据库算,然后缓存结果。
所以个人偏好方法一。
能用SQL算就在数据库里进行运算吧,= =难道自己写的php语句还会比SQL执行的运算效率高?不要把mysql想的太脆弱。
尽量简化代码,所以。。第一种。
第一种虽然说是Join查询,实际上只有一次访问数据库,加上索引不会慢
第二种肯定不会用,死伤~
第一种更简介明了,一般用第一种。
实际哪种性能更好会跟 student
和 class
两个表相对大小有关。
如果第二种方式系统负载低,其实可以把sql 优化成这样:
<code>sql = "select {xxx} from (select * from student where id in (1,2,3)) A,class B where A.class_id=B.id " </code>
如果class表的数据可以不每次从数据库查,全部缓存下来的话,第二种思想还可以。毕竟class不会太多
第一种里面有连接操作,DB在进行连接操作时很费劲(特别是表的记录很多时),而查询操作基本很快.
首先一个, 你的第二个sql 明显给的不对了. 在 程序中做join, 起码我们应该这么写:
伪码:
<code>sql = "select * from student where id in {xxxx}" res = excute(sql) string ids foreach(res as v){ // append v[class_id] to ids. } // ids is now like "1, 3, 4" sql2 = "select {xxx} from class where id in ( $ids )"; res2 = excute(sql2) </code>
这样只需要两次查询, 而你的实现明显 在黑 第二种 方式 啊.
关于在 sql里还是 在程序里做 join, High Performance Mysql 里有讨论, 第三版, 第六章, Complex Queries Versus Many Queries, 和 Join Decomposition 两节.
把 多表join 拆为 多个单表查询, 有以下优势(具体细节自己看书啦):
• Caching can be more efficient.
• Executing the queries individually can sometimes reduce lock contention.
• Doing joins in the application makes it easier to scale the database by placing tableson different servers.
• The queries themselves can be more efficient.
• You can reduce redundant row accesses.
• To some extent, you can view this technique as manually implementing a hashjoin instead of the nested loops algorithm MySQL uses to execute a join. A hash join might be more efficient.> undefined> undefined> undefined> undefined
额,显然是在用第一种啊
原因?
各位叔叔姐姐大爷大妈,求考虑下,sql的主要用途是干嘛的?
sql script的计算数量级是多少的?
excute 貌似不是T-SQL92规范中支持的吧?楼上说的没错,楼主绝对是高级黑
我想说,如何你想混合计算,那起码中间的foreach 返回值相关的东西,你丢该程序去干行吗
summary
如果这里你不选方法一,那你就当我什么都没说
不是偏好问题,是堆代码的原则性问题:1.先尽可能降低SQL文发行次数。 2.再优化SQL文执行效率。
方法二把发行SQL文写在循环代码里,是写代码的大忌,无论你做的东西有多么的轻量级。
PS:SQL文基本不可能有得不到的结果集,所以不要用多次发行SQL文的方式来解决查询结果集拼凑问题。
肯定不会用第二种,因为mysql再慢也比当前语言实现的快,而且查询在语句端更容易优化,sql更加容易维护。

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Dreamweaver CS6
視覺化網頁開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!