Home > Microsoft .Net Development Tips > Microsoft SQL Server > A simple database access component
Win Development Tips:
EMAIL THIS
 TIPS & NEWSLETTERS TOPICS 

MICROSOFT SQL SERVER

A simple database access component


Yateen Thakkar
08.15.2003
Rating: -3.00- (out of 5)


Digg This!    StumbleUpon Toolbar StumbleUpon    Bookmark with Delicious Del.icio.us   


Please let other users know how useful this tip is by rating it below. Do you have a tip or code of your own you'd like to share? Submit it here.


We all use components and databases these days. Hence, I thought, why not make a generic component that everybody can use? Yes, you can actually use this component for database access. You can connect to any database with a valid connection string and pass any valid SQL statement. The method DataReader takes two arguments:

  1. DBString (the database connection string)
  2. SQL (the SQL statement)

The component returns to you an ADO DataReader, which you can databind to a ASP Datagrid. Here is the code for the component (DBAccess.cs):

Namespace DBAccess 
 { 
using System; 
using System.Data; 
using System.Data.ADO; public
class DBRead 

{ 
public ADODataReader DataReader(string DBStr,string
strSQL) 

{ 
  // Create the connection 
ADOConnection oCn = new ADOConnection(DBStr);
//Create the Command Object 
ADOCommand oCm =   new ADOCommand(strSQL,oCn);
//Open the connection 
oCn.Open(); 
//Create a null DataReader Object 
ADODataReader oDr ; 
//Execute the SQL Query 
oCm.Execute(out oDr); 
// Return the DataReader 
return oDr; 
} 
} 
}

You can compile the above code with the following command:

csc /r:System.Data.dll /t:library DBAccess.cs

We have imported the System.Data NameSpace in our component, now we need to give its reference. Here is the ASP.NET code (Client.aspx):

<%@Page language= "c#" AutoEventWireup="false" debug= "true" %>
<%@ Import NameSpace= "DBAccess"%>
<%@ Import NameSpace= "System.Data"%>
<%@ Import NameSpace= "System.Data.ADO"%> 
<script language=c#" runat="server" >
protected void Submit_OnClick(Object s, EventArgs e) 
{ 
// Create an instance of our component 
DBAccess.DBRead oDBr = new DBAccess.DBRead(); 
//Create a null DataReader 
ADODataReader oDr; 
// Use the DataReader Method of our component
oDr = oDBr.DataReader(dbstr.Text,SQL.Text); 
// DataBind the DataReader with the DataGrid 
oDg.DataSource = oDr; 
oDg.DataBind(); 
} 
</script>
<html>
<head> 
<meta name="GENERATOR" Content="Microsoft Visual Studio 7.0"> 
<meta name="CODE_LANGUAGE" Content="C#"> 
</head>
<body> 
<form method="post" runat="server"> 
DB String : <asp:textbox id="dbstr" runat="Server"/><br/> 
SQL Query : <asp:textbox id="SQL" runat="Server"/><br/> 
<asp:button text="Submit" runat="Server" onclick="Submit_OnClick"/> 
<br/> 
<ASP:DataGrid id="oDg" runat="server" 
BackColor="#ccccff" 
BorderColor="black" 
ShowFooter="false" 
CellPadding=3 
CellSpacing="0" 
Font-Size="9pt" 
HeaderStyle-BackColor="#aaafff" 
Headerstyle-font-bold 
/>
</form>
</body>
</html>

You don't have to separately compile the ASP.NET client. It automatically gets compiled with the first request. Happy coding!


Source: DotNetExtreme.com

Rate this Tip
To rate tips, you must be a member of SearchWinDevelopment.com.
Register now to start rating these tips. Log in if you are already a member.




Digg This!    StumbleUpon Toolbar StumbleUpon    Bookmark with Delicious Del.icio.us   



RELATED CONTENT
Microsoft SQL Server
Using the Visual Studio 2005 DataSet Designer to build a data access layer
The CTE, the hierarchical query and SQL Server 2005
SQL Server 2005 recursive functions and the CTE
Choose the right .NET data provider, optimize application performance
The fallacy of the data layer -- or, a new architectural model for software designs
Book excerpt: ADO.NET and SQL Server 2005
Addressing common SQL Server questions
Book Excerpt: The .NET Framework and SQL Server 2005
WinForms development using SQL Server 2005 and Visual Basic 2005
Configuring ASP.NET 2.0 apps to SQL Server 2005 databases

SQL Server and .NET development
Microsoft releases new CTP of Oslo SDK
Perpetuum unveils database synchronizer for .NET 2.0
The CTE, the hierarchical query and SQL Server 2005
SQL Server 2005 recursive functions and the CTE
SQL Examiner Suite synchronizes data schema, sets
Book excerpt: ADO.NET and SQL Server 2005
DataDirect database drivers now support MySQL
Top .NET tips of 2007 (so far)
Addressing common SQL Server questions
Book Excerpt: The .NET Framework and SQL Server 2005

RELATED RESOURCES
2020software.com, trial software downloads for accounting software, ERP software, CRM software and business software systems
Search Bitpipe.com for the latest white papers and business webcasts
Whatis.com, the online computer dictionary

DISCLAIMER: Our Tips Exchange is a forum for you to share technical advice and expertise with your peers and to learn from other enterprise IT professionals. TechTarget provides the infrastructure to facilitate this sharing of information. However, we cannot guarantee the accuracy or validity of the material submitted. You agree that your use of the Ask The Expert services and your reliance on any questions, answers, information or other materials received through this Web site is at your own risk.



Database Programming Solutions - .NET XML, Visual Studio LINQ, ORM .NET
About Us  |  Contact Us  |  For Advertisers  |  For Business Partners  |  Site Index  |  RSS
SEARCH 
TechTarget provides technology professionals with the information they need to perform their jobs - from developing strategy, to making cost-effective purchase decisions and managing their organizations' technology projects - with its network of technology-specific websites, events and online magazines.

TechTarget Corporate Web Site  |  Media Kits  |  Site Map




All Rights Reserved, Copyright 2000 - 2009, TechTarget | Read our Privacy Policy
  TechTarget - The IT Media ROI Experts