1一个整形的字段type,存的可能是600101,600102这样的数,判断它是不是以6001开头。
在postgresql8.2.5里,即使是integer,也可以直接like '6001%'来判断。在早期的
版本,报错。因此round(type/100)=6001来判断
2
1)因为要一个innerjoin的查询order by 其中一个表的create_time,select必须要把这个create_time写在select里,
2)如果把distinct写在下面语句的select从句里,而不要主的select,查询结果已经是join过的,会重复不准确,所以要如下
在postgresql8.2.5里,即使是integer,也可以直接like '6001%'来判断。在早期的
版本,报错。因此round(type/100)=6001来判断
2
1)因为要一个innerjoin的查询order by 其中一个表的create_time,select必须要把这个create_time写在select里,
2)如果把distinct写在下面语句的select从句里,而不要主的select,查询结果已经是join过的,会重复不准确,所以要如下
SELECT DISTINCT(qtype) as codeId FROM
(SELECT q.type as qtype,a.create_time as atime
FROM question as q,answer as a
WHERE a.question_id=q.question_id
and a.user_id=#userId#
order by a.create_time desc
) as lalala
limit 3
本文介绍了在PostgreSQL中如何对整型字段进行特定前缀的匹配操作,并讨论了不同版本间的兼容性问题。此外,还涉及了使用inner join进行查询时order by及distinct关键字的正确用法。
1751

被折叠的 条评论
为什么被折叠?



