OO4O 関数


  Database オブジェクトの取得

  

Public Function GetDatabase( )

	Set OraDatabase	= OraSession.GetDatabaseFromPool(10)
	OraDatabase.LastServerErrReset

	Set GetDatabase = OraDatabase

End Function
  

  トランザクションの開始

  

Public Function BeginTran( OraDatabase )

	On Error Resume Next 
	OraDatabase.Session.BeginTrans
	if OraDatabase.Session.LastServerErr <> 0 then
		OraDatabase.Session.CommitTrans
		OraDatabase.Session.BeginTrans
	end if
	On Error Goto 0

End Function
  

  トランザクションの終了

  

Public Function CommitTran( OraDatabase )

	OraDatabase.Session.CommitTrans

End Function
  

  RollBack

  

Public Function RollbackTran( OraDatabase )

	OraDatabase.Session.Rollback

End Function
  

  SELECT文の実行

  

Public Function OraSelect( OraDatabase, ByRef OraDynaset, SqlQuery )

	Set OraDynaset	= OraDatabase.CreateDynaset(SqlQuery,2)
	if OraDynaset.EOF then
		OraSelect = False
	else
		OraSelect = True
	end if

End Function
  

  SQL文の実行

  

Public Function ExecuteSQL( OraDatabase, SQLCommand )

	On Error Resume Next 
	OraDatabase.ExecuteSQL( SQLCommand )
	if OraDatabase.LastServerErr <> 0 then
		ExecuteSQL = False
	else
		ExecuteSQL = True
	end if
	On Error Goto 0

End Function
  

  一時テーブルの作成(存在する場合はTRUNCATE)

  

Public Function CreateTmpTable( DefinePath, TableName )

	Dim	FileSystem
	Dim	FileHandle
	Set FileSystem	= Server.CreateObject( "Scripting.FileSystemObject" )

	TargetTableName = "ZT" & Session.SessionID & TableName

	Set OraDatabase = GetDatabase( )
	SqlQuery = "select TABLE_NAME from USER_TABLES where TABLE_NAME = " & Ss( TargetTableName )
	Set OraDynaset	= OraDatabase.CreateDynaset(SqlQuery,2)
	if OraDynaset.EOF then
		SqlUpdate = "CREATE TABLE " & TargetTableName & " ( "

		SourcePath = Server.MapPath( DefinePath )
		Set FileHandle = FileSystem.OpenTextFile( SourcePath, 1 )

		Do while FileHandle.AtEndOfStream <> True 
			LineString = FileHandle.ReadLine
			SqlUpdate = SqlUpdate & LineString & vbCrLf
		Loop

		FileHandle.Close

		SqlUpdate = SqlUpdate & " )"

		On Error Resume Next 
		OraDatabase.ExecuteSQL( SqlUpdate )
		if OraDatabase.LastServerErr <> 0 then
			CreateTmpTable = False
			Call Alert( "一時テーブルの作成に失敗しました" )
			Exit Function
		end if
		On Error Goto 0
	else
		SqlUpdate = "truncate table " & TargetTableName
		On Error Resume Next 
		OraDatabase.ExecuteSQL( SqlUpdate )
		if OraDatabase.LastServerErr <> 0 then
			CreateTmpTable = False
			Call Alert( "一時テーブルの初期化に失敗しました" )
			Exit Function
		end if
		On Error Goto 0
	end if

	CreateTmpTable = True

End Function
  

  インデックス付き一時テーブルの作成(存在する場合はTRUNCATE)

  

