// 5. %s - 字符串 $str = "這是用來測試的sprintf的字符串( %s )。今天消費了%f元。從鐘樓到小寨有%d站。上班"; $arg = '%s'; echo sprintf($str,$arg,6,5); //返回結果:這是用來測試的sprintf的字符串( %s )。今天消費了6.000000元。從鐘樓到小寨有5站。上班 至于其它的參數,大家可以試著測試一下.下面說一下這個函數的一些用途,比如我們在對一張數據表所有數據做多個字段更新時,如果使用循環更新的話,那是很耗費資源的,這里就要用到我們sprintf()函數了.在數據庫批量更新時,我一般采用 case then when end 的語法來做,基本語法如: 復制代碼 代碼如下:UPDATA table SET field = CASE id WHEN 1 THEN 'value1' WHEN 2 THEN 'value2' WHEN 3 THEN 'value3' END WHERE id IN (1,2,3) 上面的意思就是說,更新 table 設置 id = 1 的值為 value1, id = 2 的值為 value2 ,id = 3 的值為 value3,這樣參數上面的函數將sql語句結合成這樣SQL語句,只需一條SQL就可以進行批量更新,具體的方法為: 復制代碼 代碼如下://比如 id 對應的值為以下數組 $info = array(1= '張三',2= '李四',3= '王五'); $ids = implode(',',array_keys($info)) //獲取所有的ID字符串 //組合SQL $sql = "UPDATA user SET username = CASE id"; foreach($info as $id= $username){ $sql .= sprintf("WHEN %d THEN %s",$id,$username); } $sql .= "END WHERE id IN ($ids)"; // $model- query($sql)上面就可以完成批量更新的操作,后面的 where子句確保只有3行數據執行.希望本文所述對大家的PHP程序設計有所幫助。PHP教程