데이터 베이스 MySQL 튜토리얼 Access分页及效率分析(MSSQL Server、Oracle分页)

Access分页及效率分析(MSSQL Server、Oracle分页)

Jun 07, 2016 pm 03:50 PM
access mssql o server 분석하다 쪽수 매기기 능률

在实际过运用过程中,我们开发的项目有时需要支持多种数据库,那么在开发中我们会遇到不同的数据库在SQL语句方面还有区别,导致我们有些细节需要去调整,下面就分页功能在不同的数据库中的具体使用详细说明。 一、Access数据库分页与效率分析 由于Access操作

 在实际过运用过程中,我们开发的项目有时需要支持多种数据库,那么在开发中我们会遇到不同的数据库在SQL语句方面还有区别,导致我们有些细节需要去调整,下面就分页功能在不同的数据库中的具体使用详细说明。

 

一、Access数据库分页与效率分析
        由于Access操作简单,调用,迁移方便,节省费用,对于搭建者的能力要求也会低些,对于较小量的数据,我们使用Access数据库是比较适合的,但是随着数据量增加,达到几十万、几百万甚至更多的时候,那么数据库的效率就会出现问题了,这个时候比如像分页功能可能就出现问题了,下面我们就看看常见的Access分页有哪些方式?

        方案一:使用ADO.NET本身的结果集,使用PageSize,AbsolutePage的属性来进行分页
                        当然我一般不推荐使用拖控件进行快速开发,拖控件会导致产生大量的垃圾代码,是网站效率低下,当然在后台可以使用部分控件,今天就不说.NET拖控件效率低下的问题了,使用ADO.NE的结果集方式,每次都要读入符合条件的所有记录,然后再定位于对应页的记录。当数据量大的时候,效率就十分的低下。
        方案二:使用not in 方式

                       select top 3 * from Article where Id not in(select top 6 Id from Article)
                       使用not in 方式,其中的top效率很高,但是not in 呢? 测试发现,当数据量比较小时还是挺快的,但是当到达10万条数据是,单击查询就慢了,如果使用该分页方式,当数据量很大时,估计天天有人在骂:这是哪个SB开发的系统啊,这么垃圾!
       方案三:使用select top pageSize * from (select top pageindex*pageSize * from ywgl_news order by id desc) order by id
                       在实际过程中发现,当数据量比较大是,使用这种方式分页,Access的效率还可以,比not in 方式效率高多了,但是此处也需要注意的是:很多人喜欢使用select * from 表名, 实际中发现这不是一个好习惯,我们应该需要什么字段查询什么字段,这样能够极大的节省服务器资源。

 

二、MSSQL Server和Oracle数据库的分页
        当然MSSQL Server和Oracle数据库的分页可以选择的方式更多,除了使用ADO.NET数据集、Not in 方式、Select top方式外,还有row_number方式等更好的分页实现方式,
                  select * from
                               (select * ,row_number() over(order by Id) rownumber from T_Users) as t
                  where t.rownumber>4 and t.rownumber         需要注意的是:在MSSQL Server和Oracle中使用row_number还有些细节不同,下面就是Oracle和MS SqlServer中的具体分页方式:
                  int start = (pageindex - 1) * pageSize;
                  int end = pageindex * pageSize;
       Oracle的分页T-SQL语句:
                 string sql = "select * from(select a.*,rownum row_num from(select * from ywgl_news t {0} order by t.Id desc) a)b where b.row_num>" + start.ToString() + " and b.row_num         MSSQL Server的分页T-SQL语句:
                 string sql = "select * from(select * ,row_number() over(order by Id) rownumber from ywgl_news {0}) as t where t.rownumber>"+start.ToString()+" and t.rownumber

 

三、附录存储过程的写法(MSSQL SERVER为例)      
        --创建存储过程row_number方式
        alter proc GetPageForRownumber
        (
               @pageIndex int,--当前页
               @pageSize int,--页容量
               @rowCount int out,--总行数
               @pageCount int out --总页数
         )
         as
         begin
         declare @sql nvarchar(225)
         select @rowCount=count(Id),@pageCount=ceiling((count(Id)+0.0)/@pageSize) from T_Users
         set @sql='select * from
                                        (select * ,row_number() over(order by Id) rownumber from T_Users) as t
                          where t.rownumber>'+str((@pageIndex-1)*@pageSize)+' and t.rownumber           exec(@sql)
          end

         ---测试row_number 方式的存储过程
         declare @rc int,@pc int
         exec GetPageForRownumber 3,2,@rc out,@pc out
         select @rc,@pc

 

四、开发中遇到的小问题
       1、报错"标准表达式中数据类型不匹配。"
             Access在进行参数化查询的时候老是报错,这让哥很纳闷啊,看着SQL语句也是对的,参数的值也是对的,为什么老是提示报错呢?如下图代码就会报该错误。
                          string sql = "UPDATE ywgl_News set New_Title=@New_Title, New_Source=@New_Source ,New_ReadCount=@New_ReadCount,New_Content=@New_Content,New_Summary=@New_Summary,New_Author=@New_Author,New_ClassId=@New_ClassId where Id=@Id";
                        OleDbParameter[] para = new OleDbParameter[]
                        {
                     
                                 new OleDbParameter("@Id",model.New_id),
                                 new OleDbParameter("@New_Title",ToDBValue(model.New_title)),
                                 new OleDbParameter("@New_Source",ToDBValue(model.New_source)),
                                 new OleDbParameter("@New_ReadCount",ToDBValue(model.New_readcount)),
                                 new OleDbParameter("@New_Content",ToDBValue(model.New_content)),
                                 new OleDbParameter("@New_Summary",ToDBValue(model.New_summary)),
                                 new OleDbParameter("@New_Author", ToDBValue(model.New_author)),
                                 new OleDbParameter("@New_ClassId",ToDBValue(model.New_class.Id))  
                         };
                         num = AccessHelper.ExecuteNonQuery(sql, para);
         经过查找原因,原来问题出在”@“符号上了,我们可以用”?“占位符替换,这个MSSQL Server有点小不同,如果使用了”@“那么就要确保各个参数的顺序一致。否则就报该错误。
         2、在删除操作时删除不了
               各个数据库具体T-SQL语句还有些不同,在Oracle中中 string sql = "Delete ywgl_news where Id=:Id";可以删除,没问题,但是在Access中这样写就不行了应该这样写:
                string sql = "Delete from ywgl_news where Id=@Id";

 

五、总结三种不同数据库的分页方式及效率
        那么我们在实际应用中,到底该选择哪种类型的数据库呢?使用Access,还是MSSQL Server,还是Oracle?不要觉得Oracle就觉得你的系统很牛B,这个需要根据系统的定位和使用者来进行确定,如果说是一个很小的政府门户网站,数据量也很小,那么用一个Access完全够了,而且数据量很小的时候,Access的速度还更快,当然如果说是做GIS的国土数据整合系统,那像这样的海量的数据,那就肯定需要用像Oracle大型数据库了。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Windows 11에서 백그라운드 애플리케이션을 비활성화하는 방법_Windows 11 튜토리얼에서 백그라운드 애플리케이션을 비활성화하는 방법 Windows 11에서 백그라운드 애플리케이션을 비활성화하는 방법_Windows 11 튜토리얼에서 백그라운드 애플리케이션을 비활성화하는 방법 May 07, 2024 pm 04:20 PM

1. Windows 11에서 설정을 엽니다. Win+I 단축키나 다른 방법을 사용할 수 있습니다. 2. 앱 섹션으로 이동하여 앱 및 기능을 클릭합니다. 3. 백그라운드에서 실행되는 것을 방지하려는 애플리케이션을 찾으세요. 점 3개 버튼을 클릭하고 고급 옵션을 선택합니다. 4. [백그라운드 애플리케이션 권한] 섹션을 찾아 원하는 값을 선택하세요. 기본적으로 Windows 11은 전원 최적화 모드를 설정합니다. 이를 통해 Windows는 애플리케이션이 백그라운드에서 작동하는 방식을 관리할 수 있습니다. 예를 들어, 배터리를 절약하기 위해 배터리 절약 모드를 활성화하면 시스템은 모든 앱을 자동으로 닫습니다. 5. 애플리케이션이 백그라운드에서 실행되는 것을 방지하려면 [안함]을 선택합니다. 프로그램이 알림을 보내지 않거나 데이터를 업데이트하지 못하는 경우 등을 확인할 수 있습니다.

DeepSeek PDF를 변환하는 방법 DeepSeek PDF를 변환하는 방법 Feb 19, 2025 pm 05:24 PM

DeepSeek은 파일을 PDF로 직접 변환 할 수 없습니다. 파일 유형에 따라 공통 문서 (Word, Excel, PowerPoint) : Microsoft Office, LibreOffice 및 기타 소프트웨어를 사용하여 PDF로 내보내십시오. 이미지 : 이미지 뷰어 또는 이미지 처리 소프트웨어를 사용하여 PDF로 저장하십시오. 웹 페이지 : 브라우저의 "PDF로 인쇄"기능 또는 전용 웹 페이지에서 PDF 도구를 사용하십시오. 드문 형식 : 오른쪽 변환기를 찾아 PDF로 변환하십시오. 올바른 도구를 선택하고 실제 상황에 따라 계획을 개발하는 것이 중요합니다.

오라클에서 dbf 파일을 읽는 방법 오라클에서 dbf 파일을 읽는 방법 May 10, 2024 am 01:27 AM

Oracle은 다음 단계를 통해 dbf 파일을 읽을 수 있습니다. 외부 테이블을 만들고 dbf 파일을 참조하여 데이터를 Oracle 테이블로 가져옵니다.

PHP에서 배열 페이지 매김을 구현하는 가장 좋은 방법 PHP에서 배열 페이지 매김을 구현하는 가장 좋은 방법 May 04, 2024 pm 02:39 PM

PHP 배열을 페이지화하는 가장 일반적인 두 가지 방법은 array_slice() 함수를 사용하는 것입니다. 건너뛸 요소 수를 계산한 다음 지정된 요소 범위를 추출합니다. 내장 반복자 사용: Iterator 인터페이스를 구현하고 rewind(), key(), current(), next() 및 valid() 메서드를 사용하여 지정된 범위 내의 요소를 탐색합니다.

Botanix 해석: 네트워크 자산 관리를 위한 분산형 BTC L2(대화형 튜토리얼 포함) Botanix 해석: 네트워크 자산 관리를 위한 분산형 BTC L2(대화형 튜토리얼 포함) May 08, 2024 pm 06:40 PM

어제 BotanixLabs는 Polychain Capital, Placeholder Capital 등의 참여로 총 1,150만 달러의 자금 조달을 완료했다고 발표했습니다. 자금 조달은 BTCL2Botanix와 동등한 분산형 EVM을 구축하는 데 사용됩니다. Spiderchain은 EVM의 사용 편의성과 비트코인의 보안을 결합합니다. 2023년 11월 테스트넷이 시작된 이후 활성 주소는 200,000개가 넘었습니다. Odaily는 이번 기사에서 Botanix의 특징적인 메커니즘과 테스트넷 상호 작용 프로세스를 분석할 것입니다. Botanix 공식 정의에 따르면 Botanix는 비트코인을 기반으로 구축된 분산형 Turing-complete L2EVM이며 두 가지 핵심 구성 요소로 구성됩니다. Ethereum Virtual Machine

접근 위반 오류 해결 방법 접근 위반 오류 해결 방법 May 07, 2024 pm 05:18 PM

액세스 위반 오류는 프로그램이 메모리 할당을 초과하는 메모리 위치에 액세스할 때 발생하는 런타임 오류로, 이로 인해 프로그램이 중단되거나 비정상적으로 종료됩니다. 해결 방법에는 배열 경계 확인, 적절한 메모리 할당 기능 사용, 메모리 오버플로 확인, 실행 추적을 위한 타사 라이브러리 확인, .

Win11에서 원격 데스크톱 제어를 활성화하는 방법_Win11에서 원격 데스크톱 제어를 활성화하는 방법 Win11에서 원격 데스크톱 제어를 활성화하는 방법_Win11에서 원격 데스크톱 제어를 활성화하는 방법 May 08, 2024 pm 12:19 PM

1. 시작 메뉴에서 제어판 페이지를 검색하세요. 2. 그런 다음 제어판에서 보기를 범주로 변경하고 시스템 및 보안을 클릭합니다. 3. 시스템 아래에서 원격 액세스 허용 버튼을 찾아 클릭합니다. 4. 팝업 창에서 원격 시스템 속성 열을 클릭하고 이 컴퓨터에 대한 원격 연결 허용 버튼을 선택한 후 확인을 클릭하여 저장합니다.

Java 리플렉션 메커니즘은 클래스의 동적 로딩을 어떻게 구현합니까? Java 리플렉션 메커니즘은 클래스의 동적 로딩을 어떻게 구현합니까? May 04, 2024 pm 03:42 PM

Java 리플렉션 메커니즘을 사용하면 런타임 시 클래스를 동적으로 로드하고 인스턴스화할 수 있으며, 클래스, 메소드 및 필드를 포함하는 java.lang.reflect 패키지의 클래스를 통해 클래스 메타데이터를 조작할 수 있습니다. 예제 클래스 로드, 객체 인스턴스화, 메서드 획득 및 호출 등의 실제 사례를 통해 동적으로 로드된 클래스에서 해당 애플리케이션을 시연할 수 있으므로 프로그래밍 문제를 해결하고 유연성이 향상됩니다.

See all articles