C#与Oracle数据库
一.连接Oracle数据库
- 安装客户端: oracle数据库搭建在远程服务器上,本地只需要装个客户端,然后在安装目录下(D:\app\fangs\product\12.1.0\client_3\Network\Admin ,不一定是D盘) 配置tnsnames.ora,配置可以参考同目录下的Sample 文件夹中的内容。就是指明连接名,远程ip,servicename/SID。 然后可以利用sql develper工具打开数据库,查看数据库中的所有内容。
- c#程序通过ADO.NET连接: 首先创建连接字符串 : string connStr ="DATA SOURCE=***;PASSWORD=***;USER ID=**" ,以及后续的ADO.NET 操作就可以连接上数据库了。
- 获取数据:参考 MSDN MSDN ado.net
I. 建立数据库连接,conn.open()
II. 创建DataAdapter,这是数据库与DataSet对象之间的连接
III. 声明并创建一个DataSet对象实例,然后才能开始加载数据,该名称可以包含若干独立的表
IV. DataAdapter提供Fill,与FillSchema方法。
FillSchema方法会加载一些数据表信息,列名,约束等。
V. DataSet中的Tables集合内独立的DataTable对象来提供数据
VI. DataTables.Row可以访问每一行
二 C#中的数据类型与 Oracle 数据库字段类型对应关系
特别注意的是oracle数据库中 Number(10,1)这种类型的就可以用decimal
三.sql
1.一 中需要进行sql的传入,所以这里讲下sql 字符串的写法。
- string sql=@"";:@:C#中特殊的字符串声明方式,叫做 “逐字字符串”(verbatim strings),使用这个符号会告诉编译器这是个逐字字符串,它本身常用于写指定文件或目录的路径,因为它会通知编译器将 ’\‘作为文本常量而不是转义字符。在这里使用它是因为 sql语句可能很长,他支持换行写字符串
- 传参数给sql : string sql = @"nsert into A Values(:ID_NUM) 用 :表明这是个变量,这是oracle数据库的表达方式。其他数据库使用其他标示方式,如sqlserver使用@。注意这里的参数名不能使oracle数据库的关键词,否则会报错,显示这个参数名无效 。
- sql 语句加 常量:eg. where a>2 ,将2定义为 类 Constants中的一个变量 count 。就可以写成 where a> '" + Constants.count + @"' 一定要注意空格,否则可能识别不出关键词
2.sql 传参格式
数据库中字段定义一般会设定长度,写数值进去的时候一般位数不够,会补齐空格。
当我们执行查询、插入等数据库操作时,如果是直接赋值,oracle数据库会补齐/识别出不够的位数。但是如果使用传参数值的方法,oracle数据库则不会这么做。那么就需要补齐空格,才能判断相等条件。
eg.数据表A 的字段 ID CHAR(5)存储了某值为 A012
你执行 select *from A where ID=:ID
然后 oracleAccess.addParameter(":ID","A012")这样的查询语句是查询到 ID为A012的数据的。应该修改为
select *from A where ID=RPAD(:ID,5),这样会补齐空格的
C#与Oracle数据库的更多相关文章
- 使用Zabbix监控Oracle数据库
Orabbix介绍 监控Oracle数据库我们需要安装第三方提供的Zabbix插件,我们先测试比较有名的Orabbix,http://www.smartmarmot.com/product/orabb ...
- Oracle 数据库知识汇总篇
Oracle 数据库知识汇总篇(更新中..) 1.安装部署篇 2.管理维护篇 3.数据迁移篇 4.故障处理篇 5.性能调优篇 6.SQL PL/SQL篇 7.考试认证篇 8.原理体系篇 9.架构设计篇 ...
- Oracle数据库该如何着手优化一个SQL
这是个终极问题,因为优化本身的复杂性实在是难以总结的,很多时候优化的方法并不是用到了什么高深莫测的技术,而只是一个思想意识层面的差异,而这些都很可能连带导致性能表现上的巨大差异. 所以有时候我们应该先 ...
- Oracle 数据库语句大全
Oracle数据库语句大全 ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CH ...
- Oracle数据库升级(10.2.0.4->11.2.0.4)
环境: RHEL5.4 + Oracle 10.2.0.4 目的: 在本机将数据库升级到11.2.0.4 之前总结的Oracle数据库异机升级:http://www.cnblogs.com/jyzha ...
- 混合框架中Oracle数据库的还原处理操作
在较早期的随笔<Oracle如何实现创建数据库.备份数据库及数据导出导入的一条龙操作>粗略介绍了Oracle数据库的备份还原操作,本文想从开发框架的基础上介绍Oracle数据库的脚本或者还 ...
- Oracle数据库的链接数目超标
测试场景:Oracle数据库的链接数目超标,iServer是否自动连接. 测试步骤:(1)设置了最大连接数为85,oracle后台进程有83:(2)开启3台iserver(A,B,C)A,B发布tes ...
- 将Oracle数据库中的数据写入Excel
将Oracle数据库中的数据写入Excel 1.准备工作 Oracle数据库"TBYZB_FIELD_PRESSURE"表中数据如图: Excel模板(201512.xls): 2 ...
- Oracle数据库11g各版本介绍及功能比较
.标准版和企 业版.所有这些版本都使用相同的通用代码库构建,这意味着企业的数据库管理软件可以轻松地从规模较小的单一处理器服务器扩展到多处理器服务器集 群,而无需更改一行代码.Oracle数据库11g企 ...
- Oracle数据库,数据的增、删、改、查
oracle数据库中,数据的增.删.改.查,通过SQL语句实现 SQL:结构化查询语言: 特点:不区分大小写:字符串用单引号引起来:语句结束用分号表示结束: 行注释,在语句的最前面加"--& ...
随机推荐
- Settings.settings
项目的设置,有些设置是不能变的,有些设置是由用户决定的,Settings.settings都能搞定. 范围是应用程序级别的是只读属性,范围是用户级别的可读写 读取的方式是: Properties.Se ...
- JAVA局部内部类
在刚刚学到的android开发中了解到Button的onClick是通过局部内部类的方式实现的,具体的原理我以后再去了解,只是遇到问题总是想知道为什么,不要告诉我这是规则,死记住就可以了. 问题是局部 ...
- 转:函数signal()
from:http://blog.sina.com.cn/s/blog_4b226b92010119l5.html 当服务器close一个连接时,若client端接着发数据.根据TCP协议的规定,会收 ...
- Azure AI 服务之语音识别
笔者在前文<Azure AI 服务之文本翻译>中简单介绍了 Azure 认知服务中的文本翻译 API,通过这些简单的 REST API 调用就可以轻松地进行机器翻译.如果能在程序中简单的集 ...
- Java第1次实验提纲(基本概念与引入PTA+Git)
0. 控制台下编译.运行 在Notepad++编写Java程序 学会使用控制台,javac.java 学会使用Notepad++ 参考资料: 控制台-cmd应用基础 扫盲教程 使用命令行编译并运行ja ...
- Linux下的有用命令
在之前的博客<Linux下常用命令与使用技巧>中,介绍了Linux的常用命令,在今天的博客中,给大家介绍其他的有用命令. 1.文本转换命令 在Linux下工作,我们不可避免地要和文件格式做 ...
- C++格式化输出浮点数
主要内容 介绍C++中如何格式化输出浮点数. 控制浮点数输出格式需要包含iomanip头文件. 使用fixed来控制输出的浮点数的小数位是固定的.可参考http://en.cppreference.c ...
- Bootstrap3 栅格系统-嵌套列
为了使用内置的栅格系统将内容再次嵌套,可以通过添加一个新的 .row 元素和一系列 .col-sm-* 元素到已经存在的 .col-sm-* 元素内.被嵌套的行(row)所包含的列(column)的个 ...
- AndroidStudio中导入SlidingMenu报错解决方案
----------------------------------------------------------------------------------------------[版权申明: ...
- Ajax+Struts2实现验证码验证功能
---------------------------------------------------------------------------------------------------- ...