Oracle问题小记五:服务启动-索引-子查询-分页存储过程
2011-05-10 16:56
302 查看
今天,把 秋色园QBlog 的数据导到Oracle中运行,重拾Oracle,过程的主要问题记录下:
1:服务启动问题
这个问题发生多次了,那个毛网管没事又让人改计算名称,Oracle久没开了也没在意,Oracle服务启动总失败,折腾后才发现,于是把计算机名称改回去,重启电脑,再启用服务,正常。
2:索引问题
数据导到Oracle后,发现一些简单的查询变的相当的慢如:
select id,username,title from blog_content where userid=111 order by id desc
后来经网页点拔,给title加上索引就快了:“select中的放在包含索引(oracle中称覆盖索引)”
后来其它查询慢的,全给加索引,速度才上去,看来搞Oracle不搞索引,是没法玩的。
3:子查询语句问题
正常代码:
SELECT count(*) as UserCount,
(SELECT count(*) FROM Blog_Content WHERE TypeID=0) as ArticleCount
FROM Blog_User
此语句在Access、Mssql、Sqlite、Mysql下皆正常,唯独 Oracle不成,加个函数解决如下:
SELECT count(*) as UserCount,
min((SELECT count(*) FROM Blog_Content WHERE TypeID=0)) as ArticleCount
FROM Blog_User
4:存储过程调用问题
问题:
存储过程的参数varchar2,如果代码中参数为空,会报异常:ORA-01084: invalid argument in OCI call view
如果在PL/SQL中执行,而不会错。
解决方法是为空时,传递DBNull.Value。
5:完善 CYQ.Data for Oracle 版本分页存储过程。
直接修改了文章:折腾Oracle问题小菜记[分页存储过程/查询所有表、视图、存储过程/查询表、视图、存储过程字段结构与参数](三)
6:修改字段顺序
增加列,又不想放在最后面,拉不上去,只好写代码更改顺序号。
select object_id from all_objects where object_name='BLOG_COMMENT'--查表ID
select COL#,name from sys.col$ where obj#=49244--看一下字段顺序序号
update sys.col$ set COL#=8 where obj#=49244 and name='CREATETIME'--把序号更新了
7:更新序列初始值
数据库共用一个序列为自增ID,导完数据后序列值没变,需要调整值。
ALTER SEQUENCE 序列名称 Increment By 新的数字;
1:服务启动问题
这个问题发生多次了,那个毛网管没事又让人改计算名称,Oracle久没开了也没在意,Oracle服务启动总失败,折腾后才发现,于是把计算机名称改回去,重启电脑,再启用服务,正常。
2:索引问题
数据导到Oracle后,发现一些简单的查询变的相当的慢如:
select id,username,title from blog_content where userid=111 order by id desc
后来经网页点拔,给title加上索引就快了:“select中的放在包含索引(oracle中称覆盖索引)”
后来其它查询慢的,全给加索引,速度才上去,看来搞Oracle不搞索引,是没法玩的。
3:子查询语句问题
正常代码:
SELECT count(*) as UserCount,
(SELECT count(*) FROM Blog_Content WHERE TypeID=0) as ArticleCount
FROM Blog_User
此语句在Access、Mssql、Sqlite、Mysql下皆正常,唯独 Oracle不成,加个函数解决如下:
SELECT count(*) as UserCount,
min((SELECT count(*) FROM Blog_Content WHERE TypeID=0)) as ArticleCount
FROM Blog_User
4:存储过程调用问题
问题:
存储过程的参数varchar2,如果代码中参数为空,会报异常:ORA-01084: invalid argument in OCI call view
如果在PL/SQL中执行,而不会错。
解决方法是为空时,传递DBNull.Value。
5:完善 CYQ.Data for Oracle 版本分页存储过程。
直接修改了文章:折腾Oracle问题小菜记[分页存储过程/查询所有表、视图、存储过程/查询表、视图、存储过程字段结构与参数](三)
6:修改字段顺序
增加列,又不想放在最后面,拉不上去,只好写代码更改顺序号。
select object_id from all_objects where object_name='BLOG_COMMENT'--查表ID
select COL#,name from sys.col$ where obj#=49244--看一下字段顺序序号
update sys.col$ set COL#=8 where obj#=49244 and name='CREATETIME'--把序号更新了
7:更新序列初始值
数据库共用一个序列为自增ID,导完数据后序列值没变,需要调整值。
ALTER SEQUENCE 序列名称 Increment By 新的数字;
相关文章推荐
- Oracle问题小记五:服务启动-索引-子查询-分页存储过程
- Oracle问题小记五:服务启动-索引-子查询-分页存储过程
- Oracle问题小记五:服务启动-索引-子查询-分页存储过程
- 折腾Oracle问题小菜记[分页存储过程/查询所有表、视图、存储过程/查询表、视图、存储过程字段结构与参数](三)
- 折腾Oracle问题小菜记[分页存储过程/查询所有表、视图、存储过程/查询表、视图、存储过程字段结构与参数](三)
- 折腾Oracle问题小菜记[分页存储过程/查询所有表、视图、存储过程/查询表、视图、存储过程字段结构与参数](三)
- 折腾Oracle问题小菜记[分页存储过程/查询所有表、视图、存储过程/查询表、视图、存储过程字段结构与参数](三)
- 多表查询分页存储过程,解决了第二页不显示的问题
- oracle实现存储过程分页查询(非包)
- Oracle多条件查询分页存储过程
- Oracle 存储过程之通用分页查询
- 存储过程分页查询(ORACLE)
- oracle 分页查询存储过程
- c# oracle 存储过程分页查询
- c# oracle 存储过程分页查询
- 简单搞一下 Oracle 存储过程动态SQL之获取查询分页!
- 多表查询分页存储过程,解决了第二页不显示的问题
- 通用分页存储过程注入问题解决方案:不用存储过程,通用分页查询方法
- Oracle分页查询的一个存储过程:
- oracle入门(8)——实战:支持可变长参数、多种条件、多个参数排序、分页的存储过程查询组件