Heim  >  Artikel  >  Backend-Entwicklung  >  php sprintf函数用法例子教程

php sprintf函数用法例子教程

WBOY
WBOYOriginal
2016-07-25 08:52:321740Durchsuche
  1. // 1. %% :把 %% 替换成 %
  2. $str = '测试一下 %% 这个参数,会被替换成什么';
  3. echo sprintf($str);
  4. //返回结果: 测试一下 % 这个参数,会被替换成什么(%%被替换成一个%)
  5. // 2. %b :该参数只能替换整型数据,如果是浮点型,只会取整数部分,会忽略小数点后面的数据。如果是非整型数据。返回 0
  6. $str = '参数 %b 会替换成二进制数';
  7. $arg = '10';
  8. echo sprintf($str,$arg);
  9. //返回结果:参数 1010 会替换成二进制数
  10. $arg = 10.23;
  11. echo sprintf($str,$arg);
  12. //返回结果:参数 1010 会替换成二进制数
  13. $arg = 'abc';
  14. echo sprintf($str,$arg);
  15. //返回结果:参数 0 会替换成二进制数
  16. // 3. %c 返回字符编码的ASCII码
  17. $arg = 65;
  18. $str = "数字 {$arg} 对应的ASCII码为 %c ";
  19. echo sprintf($str,$arg);
  20. //返回结果:数字 65 对应的ASCII码为 A
  21. // 4. %d 将一段字符里的%d替换成int型,数据要求同 $b 相同
  22. $str = 'ID号为 %d ';
  23. $arg = -3;
  24. echo sprintf($str,$arg);
  25. //返回结果:ID号为 -3
  26. $arg = 4.5;
  27. echo sprintf($str,$arg);
  28. //返回结果:ID号为 4
  29. $arg = 'abc';
  30. echo sprintf($str,$arg);
  31. //返回结果:ID号为 0
  32. // 5. %s - 字符串
  33. $str = "这是用来测试的sprintf的字符串( %s )。今天消费了%f元。从钟楼到小寨有%d站。上班";
  34. $arg = '%s';
  35. echo sprintf($str,$arg,6,5);
  36. //返回结果:这是用来测试的sprintf的字符串( %s )。今天消费了6.000000元。从钟楼到小寨有5站。上班
复制代码

有关参数用法,测试: 在对一张数据表所有数据做多个字段更新时,如果使用循环更新的话,那是很耗费资源的,这里就要用到我们sprintf()函数了。 在数据库批量更新时,一般采用 case then when end 的语法来做,基本语法,例如:

  1. UPDATA table
  2. SET field = CASE id
  3. WHEN 1 THEN 'value1'
  4. WHEN 2 THEN 'value2'
  5. WHEN 3 THEN 'value3'
  6. END
  7. WHERE id IN (1,2,3)
复制代码

更新 table 设置 id = 1 的值为 value1, id = 2 的值为 value2 ,id = 3 的值为 value3,这样参数上面的函数将sql语句结合成这样SQL语句,只需一条SQL就可以进行批量更新

例子:

  1. //比如 id 对应的值为以下数组
  2. $info = array(1=>'张三',2=>'李四',3=>'王五');
  3. $ids = implode(',',array_keys($info)) //获取所有的ID字符串
  4. //组合SQL
  5. $sql = "UPDATA user SET username = CASE id";
  6. foreach($info as $id=>$username){
  7. $sql .= sprintf("WHEN %d THEN %s",$id,$username);
  8. }
  9. $sql .= "END WHERE id IN ($ids)";
  10. // $model->query($sql)
复制代码

以上可以完成批量更新的操作,其中where子句确保只有3行数据执行。



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn