Oracle系列——开发中奇葩问题你遇到几个(一)

前言:在使用oracle数据进行开发的时候有没有经常出现一些很奇怪、很纳闷、很无厘头的问题呢。下面是本人使用oracle一段时间遇到的问题小节,在此做个记录,方便以后再遇到类似的问题能快速解决。如果你是数据库大虾,此文可以略过;如果你是数据库小菜或者刚从sql server转到使用oracle开发,这些问题可能你曾经遇到或者即将遇到,不信?走着瞧!

1、oracle插入数据中文乱码的问题:

问题描述:在plsql中不管是编辑数据,还是使用insert语句插入,所有的中文都会变成乱码。

解决方法:

我的电脑---右击---属性---高级---环境变量---系统变量---新建

变量名:NLS_LANG

变量值:SIMPLIFIED CHINESE_CHINA.ZHS16GBK,确定后再试试,OK。

2 、在plsql中增删改数据后,查询看到结果变了,但是程序访问还是原来的数据。

问题描述:测试需要,在plsql中更新一条数据,然后程序查询该数据。很奇怪的是程序查询到的结果总是更新之前的。怎么回事?

解决方法:plsql里面有一个提交的操作,在增删改数据后,需要提交一下数据,其他进程才能访问到修改的数据。如果你之前一直用的ms sql server,刚使用oracle的过程中,是否也遇到类似的问题呢。

3、在plsql中修改数据后,没有提交,程序修改这个表数据时就会卡死。因为表被plsql的进程锁掉了。需要在plsql里面提交数据,这个时候锁才会释放。这也就是为什么经常看到下面代码的原因:

lock (syncCommit)
{
    try
    {
          return context.SaveChanges();
    }
    catch (DbEntityValidationException dbEx)
    {

    }
}

4、使用PowerDesigner设计表后生成DDL语句,执行DDL语句后表、字段、关联键都可以正常生成,可是奇怪的问题就来了,你在plsql里面select * from table1表时,提示表或者视图不存在,可是你仔细看了好多遍,表明明存在呀。还出鬼了呢。。。

问题描述:我们来看生成的DDL语句

/*==============================================================*/
/* DBMS name:      ORACLE Version 11g                           */
/* Created on:     2015/7/2 15:45:52                            */
/*==============================================================*/

drop table "TB_Department" cascade constraints;

drop table "TB_Menu" cascade constraints;

drop table "TB_MenuRole" cascade constraints;

drop table "TB_Role" cascade constraints;

drop table "TB_UserRole" cascade constraints;

drop table "TB_Users" cascade constraints;

/*==============================================================*/
/* Table: "TB_Department"                                       */
/*==============================================================*/
create table "TB_Department"
(
   "department_id"      CHAR(10),
   "department_name"    CHAR(10),
   "parent_id"          CHAR(10),
   "level"              CHAR(10),
   "status"             CHAR(10)
);

/*==============================================================*/
/* Table: "TB_Menu"                                             */
/*==============================================================*/
create table "TB_Menu"
(
   "menu_id"            CHAR(10),
   "menu_name"          CHAR(10),
   "menu_url"           CHAR(10),
   "parent_id"          CHAR(10),
   "level"              CHAR(10),
   "sort_order"         CHAR(10),
   "status"             CHAR(10),
   "remark"             CHAR(10)
);

/*==============================================================*/
/* Table: "TB_MenuRole"                                         */
/*==============================================================*/
create table "TB_MenuRole"
(
   "id"                 CHAR(10),
   "role_id"            CHAR(10),
   "menu_id"            CHAR(10),
   "role_type"          CHAR(10),
   "button_id"          CHAR(10)
);

/*==============================================================*/
/* Table: "TB_Role"                                             */
/*==============================================================*/
create table "TB_Role"
(
   "role_id"            CHAR(10),
   "role_name"          CHAR(10),
   "description"        CHAR(10),
   "createtime"         CHAR(10),
   "modifytime"         CHAR(10)
);

/*==============================================================*/
/* Table: "TB_UserRole"                                         */
/*==============================================================*/
create table "TB_UserRole"
(
   "id"                 CHAR(10),
   "role_id"            CHAR(10),
   "user_id"            CHAR(10)
);

/*==============================================================*/
/* Table: "TB_Users"                                            */
/*==============================================================*/
create table "TB_Users"
(
   "user_id"            INT,
   "user_name"          CHAR VARYING(0),
   "user_password"      CHAR VARYING(0),
   "fullname"           CHAR(10),
   "department_id"      CHAR(10),
   "status"             CHAR(10),
   "createtime"         DATE,
   "modifytime"         DATE,
   "remark"             CHAR(10)
);

comment on table "TB_Users" is
‘用户信息表‘;

解决方案:原来是"号在作怪,由于生成的表里面带了引号,所以当你用tb_users去查时,提示找不到该表。当你讲所有的引号去掉,再重新执行DDL,再去查询,就这样正常了。郁闷了好久吧!!如果你也是用过PowerDesigner生成过DDL语句,可能也遇到过问题。

