php读取数据库语句问题(新手)高手指点下

恋着宝贝的鱼 2010-08-13 04:08:40
我初学php请问下这个语句是什么意思?
$query = "Select arc.*,tp.defaultname,tp.namerule,from `#@__archives` arc left join `#@__arctype` tp on arc.typeid=tp.id WHERE FIND_IN_SET('f', arc.flag)>0 and arc.litpic<>'' order by pubdate desc limit 0,15";
其中tp是表名,defaultname是字段名对吗?
还有#@__archives` arc left join `#@__arctype` tp on arc.typeid=tp.id是什么意思?
还有这个FIND_IN_SET('f', arc.flag)>0 and arc.litpic<>'' order by pubdate desc limit 0,15";呢?
我初学php看见别人代码里写的,希望高手指点下哈。
...全文
131 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
恋着宝贝的鱼 2010-08-14
  • 打赏
  • 举报
回复
谢谢一楼的高手。
caizhuguanguan 2010-08-13
  • 打赏
  • 举报
回复
有点迷糊
Dleno 2010-08-13
  • 打赏
  • 举报
回复
其中tp是表名,defaultname是字段名对吗?

不是表名,是表的别名。(`#@__archives` arc left join `#@__arctype` tp
===============
还有`#@__archives` arc left join `#@__arctype` tp on arc.typeid=tp.id是什么意思?

left join左连;on arc.typeid=tp.id(即符合`#@__archives`.typeid=`#@__arctype`.id 的条件)
===============
还有这个FIND_IN_SET('f', arc.flag)>0 and arc.litpic<>'' order by pubdate desc limit 0,15";呢?

FIND_IN_SET(str,strlist)
假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。 这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。

mysql> SELECT FIND_IN_SET('b','a,b,c,d');

-> 2

21,893

社区成员

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

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