今天,把 秋色园QBlog 的数据导到Oracle中运行,重拾Oracle,过程的主要问题记录下:
1:服务启动问题
2:索引问题
数据导到Oracle后,发现一些简单的查询变的相当的慢如:
select id,username,title from blog_content where userid=111 order by id desc
后来经网页点拔,给title加上索引就快了:“select中的放在包含索引(oracle中称覆盖索引)”
后来其它查询慢的,全给加索引,速度才上去,看来搞Oracle不搞索引,是没法玩的。
3:子查询语句问题
正常代码:
(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:存储过程调用问题
问题:
如果在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 新的数字;
版权声明:本文原创发表于 博客园,作者为 路过秋天 本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。 |
个人微信公众号![]() |
Donation(扫码支持作者):支付宝:![]() |
Donation(扫码支持作者):微信:![]() |
![]() |
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)