5、用EF去连接oracle数据库时,最开始开发一直用的test用户,最近项目要上线了,在服务器上面安装好oracle,建好正式用户admin,可是奇怪的事情发生了。程序里面该改的配置文件,连接字符串都改了,数据表都创建正常,表空间什么的也都没问题,可是用admin连接的时候总是提示找不到对应的表或视图。这又是为什么呢?其实问题就在admin这个用户那里。

原因分析:因为之前开发一直用的test用户,拖EF表结构的时候也是test,这样在edmx文件中就生成了对应的Schema="Test"。而在连接数据库是,EF自动生成的Sql语句会带Test用户,所以导致找不到表。

<EntityContainer Name="ModelStoreContainer">
          <EntitySet Name="TB_DEPARTMENT" EntityType="Self.TB_DEPARTMENT" Schema="Test" store:Type="Tables" />
          <EntitySet Name="TB_MENU" EntityType="Self.TB_MENU" Schema="Test" store:Type="Tables" />
          <EntitySet Name="TB_MENUROLE" EntityType="Self.TB_MENUROLE" Schema="Test" store:Type="Tables" />
          <EntitySet Name="TB_ROLE" EntityType="Self.TB_ROLE" Schema="Test" store:Type="Tables" />
          <EntitySet Name="TB_USERROLE" EntityType="Self.TB_USERROLE" Schema="Test" store:Type="Tables" />
          <EntitySet Name="TB_USERS" EntityType="Self.TB_USERS" Schema="Test" store:Type="Tables" />

解决方案:重新生成表结构,或者手动改掉Schma的值。

6、查询时,有时在PL/SQL里面可以用中文模糊搜索,但是在程序调试中使用中文模糊搜索时总查询不到记录。

原因分析:由于PL/Sql里面进行过自动编码,所以支持中文检索,当程序用sql语句查询时如果没有设置编码的话可能查不到中文。

解决方案:需要在web.config配置文件加上 Unicode=true;
<property name="connection.connection_string">User ID=mall;Password=super123;Unicode=true;Data Source=EIPUAT</property>

7、oracle里面新建用户的时候,用户会有一个默认表空间,而此用户是无法访问到其他表空间下面的数据表的。这个时候需要修改用户的默认表空间或者表的所属表空间。

(1)修改表的表空间语句:

alter table TABLE_NAME move tablespace TABLESPACENAME

(2)修改默认用户的表空间:

alter user user_name default tablespace tablespace_name;

8、oracle创建自增序列。如果在sql server里面,只需要给主键设置自增长就行了。oracle可没有这玩意儿,怎么办?

解决方案:

(1) 创建自增序列,在PLSql里面的SQL 窗口中执行如下语句,创建自增序列TB_TRIAL_PROCESS_SQE

create sequence TB_TRIAL_PROCESS_SQE
minvalue 1 
maxvalue 99999999
increment by 1
start with 1; /*步长为1*/
/*创建触发器*/
DROP TRIGGER TB_TRIAL_PROCESS_TRI;
create or replace trigger TB_TRIAL_PROCESS_TRI
before insert on TB_TRIAL_PROCESS /*触发条件:当向表TB_TRIAL_PROCESS 执行插入操作时触发此触发器*/
for each row/*对每一行都检测是否触发*/
begin/*触发器开始*/ 
select TB_TRIAL_PROCESS_SQE.NEXTVAL into :new.trial_id from dual;  /*触发器主题内容,即触发后执行的动作,在此是取得序列dectuser_tb_seq的下一个值插入到表dectuser中的userid字段中*/
end; /*退出sqlplus行编辑*/

(2) nhibernate的xml里面配置这个序列
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
  <class name="E2E.Model.TB_TRIAL_PROCESS, E2E.Model" table="TB_TRIAL_PROCESS">
    <id name="TRIAL_ID" type="Decimal" unsaved-value="0">
      <column name="TRIAL_ID" sql-type="NUMBER" not-null="true" unique="true"/>
      <generator class="sequence">
        <param name="sequence">TB_TRIAL_PROCESS_SQE</param>
      </generator>
    </id>

9、oracle里面经常会遇到表被锁定的情况,有时需要手动解锁。

查看系统的锁语句:

select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo,
dba_objects ao,
v$session sess
where ao.object_id = lo.object_id and lo.session_id = sess.sid;

