免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2464 | 回复: 9
打印 上一主题 下一主题

菜鸟求助 sybase sql 语法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-09-05 16:36 |只看该作者 |倒序浏览
麻烦大家给改下 谢谢了
select a.*,b.* from rl_unit_name a, (select user_id from rl_unit_name)b where a.id=b.id

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-09 06:20:00数据库技术版块每日发帖之星
日期:2015-11-03 06:20:00数据库技术版块每日发帖之星
日期:2016-02-20 06:20:00数据库技术版块每日发帖之星
日期:2016-07-13 06:20:00数据库技术版块每日发帖之星
日期:2016-07-31 06:20:00数据库技术版块每日发帖之星
日期:2016-08-01 06:20:00数据库技术版块每日发帖之星
日期:2016-08-18 06:20:00
2 [报告]
发表于 2012-09-05 16:47 |只看该作者
首先,rl_unit_name里面有id这个字段吗?如果有那么就写成
select a.*,b.* from rl_unit_name a, (select user_id from rl_unit_name)b where a.id=b.user_id

select a.*,b.user_id from rl_unit_name a, (select id,user_id from rl_unit_name)b where a.id=b.id

论坛徽章:
0
3 [报告]
发表于 2012-09-06 08:52 |只看该作者
本帖最后由 abbywl 于 2012-09-06 08:53 编辑

非常感谢2楼  可是这样写回报异常   Incorrect syntax near the keyword 'select'.
貌似sybase不支持 (select user_id from rl_unit_name)b 这样写
应该怎么写呢

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-09 06:20:00数据库技术版块每日发帖之星
日期:2015-11-03 06:20:00数据库技术版块每日发帖之星
日期:2016-02-20 06:20:00数据库技术版块每日发帖之星
日期:2016-07-13 06:20:00数据库技术版块每日发帖之星
日期:2016-07-31 06:20:00数据库技术版块每日发帖之星
日期:2016-08-01 06:20:00数据库技术版块每日发帖之星
日期:2016-08-18 06:20:00
4 [报告]
发表于 2012-09-06 09:53 |只看该作者
什么版本的?

论坛徽章:
0
5 [报告]
发表于 2012-09-06 10:47 |只看该作者
回复 1# abbywl


select a.*,b.user_id from rl_unit_name a,  rl_unit_name b where a.id=b.id


   

论坛徽章:
0
6 [报告]
发表于 2012-09-06 10:56 |只看该作者
本帖最后由 abbywl 于 2012-09-06 10:57 编辑

版本12.5,原语句是这样滴
select a.* from rl_unit_name a,
(select  max(un_name_date) un_name_date ,un_inner_code from rl_unit_name group by un_inner_code) b where
a.un_inner_code=b.un_inner_code and a.un_name_date=b.un_name_date
报错Incorrect syntax near the keyword 'select'.

论坛徽章:
0
7 [报告]
发表于 2012-09-06 11:02 |只看该作者
回复 6# abbywl


    版本12.5,原语句是这样滴
select a.* from rl_unit_name a,
(select  max(un_name_date) un_name_date ,un_inner_code from rl_unit_name group by un_inner_code) b where
a.un_inner_code=b.un_inner_code and a.un_name_date=b.un_name_date
报错Incorrect syntax near the keyword 'select'.



select a.* from  rl_unit_name a  where  a.un_inner_code in (select   max(un_name_date)  from   rl_unit_name group by un_inner_code ))

论坛徽章:
0
8 [报告]
发表于 2012-09-06 11:28 |只看该作者
还是不行呀

论坛徽章:
0
9 [报告]
发表于 2012-09-06 11:33 |只看该作者
回复 8# abbywl


    select a.* from  rl_unit_name a  where  a.un_inner_code in (select   max(un_name_date)  from   rl_unit_name group by un_inner_code )

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-09 06:20:00数据库技术版块每日发帖之星
日期:2015-11-03 06:20:00数据库技术版块每日发帖之星
日期:2016-02-20 06:20:00数据库技术版块每日发帖之星
日期:2016-07-13 06:20:00数据库技术版块每日发帖之星
日期:2016-07-31 06:20:00数据库技术版块每日发帖之星
日期:2016-08-01 06:20:00数据库技术版块每日发帖之星
日期:2016-08-18 06:20:00
10 [报告]
发表于 2012-09-06 14:18 |只看该作者
派生表是得在ASE15里面才有的,你这12.5是还没有
select a.* from rl_unit_name a,
(select  max(un_name_date) un_name_date ,un_inner_code from rl_unit_name group by un_inner_code) b where
a.un_inner_code=b.un_inner_code and a.un_name_date=b.un_name_date
可以写成
select * from rl_unit_name
group by un_inner_code
having un_name_date=max(un_name_date)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP