Blog信息 |
blog名称:注册会计师(注会)练习软件 日志总数:398 评论数量:116 留言数量:27 访问次数:3268851 建立时间:2005年6月6日 |

| |
[delpih编程]mygeneration做的一个模板,备忘 软件技术
吕向阳 发表于 2009/10/18 16:57:05 |
<%on error resume nextDim databaseDim objTableDim objColumnDim intLpDim bInFirstDim strProcNameDim bHasComputedDim strWhereClauseDim strWhereAndDim strWhereFieldsDim strCommaDim tableNamesDim tableNameDim bufferDim writeToDatabaseSet database = MyMeta.Databases(0)Set tableNames = input.Item("lstTables")writeToDatabase = input.Item("chkBox")%>unit uallclass;interfaceuses Windows, Messages;<%' Loop through the tables the user select and generate the stored procs and save them to diskFor intLp = 0 To tableNames.Count - 1Set objTable = database.Tables(tablenames.item(intLp))%>TYPE _<%output.writeLn(objTable.Alias) & "=CLASS" for Each objColumn in objTable.Columnsoutput.writeLn " " & TrimSpaces(objColumn.Name) & ":" & mydatatype(objColumn) & ";"Next%> public procedure clear;end;<% Next %>implementation<% For intLp = 0 To tableNames.Count - 1Set objTable = database.Tables(tablenames.item(intLp))%>procedure _<%=objtable.name%>.clear;begin<%for Each objColumn in objTable.Columnsoutput.writeLn " " & TrimSpaces(objColumn.Name) & ":=" & myfirst(objColumn) & ";"Next%>end;<% Next %>end;<%function mydatatype(objColumn) if ucase(objColumn.DataTypeNameComplete)="LONG" THEN mydatatype="long" exit function end if if ucase(objColumn.DataTypeNameComplete)="DECIMAL" THEN mydatatype="double" exit function end if if ucase(objColumn.DataTypeNameComplete)="TEXT" THEN mydatatype="string" exit function end if if ucase(objColumn.DataTypeNameComplete)="DATETIME" THEN mydatatype="tdatetime" exit function end if if ucase(objColumn.DataTypeNameComplete)="BIT" THEN mydatatype="boolean" exit function end if if ucase(objColumn.DataTypeNameComplete)="IEEESINGLE" THENmydatatype="single" exit function end if if ucase(objColumn.DataTypeNameComplete)="INTEGER" THEN mydatatype="integer" exit function end if if ucase(objColumn.DataTypeNameComplete)="IEEEDOUBLE" THENmydatatype="double" exit function end if mydatatype="string"end functionfunction myfirst(objColumn) if ucase(objColumn.DataTypeNameComplete)="LONG" THEN myfirst="" exit function end if if ucase(objColumn.DataTypeNameComplete)="DECIMAL" THEN myfirst="0" exit function end if if ucase(objColumn.DataTypeNameComplete)="TEXT" THEN myfirst="''" exit function end if if ucase(objColumn.DataTypeNameComplete)="DATETIME" THEN myfirst="1900-01-01" exit function end if if ucase(objColumn.DataTypeNameComplete)="BIT" THEN myfirst="true" exit function end if if ucase(objColumn.DataTypeNameComplete)="IEEESINGLE" THENmyfirst=0 exit function end if if ucase(objColumn.DataTypeNameComplete)="INTEGER" THEN myfirst="0" exit function end if if ucase(objColumn.DataTypeNameComplete)="IEEEDOUBLE" THENmyfirst="0" exit function end if myfirst="''"end functionFunction TrimSpaces(str)Dim tnameDim nameDim charDim lname = ""tname = strl = Len(tname)For j = 1 To lchar = Mid(tname, j, 1)If Not char = " " Thenname = name & charEnd IfNextTrimSpaces = nameEnd Function%> |
|
|