- 浏览: 245666 次
- 性别:
- 来自: 天津
文章分类
最新评论
-
yulanlian:
...
实现在删除数据后,自增列的值连续 -
RonQi:
楼主写的很好,支持原创!
Google Protocol Buffers
1.C#连接连接Access
using System.Data; using System.Data.OleDb; .. string strConnection="Provider=Microsoft.Jet.OleDb.4.0;"; strConnection+=@"Data Source=C:BegASPNETNorthwind.mdb"; OleDbConnection objConnection=new OleDbConnection(strConnection); .. objConnection.Open(); objConnection.Close();
解释:
连接Access数据库需要导入额外的命名空间,所以有了最前面的两条using命令,这是必不可少的!
strConnection这个变量里存放的是连接数据库所需要的连接字符串,他指定了要使用的数据提供者和要使用的数据源.
"Provider=Microsoft.Jet.OleDb.4.0;"是指数据提供者,这里使用的是Microsoft Jet引擎,也就是Access中的数据引擎,asp.net就是靠这个和Access的数据库连接的.
"Data Source=C:\BegASPNET\Northwind.mdb"是指明数据源的位置,他的标准形式是"Data Source=MyDrive:MyPath\MyFile.MDB".
PS:
1."+="后面的"@"符号是防止将后面字符串中的"\"解析为转义字符.
2.如果要连接的数据库文件和当前文件在同一个目录下,还可以使用如下的方法连接:
strConnection+="Data Source=";
strConnection+=MapPath("Northwind.mdb");
这样就可以省得你写一大堆东西了!
3.要注意连接字符串中的参数之间要用分号来分隔.
"OleDbConnection objConnection=new OleDbConnection(strConnection);"这一句是利用定义好的连接字符串来建立了一个链接对象,以后对数据库的操作我们都要和这个对象打交道.
2.C#连接SQL Server
using System.Data; using System.Data.SqlClient; .. string strConnection="user id=sa;password=;"; strConnection+="initial catalog=Northwind;Server=YourSQLServer;"; strConnection+="Connect Timeout=30"; SqlConnection objConnection=new SqlConnection(strConnection); .. objConnection.Open(); objConnection.Close();
解释:
连接SQL Server数据库的机制与连接Access的机制没有什么太大的区别,只是改变了Connection对象和连接字符串中的不同参数.
首先,连接SQL Server使用的命名空间不是"System.Data.OleDb",而是"System.Data.SqlClient".
其次就是他的连接字符串了,我们一个一个参数来介绍(注意:参数间用分号分隔):
"user id=sa":连接数据库的验证用户名为sa.他还有一个别名"uid",所以这句我们还可以写成"uid=sa".
"password=":连接数据库的验证密码为空.他的别名为"pwd",所以我们可以写为"pwd=".
这里注意,你的SQL Server必须已经设置了需要用户名和密码来登录,否则不能用这样的方式来登录.如果你的SQL
Server设置为Windows登录,那么在这里就不需要使用"user
id"和"password"这样的方式来登录,而需要使用"Trusted_Connection=SSPI"来进行登录.
"initial catalog=Northwind":使用的数据源为"Northwind"这个数据库.他的别名为"Database",本句可以写成"Database=Northwind".
"Server=YourSQLServer":使用名为"YourSQLServer"的服务器.他的别名为"Data
Source","Address","Addr".如果使用的是本地数据库且定义了实例名,则可以写为"Server=(local)\实例名";如果
是远程服务器,则将"(local)"替换为远程服务器的名称或IP地址.
"Connect Timeout=30":连接超时时间为30秒.
在这里,建立连接对象用的构造函数为:SqlConnection.
3.C#连接Oracle
using System.Data.OracleClient; using System.Data; //在窗体上添加一个按钮,叫Button1,双击Button1,输入以下代码 private void Button1_Click(object sender, System.EventArgs e) { string ConnectionString="Data Source=sky;user=system;password=manager;";//写连接串 OracleConnection conn=new OracleConnection(ConnectionString);//创建一个新连接 try { conn.Open(); OracleCommand cmd=conn.CreateCommand(); cmd.CommandText="select * from MyTable";//在这儿写sql语句 OracleDataReader odr=cmd.ExecuteReader();//创建一个OracleDateReader对象 while(odr.Read())//读取数据,如果odr.Read()返回为false的话,就说明到记录集的尾部了 { Response.Write(odr.GetOracleString(1).ToString());//输出字段1,这个数是字段索引,具体怎么使用字段名还有待研究 } odr.Close(); } catch(Exception ee) { Response.Write(ee.Message); //如果有错误,输出错误信息 } finally { conn.Close(); //关闭连接 } }
4.C#连接MySQL
using MySQLDriverCS; // 建立数据库连接 MySQLConnection DBConn; DBConn = new MySQLConnection(new MySQLConnectionString("localhost","mysql","root","",3306).AsString); DBConn.Open(); // 执行查询语句 MySQLCommand DBComm; DBComm = new MySQLCommand("select Host,User from user",DBConn); // 读取数据 MySQLDataReader DBReader = DBComm.ExecuteReaderEx(); // 显示数据 try { while (DBReader.Read()) { Console.WriteLine("Host = {0} and User = {1}", DBReader.GetString(0),DBReader.GetString(1)); } } finally { DBReader.Close(); DBConn.Close(); } //关闭数据库连接 DBConn.Close();
5.C#连接IBM DB2
OleDbConnection1.Open(); //打开数据库连接 OleDbDataAdapter1.Fill(dataSet1,"Address"); //将得来的数据填入dataSet DataGrid1.DataBind(); //绑定数据 OleDbConnection1.Close(); //关闭连接 //增加数据库数据 在Web Form上新增对应字段数量个数的TextBox,及一个button,为该按键增加Click响应事件代码如下: this.OleDbInsertCommand1.CommandText = "INSERTsintosADDRESS(NAME, EMAIL, AGE, ADDRESS) VALUES ('"+TextBox1.Text+"','"+TextBox2.Text+"','"+TextBox3.Text+"','"+TextBox4.Text+"')"; OleDbInsertCommand1.Connection.Open(); //打开连接 OleDbInsertCommand1.ExecuteNonQuery(); //执行该SQL语句 OleDbInsertCommand1.Connection.Close(); //关闭连接
6.C#连接SyBase
Provider=Sybase.ASEOLEDBProvider.2;Initial Catalog=数据库名; User ID=用户名;Data Source=数据源;Extended Properties=""; Server Name=ip地址;Network Protocol=Winsock;Server Port Address=5000;
7.C#连接Express
<add name="BulkCopy" connectionString="Data Source=.\SQLEXPRESS; AttachDbFilename=|DataDirectory|\BulkCopy.mdf; Integrated Security=True;User Instance=False" providerName="System.Data.SqlClient" />
其中|DataDirectory|关键字是用来识别App的数据目录,“User Instance”属性用来判断在 DbConnection.Open() 方法执行时是否使用当前用户来启动SQL Express的一个实例。
我的环境配置为:
SQL Server 2005 Express SP2 英文版(升级到SP2 后下面的问题还是一样,解决不了)
Visual Studio 2005 SP1 中文版
问题是在我调试的时候出现了各种各样的异常:
1.Exception:
An attempt to attach an auto-named database for file ..\bin\PUBS.MDF failed. A database with the same name exists, or specified file cannot be opened, or it is located on UNC share.
对应的链接字符串:
<add name="BulkCopy" connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\BulkCopy.mdf; Integrated Security=True;User Instance=False" providerName="System.Data.SqlClient" />
任我如何Baidu、Google、MSDN都解决不了,其中倒是有一篇文章提供了7个方法,可惜在我的环境下一个都不得行。确实为这个问题搞了两天,先使用第3的方法来使例子跑起来,以后再来看这个问题了,一下子也搞不了这么多东西
2.Exception:
Generating user instances in SQL Server is disabled. Use sp_configure 'user instances enabled' to generate user instances.
对应的链接字符串:
<add name="BulkCopy" connectionString="Data Source=.\SQLEXPRESS; Initial Catalog=BulkCopy.MDF;Integrated Security=True;User Instance=True; MultipleActiveResultSets=True" providerName="System.Data.SqlClient" />
该字符串使用传统的SQL 2000的写法,“Initial Catalog”属性,但这种方法不利于部署。“User Instance”属性只在“Express”版本有效
出现上面的异常是没有设置'user instances enabled' ,这个可以在SQL Server Management Studio Express 里的查询器运行下面语句来更改(需要重启SQL Server Management Studio Express,可以参考MSDN):
sp_configure 'user instances enabled','1' RECONFIGURE; GO
3.把“User Instance”属性关闭了:
<add name="BulkCopy" connectionString="Data Source=.\SQLEXPRESS; Initial Catalog=BulkCopy.MDF;Integrated Security=True;User Instance=False; MultipleActiveResultSets=True" providerName="System.Data.SqlClient" />
就可以正常运行实例了。
注意:
数据库名和扩展名区分大小写,而且必须有扩展名,否则将会有如下类似异常:
Cannot open database "BulkCopy" requested by the login. The login failed. Login failed for user 'DOHO\Doho'.
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/QQlvbo/archive/2009/03/05/3960900.aspx
发表评论
-
win7和VS2010下配置OpenGL的方法
2011-01-15 23:45 6411刚装了win7和VS2010。看了下配置OpenGL的方法和以 ... -
用好ASP.NET 2.0的URL映射
2010-12-06 08:31 764简介: URL映射是ASP.NET 2.0中提供的 ... -
.NET加密技术应用
2010-12-06 08:20 774using System; using System. ... -
加密web.config中数据参数的信息
2010-12-06 08:17 828我们都知道web.config可以保存连接字符串, ... -
主题:ASP.NET加上水印
2010-12-02 19:56 814为我们发布的图片加上一个水印,也是我们经常要做的事情,那怎 ... -
asp.net 2.0 读写配置文件
2010-12-01 11:13 1106下面我给出一个简单的例子说明如何使用WebConf ... -
ASP.NET配置文件的读、写操作
2010-12-01 11:03 1322虽然web.config文件是一个XML文件,但是由于权限的原 ... -
使用aspx实现发送email
2010-11-28 22:08 737源代码如下:using System; using Syst ... -
未能加载文件或程序集system.web.extensions解决方法
2010-11-27 09:40 1639未能加载文件或程序集system.web.extensions ... -
asp.net根据域名查ip C#版
2010-10-31 17:04 1007网上有类似的教程,但是是asp.net 1.1的版本,这是本人 ... -
如何构造一个C#语言的爬虫程序
2010-10-31 17:03 866C#特别适合于构造蜘蛛 ... -
C#代码与javaScript函数的相互调用
2010-10-31 16:55 1118C#代码与javaScript函数的相互调用 我们通过问答 ... -
C#操作XML的类:xmlHelper例子
2010-10-31 16:31 4463首先,看下这个XmlHelper类库的结构,如下图: 然后, ... -
C#知识点总结_委托篇
2010-10-30 18:10 638C#知识点总结1——委托篇 1.委托概念: 当要把方法传 ... -
调用Windows API
2010-10-30 18:04 1008在.Net Framework SDK文档中 ... -
C#中正确的调用API函数
2010-10-30 18:02 1015在C#中经常需要调用一些API函数,那么怎样才能正确的调用AP ... -
用C#和本地Windows API操纵系统菜单
2010-10-30 18:00 1531一、前言 .NET框架是Windows应用领域中一个非常新 ... -
C#调用rar.exe解压一个rar文件到系统的临时目录
2010-08-31 00:04 1890//取得系统临时目录 string sysTempDir = ... -
C#实现winform软件开机自动启动并最小化到系统托盘
2010-08-31 00:01 4452一、开机自动启动: 拖一个CheckBox 1、软件启动时 ... -
C#里面比较时间大小三种方法收藏
2010-08-30 23:56 13011.比较时间大小的实验 string st1 ...
相关推荐
.NET(C#)连接各类数据库代码 .NET(C#)连接各类数据库代码概述 .NET(C#)连接各类数据库代码是指使用C#语言连接各种类型的数据库,包括Access、SQL Server等。在连接数据库之前,需要导入相应的命名空间,例如...
### .NET(C#)连接各类数据库详解 #### 一、引言 在.NET框架中,C#作为一种广泛使用的编程语言,被大量应用于企业级应用程序的开发。这些应用程序往往需要与不同的数据库进行交互,例如Microsoft Access、SQL ...
### .NET (C#) 连接各类数据库详解 #### 一、概述 在.NET框架中,使用C#语言进行数据库操作是常见的需求之一。本文将详细介绍如何利用C#连接不同类型的数据库,包括Access和SQL Server,并提供具体的示例代码。 #...
### .NET(C#)连接各类数据库综合指南 在.NET框架中,C#作为一种广泛使用的编程语言,提供了丰富的功能来处理数据库操作。无论是连接轻量级的Access数据库还是企业级的SQL Server,C#都能轻松应对。本文将深入探讨C#...
C# 语言用于连接数据库的方式主要有两种,一种是连接 SQL Server 数据库,另一种是连接 Access 数据库。这两种方式在连接机制上有所不同,但都遵循类似的步骤,包括创建连接对象、设置连接字符串、打开和关闭连接。 ...
本集锦主要聚焦于`.NET`(特别是C#)如何连接和操作各种数据库,如SQL Server、MySQL、Oracle、SQLite等。 1. **ADO.NET基础**: ADO.NET是.NET框架的一部分,它提供了与数据源交互的组件。主要包括DataSet、...
### ASP.NET 连接各类数据库知识点详解 #### 一、C#连接Access数据库 在ASP.NET应用程序中,连接Access数据库通常使用OLE DB提供程序。以下是对连接过程的详细解析: **1. 导入必要的命名空间** ```csharp using...
下面我们将详细介绍如何使用C#连接到Access和SQL Server数据库。 首先,我们来看C#连接Access数据库的实现方式。Access数据库通常使用OLE DB数据提供者,因此我们需要引入`System.Data.OleDb`命名空间。连接字符串...
同时,ADO.NET则用于数据库操作,提供了连接数据库、执行SQL语句、管理数据连接等便捷的API,使得数据管理更加高效。 该系统可能包含了多个子模块,如人力资源管理、财务管理、供应链管理等,这些模块通过C#的面向...
【C#连接数据库详解】 C#作为.NET框架的一部分,提供了丰富的数据访问能力,可以方便地连接到各种类型的数据库。在本文中,我们将详细介绍如何使用C#连接Access、SQL Server、Oracle、MySQL、IBM DB2以及SyBase这六...