Public Function CreateTmpIdxTable( DefinePath, TableName, IdxColumns )

	Dim	FileSystem
	Dim	FileHandle
	Set FileSystem	= Server.CreateObject( "Scripting.FileSystemObject" )

	TargetTableName = "ZT" & Session.SessionID & TableName

	Set OraDatabase = GetDatabase( )
	SqlQuery = "select TABLE_NAME from USER_TABLES where TABLE_NAME = " & Ss( TargetTableName )
	Set OraDynaset	= OraDatabase.CreateDynaset(SqlQuery,2)
	if OraDynaset.EOF then
		SqlUpdate = "CREATE TABLE " & TargetTableName & " ( "

		SourcePath = Server.MapPath( DefinePath )
		Set FileHandle = FileSystem.OpenTextFile( SourcePath, 1 )

		Do while FileHandle.AtEndOfStream <> True 
			LineString = FileHandle.ReadLine
			SqlUpdate = SqlUpdate & LineString & vbCrLf
		Loop

		FileHandle.Close

		SqlUpdate = SqlUpdate & " )"

		On Error Resume Next 
		OraDatabase.ExecuteSQL( SqlUpdate )
		if OraDatabase.LastServerErr <> 0 then
			CreateTmpIdxTable = False
			Call Alert( "一時テーブルの作成に失敗しました" )
			Exit Function
		end if
		On Error Goto 0

		if IdxColumns <> "" then
			sToken = Split( IdxColumns, ":" )
			nToken = Ubound( sToken )
			For I = 0 to nToken
				SqlUpdate = "create index " & TargetTableName & "IDX" & I + 1 & " on " & TargetTableName
				SqlUpdate = SqlUpdate & " (" & sToken(I) & ")"
				On Error Resume Next 
				OraDatabase.ExecuteSQL( SqlUpdate )
				if OraDatabase.LastServerErr <> 0 then
					CreateTmpIdxTable = False
					Call Alert( "一時テーブルのインデックスの作成に失敗しました" )
					Exit Function
				end if
				On Error Goto 0
			Next
		end if

	else
		SqlUpdate = "truncate table " & TargetTableName
		On Error Resume Next 
		OraDatabase.ExecuteSQL( SqlUpdate )
		if OraDatabase.LastServerErr <> 0 then
			CreateTmpIdxTable = False
			Call Alert( "一時テーブルの初期化に失敗しました" )
			Exit Function
		end if
		On Error Goto 0
	end if

	CreateTmpIdxTable = True

End Function
  




yahoo  google  MSDN  MSDN(us)  WinFAQ  Win Howto  tohoho  ie_DHTML  vector  wdic  辞書  天気 


[Vsfuncs]
Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
24/04/20 03:57:56
InfoBoard Version 1.00 : Language=Perl

1 BatchHelper COMprog CommonSpec Cprog CprogBase CprogSAMPLE CprogSTD CprogSTD2 CprogWinsock Cygwin GameScript HTML HTMLcss InstallShield InstallShieldFunc JScript JScriptSAMPLE Jsfuncs LLINK OldProg OracleGold OracleSilver PRO PRObrowser PROc PROconePOINT PROcontrol PROftpclient PROjscript PROmailer PROperl PROperlCHAT PROphp PROphpLesson PROphpLesson2 PROphpLesson3 PROphpfunction PROphpfunctionArray PROphpfunctionMisc PROphpfunctionString PROsql PROvb PROvbFunction PROvbString PROvbdbmtn PROvbonepoint PROwebapp PROwin1POINT PROwinSYSTEM PROwinYOROZU PROwindows ProjectBoard RealPHP ScriptAPP ScriptMaster VBRealtime Vsfuncs a1root access accreq adsi ajax amazon argus asp aspSample aspVarious aspdotnet aw2kinst cappvariety centura ckeyword classStyle cmaterial cmbin cmdbapp cmenum cmlang cmlistbox cmstd cmstdseed cmtxt cs daz3d db dbCommon dbaccess dnettool dos download flex2 flex3 flex4 framemtn framereq freeWorld freesoft gimp ginpro giodownload google hdml home hta htmlDom ie9svg install java javaSwing javascript jetsql jquery jsp jspTest jspVarious lightbox listasp listmsapi listmsie listmsiis listmsnt listmspatch listmsscript listmsvb listmsvc memo ms msde mysql netbeans oraPlsql oracle oracleWiper oraclehelper orafunc other panoramio pear perl personal pgdojo pgdojo_cal pgdojo_holiday pgdojo_idx pgdojo_ref pgdojo_req php phpVarious phpguide plsql postgres ps r205 realC realwebapp regex rgaki ruby rule sboard sc scprint scquest sdb sdbquest seesaa setup sh_Imagick sh_canvas sh_dotnet sh_google sh_tool sh_web shadowbox shgm shjquery shvbs shweb sjscript skadai skywalker smalltech sperl sqlq src systemdoc tcpip tegaki three toolbox twitter typeface usb useXML vb vbdb vbsfunc vbsguide vbsrc vpc wcsignup webanymind webappgen webclass webparts webtool webwsh win8 winofsql wmi work wp youtube