mysql存储过程

fdasf 2009-08-07 05:13:31
有一个存储过程,其中有一段代码是这样的:

PREPARE statement FROM
"SELECT p.product_id, p.name,
IF(LENGTH(p.description) <= ?,
p.description,
CONCAT(LEFT(p.description, ?),
'...')) AS description,
p.price, p.discounted_price, p.thumbnail
FROM product p
INNER JOIN product_category pc
ON p.product_id = pc.product_id
WHERE pc.category_id = ?
ORDER BY p.display DESC
LIMIT ?, ?";

我想问问
IF(LENGTH(p.description) <= ?,
p.description,
CONCAT(LEFT(p.description, ?),
'...'))
这部分该怎么理解?
...全文
58 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
fdasf 2009-08-07
  • 打赏
  • 举报
回复
查到了,原来是IF条件语句,相当于?:
fdasf 2009-08-07
  • 打赏
  • 举报
回复
查到了,原来是IF条件语句,相当于?:
fdasf 2009-08-07
  • 打赏
  • 举报
回复
?是占位符,以便参数替换,这是prepared statement啊。我就是不明白if条件语句中有逗号该怎么理解
cakexiang 2009-08-07
  • 打赏
  • 举报
回复
没这么写过,看到问号就先想到乱码,O(∩_∩)O~
llj480028 2009-08-07
  • 打赏
  • 举报
回复
帮顶!顺便学习了!

21,893

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