杀掉锁表进程语句:(上面的语句会得到两个字段SID和serial#)

alter system kill session ‘SID,serial#‘;/*将上面语句查询到的SID和serial#复制到本语句的相应位置执行即可*/

10、C#程序里面同时执行多条SQL语句,于此同时又不方便使用存储过程或数据库事务。一般是增删改语句。

解决方案:如果你将多条SQL语句用分号隔开放在plsql中执行是可以得到结果的。但是在程序里面直接传多条SQL语句时则会提示错误。这个时候需要在这多条SQL语句的前后分别加上begin和end。这样就能解决问题。记得原来在SQL Server里面直接这样传多条sql语句是可以的。但在oracle里面需要这么处理下。

11、未完待续......

以上是本人在使用oracle开发过程中经常遇到的问题的一些小结。目前为止先整理这么多,后续会将这个序列继续下去。

时间: 2024-10-29 19:05:41

Oracle系列——开发中奇葩问题你遇到几个(一)的相关文章

软件开发中oracle查询常用方法总结

上次新霸哥和大家讲解了一些关于oracle的知识发现大家对oracle还是比较感兴趣的,下面新霸哥就大家比较关系的oracle中常用的查询有哪几种?做个和oracle相关的开发的朋友可能会知道答案,但是刚接触过oracle的朋友可能还不知道是怎么回事.今天,新霸哥将在此给大家做一个详细的介绍. 多表连接查询 连接多表 1. 笛卡尔积 在没有任何过滤条件的情况下,左表的任意一行记录 与 右表的任意记录进行连接 2. 使用连接查询 下面新霸哥简单的介绍一下语法1:select columnList

java web开发中的奇葩事web.xml中context-param中的注释

同事提交了代码.结果除同事之外,其他人全部编译报错.报错说web.xml中配置的一个bean 没有定义.按照报错提示,各种找,无果. 由于代码全部都是提交到svn主干,之前也没有做过备份,只能一步一步删除同事提交的代码,进行还原. 奇葩事情出现了! <context-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:/context_entry.xml

ADF_Tutorials系列04_Getting Started_使用Oracle ADF开发富Web应用程序(Part2)

二.案例实现 - Create JSF Web Pages 二.案例实现 - Add More Complex Business Services 二.案例实现 - Create a Page Flow 二.案例实现 - Use ADF Faces Framework Features ADF_Tutorials系列04_Getting Started_使用Oracle ADF开发富Web应用程序(Part2)

扒一扒系列之开发中常用的Java集合类(ArrayList篇 jdk 1.7)

关于这个系列,因为开发主要用的是java语言,一直想写写java开发中常用的一些类(虽然这才是开始的第三篇>_<),所有就起了“扒一扒”系列.这个系列会有框架,或者其他学到的东西.文章尽量做到简洁,用少的篇幅理顺相关的知识点和使用方法.废话少说,接下来扒一扒ArrayList这个集合类. 一.数据结构 让我们先看下ArrayList所在包的位置,在java.util.ArrayList中(如图1-1),它在jdk中的util中,说明它在开发中比较常用.从它的名字能看出数据结构为一个数组,看一下

【ABAP系列】SAP ABAP 开发中的SMARTFORMS 参数

公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 开发中的SMARTFORMS 参数 前言部分 大家可以关注我的公众号,公众号里的排版更好,阅读更舒适. 正文部分 &symbol& (括号中,小写字母为变量)&symbol&  屏蔽从第一位开始的N位&symbol (n)&   只显示前N位&symbol (S)&a

openresty开发系列16--lua中的控制结构if-else/repeat/for/while

openresty开发系列16--lua中的控制结构if-else/repeat/for/while 一)条件 - 控制结构 if-else if-else 是我们熟知的一种控制结构.Lua 跟其他语言一样,提供了 if-else 的控制结构. 1)单个 if 分支 型 if 条件 then --body end 条件为真 ,执行if中的body ----------------------- x = 10 if x > 0 then print("分支一") end ----

iOS HmacSHA1加密 和 MD5 Base64加密 --iOS开发系列---项目中成长的知识五

项目中开发中需要对一些数据进行加密后和服务器验证是否是我们客户端发出的请求! 方案是服务器定的,使用HmacSHA1加密和MD5 Base64加密 加密过程比较复杂 1.获取格林威治时间 2.用base64编码对请求数据内容进行MD5值计算 3.设置请求格式 4.设置鉴权信息,需要对上面的3个内容以及请求的链接 进行HMacSHA1再次进行加密 加密过后把上面4步获得的值加入到http的请求头中,一并发送给服务器,服务器经过验证后,才返回给我们我们想要的信息 下面贴代码说明我们使用的两个加密 首

.NET程序员细数Oracle与众不同的那些奇葩点

扯淡 距上次接触 Oracle 数据库已经是 N 年前的事了,Oracle 的工作方式以及某些点很特别,那会就感觉,这货就是一个奇葩!最近重拾记忆,一直在折腾 Oracle,因为 Oracle 与众不同,所以,想在这儿记录下 Oracle 不同于其他数据库的一些地方以及使用 Oracle 过程遇上的点点滴滴,同时,也让对 Oracle 陌生的同学有所了解. 导航 安装与创建数据库 Oracle 奇葩点 限定符 区分大小写 字符类型比较大小写 dual 表 不能执行多条sql sys_guid 函

oracle系列(六)OEM与常见故障处理

博主QQ:819594300 博客地址:http://zpf666.blog.51cto.com/ 有什么疑问的朋友可以联系博主,博主会帮你们解答,谢谢支持! 前言:oracle除了使用命令操作以外,还可以使用OEM图形化管理,日常的管理工作都可以通过OEM操作,包括数据库对象的创建,用户权限的管理,数据文件和参数的配置.备份和恢复操作等. 一.OEM知识点 1.OEM简介 OEM是采用直观而且方便的图像化界面来控制和管理ORACLE数据库的工具集,它包含大量对DBA有用的工具.在oracle中