一.连接Oracle数据库

  1. 安装客户端: oracle数据库搭建在远程服务器上,本地只需要装个客户端,然后在安装目录下(D:\app\fangs\product\12.1.0\client_3\Network\Admin ,不一定是D盘) 配置tnsnames.ora,配置可以参考同目录下的Sample 文件夹中的内容。就是指明连接名,远程ip,servicename/SID。 然后可以利用sql develper工具打开数据库,查看数据库中的所有内容。
  2. c#程序通过ADO.NET连接:  首先创建连接字符串 : string connStr ="DATA SOURCE=***;PASSWORD=***;USER ID=**" ,以及后续的ADO.NET 操作就可以连接上数据库了。
  3. 获取数据:参考 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 字符串的写法。

  1. string sql=@"";:@:C#中特殊的字符串声明方式,叫做 “逐字字符串”(verbatim strings),使用这个符号会告诉编译器这是个逐字字符串,它本身常用于写指定文件或目录的路径,因为它会通知编译器将 ’\‘作为文本常量而不是转义字符。在这里使用它是因为 sql语句可能很长,他支持换行写字符串
  2. 传参数给sql : string sql = @"nsert  into A Values(:ID_NUM) 用 :表明这是个变量,这是oracle数据库的表达方式。其他数据库使用其他标示方式,如sqlserver使用@。注意这里的参数名不能使oracle数据库的关键词,否则会报错,显示这个参数名无效 。
  3. sql 语句加 常量:eg. where a>2 ,将2定义为 类 Constants中的一个变量 count 。就可以写成 where a> '" + Constants.count + @"'  一定要注意空格,否则可能识别不出关键词
备注:在c#中写sql语句时,先将sql语句放在sql developer中执行,确保sql语法没有错误,再写到程序中。像上面提到的 传参 用 “:”标记,sql developer中都是可以检查出来的

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数据库的更多相关文章

  1. 使用Zabbix监控Oracle数据库

    Orabbix介绍 监控Oracle数据库我们需要安装第三方提供的Zabbix插件,我们先测试比较有名的Orabbix,http://www.smartmarmot.com/product/orabb ...

  2. Oracle 数据库知识汇总篇

    Oracle 数据库知识汇总篇(更新中..) 1.安装部署篇 2.管理维护篇 3.数据迁移篇 4.故障处理篇 5.性能调优篇 6.SQL PL/SQL篇 7.考试认证篇 8.原理体系篇 9.架构设计篇 ...

  3. Oracle数据库该如何着手优化一个SQL

    这是个终极问题,因为优化本身的复杂性实在是难以总结的,很多时候优化的方法并不是用到了什么高深莫测的技术,而只是一个思想意识层面的差异,而这些都很可能连带导致性能表现上的巨大差异. 所以有时候我们应该先 ...

  4. Oracle 数据库语句大全

    Oracle数据库语句大全 ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CH ...

  5. 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 ...

  6. 混合框架中Oracle数据库的还原处理操作

    在较早期的随笔<Oracle如何实现创建数据库.备份数据库及数据导出导入的一条龙操作>粗略介绍了Oracle数据库的备份还原操作,本文想从开发框架的基础上介绍Oracle数据库的脚本或者还 ...

  7. Oracle数据库的链接数目超标

    测试场景:Oracle数据库的链接数目超标,iServer是否自动连接. 测试步骤:(1)设置了最大连接数为85,oracle后台进程有83:(2)开启3台iserver(A,B,C)A,B发布tes ...

  8. 将Oracle数据库中的数据写入Excel

    将Oracle数据库中的数据写入Excel 1.准备工作 Oracle数据库"TBYZB_FIELD_PRESSURE"表中数据如图: Excel模板(201512.xls): 2 ...

  9. Oracle数据库11g各版本介绍及功能比较

    .标准版和企 业版.所有这些版本都使用相同的通用代码库构建,这意味着企业的数据库管理软件可以轻松地从规模较小的单一处理器服务器扩展到多处理器服务器集 群,而无需更改一行代码.Oracle数据库11g企 ...

  10. Oracle数据库,数据的增、删、改、查

    oracle数据库中,数据的增.删.改.查,通过SQL语句实现 SQL:结构化查询语言: 特点:不区分大小写:字符串用单引号引起来:语句结束用分号表示结束: 行注释,在语句的最前面加"--& ...

随机推荐

  1. Cookie&Seesion会话 共享数据 工作流程 持久化 Servlet三个作用域 会话机制

    Day37 Cookie&Seesion会话 1.1.1 什么是cookie 当用户通过浏览器访问Web服务器时,服务器会给客户端发送一些信息,这些信息都保存在Cookie中.这样,当该浏览器 ...

  2. Docker控制组

    控制组是 Linux 容器机制的另外一个关键组件,负责实现资源的审计和限制. 它提供了很多有用的特性:以及确保各个容器可以公平地分享主机的内存.CPU.磁盘 IO 等资源:当然,更重要的是,控制组确保 ...

  3. Ubuntu 16.04: How to resolve libqt5x11extras5 (>= 5.1.0) but it is not going to be installed

    Issue: When you install Virtualbox 5.1 on Ubuntu 16.04, you may encounter following error: root@XIAY ...

  4. jboss规则引擎KIE Drools 6.3.0 Final 教程(1)

    前言 目前世面上中文的KIE DROOLS Workbench(JBOSS BRMS)的教程几乎没有,有的也只有灵灵碎碎的使用机器来翻译的(翻的不知所云)或者是基于老版本的JBOSS Guvnor即5 ...

  5. Android Studio NDK 代码 Source Insight调试 (NDK 目前开发方案 | NDK 编译 | 导入 so 库 | 项目编码转换)

    作者 : 韩曙亮 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/52088039 最近在移植一个 JNI 项目, 比较纠结, A ...

  6. Android对话框Dialog深度剖析

    对话框 对话框是提示用户作出决定或输入额外信息的小窗口. 对话框不会填充屏幕,通常用于需要用户采取行动才能继续执行的模式事件. 对话框设计 Dialog 类是对话框的基类,但您应该避免直接实例化 Di ...

  7. Git运用基础之如何删除Github上不想要的项目

    今天突然想删除,(强迫症想删除)之前练习时多创建的多个Github上的源代码或者无用Demo地址,然后看了一些文章都比较老式,这里我展示一下最新的删除步骤. 一.首先登录自己的Github账户主页(没 ...

  8. java.util.ServiceLoader使用

    近期在项目中需要实现能在配置文件中定义多个统一接口类型的类,可以在程序中获取到所有配置的类,刚开始打算配置到properties中,然后去程序读取,感觉这种方式不太灵活,于是,研究研究java中有没有 ...

  9. UNIX网络编程——tcp流协议产生的粘包问题和解决方案

    我们在前面曾经说过,发送端可以是一K一K地发送数据,而接收端的应用程序可以两K两K地提走数据,当然也有可能一次提走3K或6K数据,或者一次只提走几个字节的数据,也就是说,应用程序所看到的数据是一个整体 ...

  10. Android必知必会-Stetho调试工具

    一.背景 Stetho是 Facebook 出品的一个强大的 Android 调试工具,使用该工具你可以在 Chrome Developer Tools查看APP的布局, 网络请求(仅限使用Volle ...