楼主: zljwanzi25
1685 2

[问答] 这个程序怎么写可以有效节约程序运行空间 [推广有奖]

  • 0关注
  • 1粉丝

已卖:68份资源

博士生

52%

还不是VIP/贵宾

-

威望
0
论坛币
1775 个
通用积分
0
学术水平
0 点
热心指数
2 点
信用等级
0 点
经验
763 点
帖子
180
精华
0
在线时间
327 小时
注册时间
2006-11-22
最后登录
2021-12-6

楼主
zljwanzi25 发表于 2014-4-10 09:35:14 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
由于数据库过大,我在编程的时候经常遇到运行空间不足的问题,也就是运行过程中产生的过程数据库太多,严重占用了临时空间。比如我现在想把每个客户的最早交易时间取出来,涉及到5个数据库的链接问题,用data步来做,然后用sql来取最早的交易时间。我现在想把data步和sql 步合并到一个程序里,以减少临时空间的利用,该如何编程呢?具体程序示例如下:

data trans;
set a1 a2 a3 a4 a5;
run;

proc sql;
create table trans2 as
select id,min(trans_time) as firsttranstime;
from trans;
quite;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:proc sql Create Select Trans data步 create 数据库 程序 空间 如何

沙发
soporaeternus 发表于 2014-4-10 11:11:58
0 keep id trans_time
1 5个分开做,再汇总做一次,空间不够,时间来换。
2 估算下id的量,在set 5个数据可行的前提下用hash来做
Let them be hard, but never unjust

藤椅
bobguy 发表于 2014-4-12 11:31:50
It is a big problem.

The bottom line is to minimize the steps. Try to simplify your problem.

The solution for your problem would be simplified as,

proc sql;
  
  select sex, min (age)
  from  (
           select  age, sex from sashelp.class
           outer union corr
           select  age, sex from sashelp.class)

group by 1;

quit;

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-7 06:21