Oracl使用总结二
1、ORA-00972: 标识符过长 错误排除 可能原因:
1、如果是拼接成的sql语句,请查找传递参数时字符型字段是否两边少了引号。
2、数据库表名太长了,附各种类型的数据库表名长度:
SQLSERVER 128个字符,临时表116个字符。
Oracle 30个字符。
MySQL 64个字符。
Access 64个字符。
DB2 128个字符。
2、The content of elements must consist of well-formed character data or markup解决方法:
XML 元素必须遵循以下命名规则:
、名称可以含字母、数字以及其他的字符
、名称不能以数字或者标点符号开始
、名称不能以字符 “xml”(或者 XML、Xml)开始
、名称不能包含空格
、有可能末尾多了一个;
3、oracle 主键自增 办法:
1、通过序列方式:
将表t_uaer的字段ID设置为自增:(用序列sequence的方法来实现) ----创建表
Create table t_user(
Id number(),
userid varchar2(),
loginpassword varchar2(),
isdisable number() ); ----创建序列
create sequence user_seq
increment by
start with
nomaxvalue
nominvalue
nocache ----创建触发器
create or replace trigger tr_user
before insert on t_user
for each row
begin
select user_seq.nextval into :new.id from dual;
end; ----测试 insert into t_user(userid,loginpassword, isdisable) values('ffll','liudddyujj', );
insert into t_user(userid,loginpassword, isdisable) values('dddd','zhang', ) ;
select * from t_user; 就可以看出结果。
2、结合mybatis方式进行修改:
----创建序列
create sequence TRIGGER_INFO_SEQ
increment by 1
start with 1
nomaxvalue
nominvalue
nocache
<insert id="save" parameterType="com.bosssoft.platform.jobcenter.admin.core.model.JobInfo" useGeneratedKeys="true" keyProperty="id" databaseId="Oracle">
<selectKey resultType="java.lang.Integer" order="BEFORE" keyProperty="id">
SELECT TRIGGER_INFO_SEQ.NEXTVAL FROM dual
</selectKey>
INSERT INTO BOS_QRTZ_TRIGGER_INFO (
id,
job_group,
job_cron,
job_desc,
add_time,
update_time,
author,
alarm_email,
executor_route_strategy,
executor_handler,
executor_param,
executor_block_strategy,
executor_fail_strategy,
glue_type,
glue_source,
glue_remark,
glue_updatetime,
child_jobkey
) VALUES (
#{id},
#{jobGroup},
#{jobCron},
#{jobDesc},
to_date(to_char(sysdate,'yyyy-MM-dd HH24:mi:ss'),'yyyy-MM-dd HH24:mi:ss'),
to_date(to_char(sysdate,'yyyy-MM-dd HH24:mi:ss'),'yyyy-MM-dd HH24:mi:ss'),
#{author},
#{alarmEmail},
#{executorRouteStrategy},
#{executorHandler},
#{executorParam},
#{executorBlockStrategy},
#{executorFailStrategy},
#{glueType},
#{glueSource},
#{glueRemark},
to_date(to_char(sysdate,'yyyy-MM-dd HH24:mi:ss'),'yyyy-MM-dd HH24:mi:ss'),
#{childJobKey}
)
</insert>
4、xml里头不支持<=等不等符号,解决方法:
<![CDATA[ <= ]]>
标记避免Sql中与xml规范相冲突的字符对xml映射文件的合法性造成影响,ibatis中应该经常见到"<![CDATA["这样的东西吧,它的用处应该是转义一些特殊关键字字符,不合法的XML字符必须被替换为相应的实体。
下面是五个在XML文档中预定义好的实体:
< > 小于号
> < 大于号
& & 和
' ' 单引号
" " 双引号
应该留意,在"<![CDATA["转义符中间不要用标签
比如就可以这么用
<message><![CDATA[if salary < 1000 then]]</message>
例如:
<select id="isExistsCode" parameterType="String" resultType="Boolean">
<![CDATA[
select count(*) from afa_sample_agency where code = #{code} and id<>#{id}
]]>
</select>
或者可以用转义字符进行书写。
<select id="queryOverDueFileInfos" resultType="com.bosssoft.platform.domain.filemgr.FileInfo">
SELECT * FROM AFA_ATTACH_FILEINFO WHERE bizType=#{bizType} and createtime<#{overDueDate}
</select>
5、#和$的区别:
6、Cause: java.sql.SQLSyntaxErrorException: ORA-01745: 无效的主机/绑定变量名
原因,sql语句中,两个填充变量间没有写逗号
7、Oracle修改时间报:ORA-01830: 日期格式图片在转换整个输入字符串之前结束的解决办法
1、错误原因:
date类型不能包含秒以后的精度。
如日期:2010-01-01 20:02:20.0
解决方法:将日期秒以后的精度去除
如日期:2010-01-01 20:02:20
2、INSERT INTO TEST2 (C1, C2,c3) VALUES (${v1},${v2},to_date(${v3},'yyyy-mm-dd'));
oracle里面不需要以“;”结尾。
8、Java.sql.SQLException: ORA-01810: 格式代码出现两次
在sql语句中也就to_date只有格式,所以错就在这里。总结发现:Oracle格式是不区分大小写的,所以MM和mm是一样的 可能会以月份的形式显示。所以oracle中用了mi来代替MM。
9、Oracle里头不区分大小写:
Oracle里头不区分大小写,所以要求有大小写区分的地方,可以用别名进行转换。
<select id="triggerCountByDay" resultType="java.util.Map" databaseId="Oracle">
select triggerDay "triggerDay", COUNT(id) "triggerCount" from(
SELECT to_char(trigger_time, 'yyyy-MM-dd') triggerDay,id
FROM BOS_QRTZ_TRIGGER_LOG
WHERE trigger_time BETWEEN #{from} and #{to}
<if test="handleCode gt 0">
AND handle_code = #{handleCode}
</if>)
GROUP BY triggerDay
</select>
Oracl使用总结二的更多相关文章
- P6 EPPM R16.1安装与配置指南(二)
P6 EPPM R16.1安装与配置指南(一) http://www.cnblogs.com/endv/p/5634620.html P6 EPPM R16.1安装与配置指南(二) 环境变量配置 新建 ...
- oracl使用DataBase Configuration Assistant创建、删除数据库
原文:oracl使用DataBase Configuration Assistant创建.删除数据库 可以使用DataBase Configuration Assistant来创建一个心得数据库.Da ...
- Oracl 12c安装
Oracl安装部署 一.前置条件准备 修改hostname: hostname oracle 修改/etc/hosts:添加192.168.10.106 oracle 添加软件开发工具 搭建yum源 ...
- 【小程序分享篇 二 】web在线踢人小程序,维持用户只能在一个台电脑持登录状态
最近离职了, 突然记起来还一个小功能没做, 想想也挺简单,留下代码和思路给同事做个参考. 换工作心里挺忐忑, 对未来也充满了憧憬与担忧.(虽然已是老人, 换了N次工作了,但每次心里都和忐忑). 写写代 ...
- 前端开发中SEO的十二条总结
一. 合理使用title, description, keywords二. 合理使用h1 - h6, h1标签的权重很高, 注意使用频率三. 列表代码使用ul, 重要文字使用strong标签四. 图片 ...
- 【疯狂造轮子-iOS】JSON转Model系列之二
[疯狂造轮子-iOS]JSON转Model系列之二 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇<[疯狂造轮子-iOS]JSON转Model系列之一> ...
- 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新
上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...
- 谈谈一些有趣的CSS题目(十二)-- 你该知道的字体 font-family
开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题 ...
- MIP改造常见问题二十问
在MIP推出后,我们收到了很多站长的疑问和顾虑.我们将所有疑问和顾虑归纳为以下二十个问题,希望对大家理解 MIP 有帮助. 1.MIP 化后对其他搜索引擎抓取收录以及 SEO 的影响如何? 答:在原页 ...
随机推荐
- 026_默认的MapReduce Driver(最小驱动问题)
1. 最小配置的MapReduce Driver 读取输入文件中的内容,输出到指定目录的输出文件中,此时文件中的内容为: Key---输入文件每行内容的起始位置. Value---输入文件每行的原始内 ...
- Linux文件系统管理 常见命令df、du、fsck、dumpe2fs
概述 Linux文件系统管理 常见命令df.du.fsck.dumpe2fs. 文件系统查看命令:df 通过 df 命令可以査看已经挂载的文件系统的信息包括设备文件名.文件系统总大小.已经使用的大小. ...
- 【TopCoder】SRM160 DIV1总结
做了两道题之后才发现做的是DIV1,不是DIV2,DIV1的第二道题是DIV1的第三道题,果断决定第3题就不看了=.= 250分题:给定一个时间起点8:00 AM DAY 1,再给出一组时间终点,格式 ...
- 【Head First Servlets and JSP】笔记8:监听者
1.你不用了解所有监听者API,并不多,一共有8个.不过,你需要知道你能监听什么,以便在需要的时候可以查. 2.关于Session和Cookie.参见JavaWeb学习总结(十二)——Session ...
- 20165101 实验一 Java开发环境的熟悉
#20165103 实验一 Java开发环境的熟悉 实验报告 封面 实验要求 第一部分 1.建立"自己学号exp1"的目录 2.在"自己学号exp1"目录下建立 ...
- ibecon后台运行
程序被硬关闭后,只能执行这三个回调,而且必须写在appdelegate中,退出ibeacons信息区域时会有延时10秒左右,进入时无延时 - (void)locationManager:(CLLoca ...
- linux 安装jdk1.7 环境
由于各Linux开发厂商的不同,因此不同开发厂商的Linux版本操作细节也不一样,今天就来说一下CentOS下JDK的安装: 方法一:手动解压JDK的压缩包,然后设置环境变量 1.在/usr/目录下创 ...
- RPC与HTTP
一.为什么需要RPC,而不是简单的HTTP接口? RPC(即Remote Procedure Call,远程过程调用),主要是基于TCP/IP协议:而HTTP服务主要是基于HTTP协议的.我们都知道H ...
- 解决maven寻找依赖关系失败的问题
在mac中会碰到依赖jdk自带的jar包而maven找不到的问题 解决方案:安装jdk中的tools到本地mvn库 mvn install:install-file -Dfile=${JAVA_HOM ...
- Python httpServer服务器(初级)
使用原生的python开发的web服务器,入门级! #!/usr/bin/python # -*- coding: UTF-8 -*- import os #Python的标准库中的os模块包含普遍的 ...