DB2临时表无法创建的解决方法

DB2临时表无法创建的问题的确很让我们头疼,下面就为您介绍一个解决DB2临时表无法创建问题的方法,希望对您学习DB2临时表方面能有所帮助。

  1. procedure TXXXForm.lc_procHandleStandard(strpo:string; xPOSEQ:Integer);//HXYADD----24/09/2010----  
  2. var  
  3. strFieldList:string;//A-JW-02-351101-01  
  4. begin  
  5. strFieldList:='XNAME VARCHAR(80),'#13#10  
  6.                +'XKIND VARCHAR(20),'#13#10  
  7.                +'ENAME VARCHAR(20),'#13#10  
  8.                +'CNAME VARCHAR(20),'#13#10  
  9.                +'XBIAO VARCHAR(80),'#13#10  
  10.                +'XCODE INTEGER,'#13#10  
  11.                +'XGRADE INTEGER ';  
  12. strTmpTableName:=lc_CreatTmpTable(strFieldList);  
  13. if strTmpTableName='' then  
  14. begin  
  15.     Messagebox(handle,'无法创建 [执行标准资料] 临时表﹗','提示信息',mb_Ok);  
  16.     Exit;  
  17. end;//*)  
  18. qry6.Close;  
  19. qry6.SQL.Clear;  
  20. qry6.SQL.Add('DELETE FROM '+strTmpTableName);  
  21. qry6.ExecSQL;  
  22.  
  23. qry6.Close;  
  24. qry6.SQL.Clear;  
  25. qry6.SQL.Add('INSERT INTO '+strTmpTableName);  
  26. qry6.SQL.Add('(XNAME,XKIND,ENAME,CNAME,XBIAO,XCODE,XGRADE)');  
  27. qry6.SQL.Add('SELECT VALUE(K.PROD_NAME,''''),');  
  28. qry6.SQL.Add('       CASE K.PROD_KIND WHEN 0 THEN ''0 原色产品'' ');  
  29. qry6.SQL.Add('            WHEN 1 THEN ''1 水洗产品'' ');  
  30. qry6.SQL.Add('         ELSE ''X 不分类'' END PROD_KIND,');  
  31. qry6.SQL.Add('       VALUE(A.COLOR_ENG_NAME,''''),');  
  32. qry6.SQL.Add('       VALUE(A.COLOR_CHN_NAME,''''),');  
  33. qry6.SQL.Add('       VALUE(K.ZHIXIN_BIAO,''''),');  
  34. qry6.SQL.Add('       K.S_CODE,');  
  35. qry6.SQL.Add('       A.COLOR_GRADE ');  
  36. qry6.SQL.Add(' FROM GSSAL.SAL_PO_DTLA A ');  
  37. qry6.SQL.Add(' LEFT JOIN GSSAL.SAL_PO X ON (X.PO_NO=A.PO_NO AND X.GEN_POSEQ=A.GEN_POSEQ) ');  
  38. qry6.SQL.Add(' LEFT JOIN GSSAL.SAL_KIND K ON (K.S_CODE=VALUE(A.PROD_CODE,X.PROD_CODE)) ');  
  39. qry6.SQL.Add(' WHERE A.PO_NO=:PO_NO AND A.GEN_POSEQ=:GEN_POSEQ');  
  40. qry6.SQL.Add('   AND VALUE(K.ISVALID,''N'')=''Y'' ');  
  41. qry6.SQL.Add(' ORDER BY K.PROD_NAME,A.COLOR_ENG_NAME ');  
  42. qry6.ParamByName('PO_NO').AsString:=strpo;  
  43. qry6.ParamByName('GEN_POSEQ').AsInteger:=xPOSEQ;  
  44. qry6.ExecSQL;  
  45. qry6.Close;  
  46. qry6.SQL.Clear;  
  47. qry6.SQL.Add('SELECT * ');  
  48. qry6.SQL.Add('FROM '+strTmpTableName);  
  49. qry6.Open;  
  50. end;  
  51. -----------------------------------------------------------------------------------------------------------------------------------   
  52. function TXXXForm.lc_CreatTmpTable(strFieldList:string):string;  
  53. var  
  54. strTableName:string;  
  55. blnSuccess:boolean;  
  56. i:integer;  
  57. function lc_funcCreatTable(strFieldList,strTableName: string):Boolean;  
  58. var  
  59.     qryCreatTemp:TQuery;  
  60. begin  
  61.     Result:=False;  
  62.     qryCreatTemp:=TQuery.Create(self);  
  63.     with qryCreatTemp do  
  64.     begin  
  65.       DatabaseName:='GSCOMDB';  
  66.       SQL.Clear;  
  67.       SQL.Add('CREATE TABLE '+strTableName+' ('+strFieldList+') IN USERSPACE1 ');  
  68.       try  
  69.         ExecSQL;  
  70.         Result:=True;  
  71.       except  
  72.       end;  
  73.     end;  
  74.     qryCreatTemp.Free;  
  75. end;  
  76. begin  
  77. Result:='';//如果创建不成功则返回空字符串。  
  78. strTableName:='GSTMP.TMP_'+FormatFloat('0',now*10000000)+'';  
  79. for i:=1 to 50 do//循环 50次﹐再不能创建则退出。  
  80. begin  
  81.     blnSuccess:=lc_funcCreatTable(strFieldList,strTableName);  
  82.     if blnSuccess then //如果创建成功则返回表名﹐同时退出。  
  83.     begin  
  84.       Result:=strTableName;  
  85.       Exit;  
  86.     end;  
  87. end;  
  88. end;  
  89. -----------------------------------------------------------------------------------------------------------------------------------   
  90. procedure TXXXForm.FormCloseQuery(Sender: TObject; var CanClose: Boolean);  
  91. begin  
  92. lstUser.Free;  
  93. if strTmpTableName<>'' then  
  94. begin  
  95.     lc_DeleteTable(strTmpTableName);  
  96.     strTmpTableName:='';  
  97. end;   
  98. end;  
  99. -----------------------------------------------------------------------------------------------------------------------------------   
  100. function TXXXForm.lc_DeleteTable(strTableName:string):Boolean;  
  101. var  
  102. qryDeleteTemp:TQuery;  
  103. begin  
  104. Result:=False;  
  105. qryDeleteTemp:=TQuery.Create(Self);  
  106. with qryDeleteTemp do  
  107. begin  
  108.     DatabaseName:='GSCOMDB';  
  109.     SQL.Clear;  
  110.     SQL.Add('DROP TABLE '+strTableName);  
  111.     try  
  112.       ExecSQL;  
  113.       Result:=True;  
  114.     except  
  115.     end;  
  116. end;  
  117. qryDeleteTemp.Free;  
  118. end;  
  119. -----------------------------------------------------------------------------------------------------------------------------------   

 

 

 

 

【编辑推荐】

带您了解DB2锁的类型

db2表空间被锁的解决方法

DB2添加验证约束的实现

DB2创建表空间的方式

Linux中DB2用户组的介绍

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/225578.html<

(0)
运维的头像运维
上一篇2025-04-16 23:25
下一篇 2025-04-16 23:27

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注