(1)OracleClient数据库操作(淘汰)
一、数据库连接
Oracle 数据提供程序,位于System.Data.OracleClient 命名空间.( .NET 4 以后的版本,会将不在维护和更新了)
第一步:引入命名空间
在程序的开头写上下面的代码
using System.Data.OracleClient;
第二步:引入对应组件
点击项目-右键-添加引用-找到System.Data.OracleClient-确定.

第三步:写代码
private void button1_Click(object sender, EventArgs e)
{
string str="server=.;data source=orcl;uid=xxx;pwd=xxx";
//上面这句需要安装Oracle客户端并配置tnsnames.ora
//string str = "User ID=xxx;Password=xxx;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = orcl)));";
//上面这句需要安装Oracle客户端不需配置tnsnames.ora
OracleConnection conn = new OracleConnection(str);
conn.Open();
if (conn.State == ConnectionState.Open)
{
MessageBox.Show("连接成功");
}
conn.Close();
}
database和data source的区别?
database是数据库的意思,用sqlserver数据库是需要用这个。
data source是数据资源的意思,用Oracle数据库时用这个。
if (conn.State == ConnectionState.Open)的意思?
用conn.State判断当前数据库是关闭还是打开的,而ConnectionState.Open得意思是打开。所以如果数据库是打开状态就可以为“真”。 这句话是用来判断数据库是不是打开状态的。(前提是要引用using System.Data;命名空间)
安装oracle后 tnsnames.ora文件目录
D:\app\Administrator\product\11.2.0\dbhome_1\NETWORK\ADMIN
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = ))
)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)
二、执行sql语句(Command)
OracleCommand 命令对象的名称 =new OracleCommand(SQL语句,连接对象名称);
共分为两种操作:增删改和查询操作
当需要使用增删改操作时
string str1="insert into student values(1,'tom')";
OracleCommand cmd = new OracleCommand(str1,conn);
cmd.ExecuteReader();
当需要查询时
string str1="select * from student";
OracleCommand cmd = new OracleCommand(str1,conn);
OracleDataReader dr=cmd.ExecuteReader();//把查询的结果传给OracleDataReader的对象
//下一步读取数据
读取数据
OracleDataReader对象获取到值以后就需要读取数据了
首先
dr.read();//把箭头指向表格的第一行,第一列
然后
dr["表的字段名"]或者dr[下标数字(相当于数组)] 就可以读取指定的数据了
假设
表格的第一个字段是id,第二个字段是name
例如
dr["id"] 或者dr[0] 就能读出第一行第一列的数据
dr["name"]或者di[1]就能读出第一行第二列的数据
如果想要第二行的数据就需要用到循环
while (dr.Read())//假设这是一个控制台程序
{
Console.Write(dr[]);
Console.WriteLine(dr[]);
}
command 有三个常用方法
1、
cmd.ExecuteNonQuery();//执行sql语句并返回受影响的行数。通常用来执行增删改。
2、
OracleDataReader dr=cmd.ExecuteReader();//执行sql语句并把查询的内容放到OracleDataReader对象里。用来做查询
3、
cmd.ExecuteScalar();//执行sql语句,并返回结果集中的第一行第一列。通常和函数配合使用,为了计算某个值。
三、 DataReader
OracleDataReader的属性:HasRows 用来判断结果是否有数据,有的话返回True
if(dr.HasRows)
{
MessageBox.Show("数据表中有值");
}
OracleDataReader的方法:
dr.read();//
dr.Close();//关闭OracleDataReader对象。如果一个OracleConnection创建了多个OracleDataReader,则在创建OracleDataReader之前需要先管壁上一个。
四、数据适配器 DataAdapter对象
DataAdapter对象是一个数据适配器对象,在DataSet与数据源之间起到桥梁的作用。它有四个属性
1、 SelectCommand ,用来向数据库发送查询SQL语句
2、DeleteCommand,向数据库发送删除语句
3、InsertCommand,向数据库发送插入语句
4、UpdateCommand,向数据库发送更新语句
DataAdapter的方法
1 、Fill方法:用于填充DataSet数据集
da.Fill(ds,"student");//括号里的参数(Data对象,表名);
dataGridView1.DataSource = ds.Tables["表名"];
//或者dataGridView1.DataSource = ds.Tables[0];
2、Updata方法:用来更新数据库
增
五、数据集DataSet
(1)OracleClient数据库操作(淘汰)的更多相关文章
- c#数据库操作大全
原文:c#数据库操作大全 1.提取单条记录 //using System.Data; //using System.Data.SqlClient; using (SqlConnection cn = ...
- C# Oracle数据库操作类实例详解
本文所述为C#实现的Oracle数据库操作类,可执行超多常用的Oracle数据库操作,包含了基础数据库连接.关闭连接.输出记录集.执行Sql语句,返回带分页功能的dataset .取表里字段的类型和长 ...
- 使用ado.net打造通用的数据库操作类
最近在项目中使用中碰到了这样一种情况,查询的数据是从Oracle中获取的,但是记录下来的数据是存在Sql Server中(企业Oracle数据库管理太严,没办法操作).而且我在之前的工作中也碰到过使用 ...
- (转)C# Oracle数据库操作类
原文地址:http://www.cnblogs.com/haibing0107/p/6143922.html using System;using System.Data;using System.C ...
- Oracle数据库操作类及连接方法
创建DataBaseAccess引用库下面包括DBConnectionString.cs,DBType.cs ,SysName.cs 三个类 DBConnectionString: using Sys ...
- C# Oracle数据库操作类
using System; using System.Data; using System.Collections.Generic; using System.Configuration; using ...
- 如何在高并发环境下设计出无锁的数据库操作(Java版本)
一个在线2k的游戏,每秒钟并发都吓死人.传统的hibernate直接插库基本上是不可行的.我就一步步推导出一个无锁的数据库操作. 1. 并发中如何无锁. 一个很简单的思路,把并发转化成为单线程.Jav ...
- 【知识必备】ezSQL,最好用的数据库操作类,让php操作sql更简单~
最近用php做了点小东东,用上了ezSQL,感觉真的很ez,所以拿来跟大家分享一下~ ezSQL是一个非常好用的PHP数据库操作类.著名的开源博客WordPress的数据库操作就使用了ezSQL的My ...
- MySQL 系列(二) 你不知道的数据库操作
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 本章内容: 查看\创建\使用\删除 数据库 用户管理及授权实战 局域网 ...
随机推荐
- PowerShell技巧:使用XPath语法查询XML文件
[TechTarget中国原创] XML是存储结构化数据的一个很好的途径,但是想要让数据在其中发挥作用又会有些困难.每一种语言都有其特定方式来查询XML文件中的命名空间.元素及属性.PowerShel ...
- Android (shape,gradient)使用总结
设置背景色可以通过在res/drawable里定义一个xml,如下: <?xml version="1.0" encoding="utf-8"?> ...
- win7重装后恢复grub和ubuntu14
没有光盘和优盘启动盘,可以在win7下安装easybcd,添加一个启动选项为linux grub2,启动后进入ubutnu,执行如下: sudo -i //取得root权限 fdisk -l ...
- Django笔记 —— 模型
最近在学习Django,打算玩玩网页后台方面的东西,因为一直很好奇但却没怎么接触过.Django对我来说是一个全新的内容,思路想来也是全新的,或许并不能写得很明白,所以大家就凑合着看吧- 本篇笔记(其 ...
- React跨域问题解决
https://segmentfault.com/q/1010000012732581 非跨域问题报错 -rpccorsdomain="http://localhost:3000" ...
- [转] Linux命令行编辑常用键
ctrl + a 将光标移动到命令行开头相当于VIM里shift+^ ctrl + e 将光标移动到命令行结尾处相当于VIM里shift+$ ctrl + 方向键左键 光标移动到前一个单词开头 ctr ...
- 七、LSP 里氏替换原则
子类的对象提供了父类的所有行为,且加上子类额外的一些东西(可以是功能,可以是属性).当程序基于父类实现时,如果将子类替换父类而程序不需修改,则说明符合LSP原则. 这个解释看的似懂非懂,再看下面更进一 ...
- 软工实践Alpha冲刺(10/10)
队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 完成所有界面的链接,整理与测试 展示GitHub当日代码/ ...
- iOS大神班笔记02-模仿苹果创建单例
首先我们得要知道苹果是如何实现单例的:1.不能外界调用alloc,一调用就崩掉,其实就是抛异常(类内部第一次调用alloc就不崩溃,其他都崩溃). 2.提供一个方法给外界获取单例. 3.内部创建一次 ...
- [BZOJ4205][FJ2015集训] 卡牌配对 [建图+最大流]
题面 这是bzoj权限题,题面可以去下面的离线题库找 离线4205,只有题面,不能提交 思路 二分图匹配 这道题模型显然就是个二分图匹配嘛 那我们两两判断一下然后连边匹配.....就只有30分了 因为 ...