ASP Code
  Home arrow ASP Code arrow DB Tables Backup using ASP, OO4O and Oracl...
ASP Free Forums 
.NET  
ASP  
ASP Code  
ASP.NET  
ASP.NET Code  
BrainDump  
C#  
Code Examples  
Database  
Database Code  
IIS  
Microsoft Access  
MS SQL Server  
Silverlight  
Visual Basic.NET  
Windows Scripting  
Windows Security  
XML  
Mobile Linux 
App Generation ROI 
IBM® developerWorks 
ASP Web Hosting  
ASP.NET Web Hosting 
Windows Web Hosting
 
Weekly Newsletter
 
Developer Updates  
Free Website Content 
 RSS  Articles
 RSS  Forums
 RSS  All Feeds
Write For Us Get Paid 
Request Media Kit
Contact Us 
Site Map 
Privacy Policy 
Support 
 USERNAME
 
 PASSWORD
 
 
  >>> SIGN UP!  
  Lost Password? 
ASP CODE

DB Tables Backup using ASP, OO4O and Oracle's Export Utility by Jenny Corpus
By: aspfree
  • Search For More Articles!
  • Disclaimer
  • Author Terms
  • Rating: 4 stars4 stars4 stars4 stars4 stars / 2
    2001-09-05

    Table of Contents:

    Rate this Article: Poor Best 
      ADD THIS ARTICLE TO:
      Del.ici.ous Digg
      Blink Simpy
      Google Spurl
      Y! MyWeb Furl
    Email Me Similar Content When Posted
    Add Developer Shed Article Feed To Your Site
    Email Article To Friend
    Print Version Of Article
    PDF Version Of Article
     
     
    ADVERTISEMENT


    DB Tables Backup using ASP, OO4O and Oracle's Export Utility
    by Jenny Corpus

    This is a simple ASP program that allows the user to create
    a backup copy of a DB user's tables. It uses Oracle Objects for OLE (OO4O)
    for database access to Oracle and for the backup function, Oracle's
    Export Utility program is used. 
    This code assumes that the web server has the following installations:
    1.Oracle Net8
    2.Oracle Object for OLE

    Here is the code:

    '************** Start**********************'
    File: Export.asp
    <%@ Language=VBScript %>
    <%Option Explicit%>
    <%

    dim OraDatabase 'Oracle Database object
    dim OraDynaset 'Oracle Dynaset object

    dim sExpPath 'physical path of Export program in the web server
    dim sExpFileNm 'physical path and file name of the Export file to be created
    'physical path must be existing in the web server


    sExpPath = "d:\oracle\ora817\bin\exp.exe" 'set the location of the export program
    sExpFileNm = "d:\Test\EXPDAT.DMP" 'set the name of the Export file to be created

    'Main Procedure
    Sub Main()

    if Request.Form("hidSubmit")="1" then 'Check if the form is submitted
    Call DoExport() 'Execute Export program
    end if

    Call Header() 'Write the Header
    Call Body() 'Write the Body
    Call Footer() 'Write the Footer

    End Sub

    'Export Procedure
    Sub DoExport()
    Dim nCount 'number of rows
    Dim nCtr 'counter for the loop
    Dim sTabList 'list of selected Tables to be exported
    Dim sTabNm 'selected Table Name

    nCount = int(Request.Form("hidCount")) 'Get the total number of rows

    'Check each checkbox of it is selected
    For nCtr=1 to nCount
    if Request.Form("chkExport" & nCtr) = "on" then 'Check if checkbox is checked
    sTabNm = Request.Form("hidTabNm" & nCtr) 'Get the selected Table Name
    sTabList = sTabList & "," & sTabNm 'Place selected name in the list of tables to be exported
    end if
    next

    sTabNm = Right(sTabList, Len(sTabList) - 1) 'Remove the comma at the start of the list

    Call ExportTables(sTabList) 'Export the tables

    End Sub

    '********************************
    'Execute the Export program
    Sub ExportTables(sTabNm)
    dim wsh 'WScript object
    dim sCommand 'Export command
    dim sConnection 'DB connection string

    'Make the DB Connection string
    sConnection = AppDic("UserName") & "/" & AppDic("Password") & "@" & AppDic("DBName")

    'Create the Export command
    sCommand = sExpPath & " " & sConnection & " tables=" & sTabNm & " File=" & sExpFileNm

    'Create the WScript Object
    set wsh = server.createobject("WScript.Shell")

    'Run the Export command
    wsh.run sCommand 

    End Sub
    '*********************************

    'Writes the HTML Header
    Sub Header()
    %>
    <HTML>
    <HEAD>
    <meta HTTP-EQUIV="Content-Type" content="text/html; charset=iso-8859-1">
    </HEAD>
    <SCRIPT language=javascript>

    //Checks or Unchecks all the checkboxes
    function CheckAll()
    {
    var nCount;
    var sChkName;
    var nCheck

    nCount = document.forms[0].hidCount.value;
    if (document.forms[0].btnCheck.value=="Check")
    {
    nCheck=1;
    document.forms[0].btnCheck.value="UnCheck";
    }
    else
    {
    nCheck=2;
    document.forms[0].btnCheck.value="Check";
    };

    for (var i=1; i <= nCount; i++)
    {
    sChkName="chkExport" + i;
    if (nCheck==1)
    {
    document.forms[0].item(sChkName).checked=true;
    }
    else
    {
    document.forms[0].item(sChkName).checked=false;
    };
    };
    };

    //submit form
    function Export()
    {
    document.forms[0].hidSubmit.value=1;
    document.forms[0].method='POST';
    document.forms[0].submit();
    };
    </SCRIPT>
    <BODY>
    <%
    End Sub

    'Retrieve tables of user from DB
    Function GetResults
    Dim sqlStatement 

    ' Get the reference to the OraDatabase object from the pool
    set OraDatabase = OraSession.getDatabaseFromPool(10)

    if Oradatabase is nothing then 'Check if connection is successful
    GetResults=-1
    Exit Function
    else
    'Make the select statement
    sqlStatement = "SELECT table_name, tablespace_name FROM user_tables " 

    'Execute the select statement, store it in the Dynaset
    set OraDynaset = OraDatabase.CreateDynaset(sqlStatement, cint(0))
    if OraDynaset.RecordCount < 1 then 'Check if there are records retrieved
    GetResults=-2
    Exit Function
    else
    GetResults=1
    End if
    end if

    End Function

    'Displays error message on the HTML
    Sub DisplayError(nError)
    Dim strWrite

    Select Case nError
    Case -1
    strWrite="No Connection."
    Case -2
    strWrite="No records retrieved"
    end select

    Response.Write strWrite

    End Sub

    'Displays the retrieved rows in an HTML table
    Sub DisplayTable()
    dim strWrite 'string to write
    dim nCount 'Number of rows retrieved

    %>
    <FORM Method=POST >
    <TABLE border=1>
    <TR>
    <TD><INPUT type='button' name="btnCheck" value="Check" onclick="Javascript:CheckAll()"></TD>
    <TD nowrap> Table Name </TD>
    <TD nowrap> Tablespace Name </TD>
    </TR>
    <%
    nCount = 0
    Do Until OraDynaset.EOF
    nCount = nCount + 1
    strwrite = "<TR>" 
    strwrite = strwrite & "<TD nowrap><INPUT type='hidden' name='hidTabNm" & nCount &"' value=" & OraDynaset.Fields("table_name") & ">" 
    strwrite = strwrite & "<INPUT type='checkbox' name='chkExport" & nCount & "' ></TD>"
    strwrite = strwrite & "<TD nowrap>" & OraDynaset.Fields("table_name") & "</TD>"
    strwrite = strwrite & "<TD nowrap>" & OraDynaset.Fields("tablespace_name") & "</TD>"
    strwrite = strwrite & "</TR>" & chr(13) & chr(10)
    Response.Write strWrite

    OraDynaset.MoveNext
    Loop

    %>
    </TABLE>
    <BR>
    <INPUT type='button' name='btnExport' value="Export" onclick="JavaScript:Export()">
    <INPUT type='hidden' name='hidSubmit' value=0>
    <INPUT type='hidden' name='hidCount' value=<%=nCount%> >
    </FORM>

    <%

    End Sub


    'Displays the Body of the HTML
    Sub Body()
    Dim nRet 'Return value from GetResults(); 1=OK, -1 or -2=ERROR

    'Get the rows from DB 
    nRet=GetResults()
    If nRet <> 1 then 'Check if there is an error
    Call DisplayError(nRet)
    else
    Call DisplayTable
    end if

    End Sub

    'Writes the Footer of the HTML
    Sub Footer()

    'Set the Oracle objects to nothing
    Set OraDatabase=Nothing
    Set OraDynaset=Nothing

    %>
    </BODY>
    </HTML>
    <%
    End sub


    '****START of server-side procedures****
    Call Main()

    %>
    '************** End********************'


    '************** Start**********************'
    'File: Global.asa

    <OBJECT RUNAT="Server" SCOPE="Application" ID="AppDic" PROGID="Scripting.Dictionary"></OBJECT>
    <OBJECT RUNAT=Server SCOPE=Application ID=OraSession PROGID="OracleInProcServer.XOraSession"></OBJECT>
    <SCRIPT LANGUAGE=VBScript RUNAT=Server> 

    Sub Application_OnStart
    AppDic.Add "DBName","orcl" 'Registered service name in the SQL Net
    AppDic.Add "UserName","scott" 'User name
    AppDic.Add "Password","tiger" 'Password

    OraSession.CreateDatabasePool 20, 100, 600, AppDic("DBName"), AppDic("UserName") & "/" & AppDic("Password"), 0


    End Sub

    Sub Application_OnEnd

    'Destroys global pool of connections.
    OraSession.DestroyDatabasePool 

    End Sub

    </SCRIPT>


    DISCLAIMER: The content provided in this article is not warranted or guaranteed by Developer Shed, Inc. The content provided is intended for entertainment and/or educational purposes in order to introduce to the reader key ideas, concepts, and/or product reviews. As such it is incumbent upon the reader to employ real-world tactics for security and implementation of best practices. We are not liable for any negative consequences that may result from implementing any information covered in our articles or tutorials. If this is a hardware review, it is not recommended to open and/or modify your hardware.

    More ASP Code Articles
    More By aspfree

     

    IBM® developerWorks developerWorks - FREE Tools!


    NEW! Accelerating Software Innovation on i on Power Systems

    Attend this launch webcast with Scott Hebner, Vice President of IBM Rational Marketing and Strategy, for an overview of Rational’s new software offerings and resources to help modernize and accelerate software innovation on i on Power Systems – while ensuring past application investments are protected and continue to grow. Learn how these solutions are helping customers extend their core i5/OS solutions toward modern architectures such as SOA and web technologies to deliver business improvements that stand the test of time.
    FREE! Go There Now!


    NEW! Build Web services with transport-level security using Rational Application Developer V7, Part 1: Build Web services and Web services clients

    Build secure Web services with transport-level security using IBM Rational Application Developer V7 and IBM WebSphere Application Server V6.1. Follow this three-part series for step-by-step instructions about how to develop Web services and clients, configure HTTP basic authentication, and configure HTTP over SSL (HTTPS). This first part of the series walks you through building a Web service for a simple calculator application. You generate and test two different types of Web services clients: a Java Platform, Enterprise Edition (Java EE) client and a stand-alone Java client. You also handle user-defined exceptions in Web services.
    FREE! Go There Now!


    NEW! Don't wait! Try the Rational Application Developer (RAD) v7.5 open beta code today

    Download the Rational Application Developer (RAD) v7.5 open beta code and start developing applications for the JEE5 standard which features EJB3.0, JPA, JSF 1.2, JSP 2.1 and Servlet 2.5 standards. When you use this beta you will see how you can increase developer productivity for already existing applications with improved support for refactoring, as well as adding new features to existing applications. In addition, the beta provides tooling for JD Edwards, Oracle, SAP, Siebel and PeopleSoft to improve the developer productivity with these enterprise systems.
    FREE! Go There Now!


    NEW! Evaluate IBM Rational Developer for System i V7.1

    Download a free trial version of IBM Rational Developer for System i V7.1, which provides a complete development environment for traditional i5/OS application development. IBM Rational Developer for System i is a new eclipse-based workstation offering for i5/OS application development that provides a comprehensive Integrated Development Environment for edit/compile/debug of traditional RPG/COBOL/C/C++ i5/OS applications.
    FREE! Go There Now!


    NEW! Evaluate WebSphere Extended Deployment Compute Grid V6.1

    Visit IBM developerWorks to download a free trial version of WebSphere Extended Deployment Compute Grid, which lets you schedule, execute, and monitor batch jobs. Because online transaction processing and batch jobs execute simultaneously on the same server resources, you can avoid costly duplication of resources. Compute Grid supports job types of Java transactional batch, compute-intensive and a new type called "native execution", which enables non-Java workloads to run on distributed end points.
    FREE! Go There Now!


    NEW! IBM Rational Systems Development e-Kit

    As systems increase in complexity, communication between systems and software teams becomes more and more difficult. Now, there’s a way to improve product quality and communication.<br />Read the “Model Driven Systems Development” white paper to see how. Also included in this kit are more educational white papers, customer examples, tutorials, informative Webcasts, and best practices for designing, building and managing systems.<br />
    FREE! Go There Now!


    NEW! Software Change and Configuration Management Solution Guidelines

    This whitepaper provides areas to consider when evaluating any software configuration management solution. It addresses how the IBM solutions (Rational ClearCase and Rational ClearQuest) meet the needs and requirements of both project leaders and developers to provide successful Software Change and Configuration Management.
    FREE! Go There Now!


    NEW! Trial download: IBM Lotus Forms V3.0

    Get a free trial download of IBM Lotus Forms V3.0 (formerly Workplace Forms), which provides a zero-footprint eForms solution to help you automate and move forms-based business processes off the desktop and onto the Web. With Lotus Forms, you can extend applications beyond the firewall by creating a single electronic form document ready for use in both thick and Web 2.0 thin client format.
    FREE! Go There Now!


    NEW! Trial download: IBM Rational Performance Tester V7.0.1

    Get a free trial download of the latest version of IBM Rational Performance Tester V7.0.1, a load and performance testing solution for teams concerned about the scalability of their Web-based applications. Combining multiple ease-of-use features with granular detail, Rational Performance Tester simplifies the test-creation, load-generation and data-collection processes that help teams ensure the ability of their applications to accommodate required user loads.
    FREE! Go There Now!


    NEW! Using Rational Business Developer to enhance your developer productivity

    Join this Rational Talks to You teleconference, to hear how Enterprise Generation Language (EGL) eliminates the need for tedious and error-prone low level coding, so developers can focus on business requirements. EGL extends the Rational software development platform with a simplified programming language that enables developers who have little or no experience with Java, Web technologies or Service Oriented Architecture, to create enterprise-class applications and services quickly and easily. It also allows developers who may have little or no mainframe programming experience to quickly create traditional mainframe components.
    FREE! Go There Now!



    All FREE IBM® developerWorks Tools!

    ASP CODE ARTICLES

    - ASP Forms
    - ASP: The Beginning
    - Getting Remote Files With ASP Continued
    - Inbox and Outbox Manipulation in ASP
    - Relational DropDownList Using VB.NET
    - Ad Tracking URL Hits
    - Use ViewState to display one record per page...
    - Send Email using ASP.NET formatted in HTML
    - ASP File Explorer
    - ASP/XML Interview questions by Srivatsan Sri...
    - Various methods of setting Date values to a ...
    - Conditional DataGrid Item and using checkbox...
    - Fill .NET Listbox with SQL DataReader
    - Filling Dropdown box using Code-Behinds in C#
    - FLAMES code sample written in .NET What is F...





    © 2003-2009 by Developer Shed. All rights reserved. DS Cluster 3 hosted by Hostway
    Stay green...Green IT