데이터 베이스 MySQL 튜토리얼 创建 Oracle 分页存储过程

创建 Oracle 分页存储过程

Jun 07, 2016 pm 05:46 PM
cursor quot varchar

1.创建Oracle包的定义。使用 REF CURSOR 数据类型来处理 Oracle 结果集。REF CURSOR 是一个指向 PL/SQL 查询所返回的结果集的指针。与普通的游标不同,REF CURSOR 是一个变量,它是对游标的引用

1.创建Oracle包的定义。使用 REF CURSOR 数据类型来处理 Oracle 结果集。REF CURSOR 是一个指向 PL/SQL 查询所返回的结果集的指针。与普通的游标不同,REF CURSOR 是一个变量,它是对游标的引用

1.创建Oracle包的定义。使用 REF CURSOR 数据类型来处理 Oracle 结果集。REF CURSOR 是一个指向 PL/SQL 查询所返回的结果集的指针。与普通的游标不同,REF CURSOR 是一个变量,它是对游标的引用,可以在执行时将其设置为指向不同的结果集。使用 REF CURSOR 输出参数可以将 Oracle 结构化程序的结果集传递回调用应用程序。通过在调用应用程序中定义 OracleType.Cursor 数据类型的输出参数,可以访问 REF CURSOR 所指向的结果集。

<span><blockquote>
<pre class="brush:php;toolbar:false"><span>create or replace package MF_PAK_001 is<br>  type t_cursor is ref cursor;<br>  procedure GetDataByPage(<br>     p_tableName varchar2,<br>     p_fields varchar2,<br>     p_filter varchar2,<br>     p_sort varchar2,<br>     p_curPage number,<br>     p_pageSize number,<br>     p_cursor out t_cursor,<br>     p_totalRecords out number         <br> );<br>end MF_PAK_001;</span>
로그인 후 복사
2.创建包体。在包体中实现具体的存储过程。

<span><blockquote><span>create or replace package body MF_PAK_001 is<br>procedure GetDataByPage(<br>p_tableName varchar2,--要查询的表名<br>p_fields varchar2,--要查询的字段<br>p_filter varchar2,--过滤条件<br>p_sort varchar2,--排序字段及方向<br>p_curPage number,<br>p_pageSize number,<br>p_cursor out t_cursor,<br>p_totalRecords out number <br>)<br>is<br>v_sql varchar2(1000):='';<br>v_startRecord number(4);<br>v_endRecord number(4);<br>begin<br></span></blockquote>--获取总的记录数<br> <blockquote><span>v_sql:=' to_number(count(*)) from '||p_tableName;<br>if p_filter is not null then<br>v_sql:=v_sql||' where 1=1 and '||p_filter;<br>end if;<br>execute immediate v_sql into p_totalRecords;<br><br>v_startRecord:=(p_curPage-1)*p_pageSize;<br>v_endRecord:=p_curPage*p_pageSize;<br><br>v_sql:='select '||p_fields||' from (select '||p_fields||',rownum r from '||<br>'(select '||p_fields||' from '||p_tableName;<br>if p_filter is not null then<br>v_sql:=v_sql||' where 1=1 and '||p_filter;<br>end if;<br>if p_sort is not null then<br>v_sql:=v_sql||' order by '||p_sort;<br>end if;<br>v_sql:=v_sql||') A where rownum='||to_char(v_startRecord);<br>open p_cursor for v_sql;<br><br>end GetDataByPage; <br>end MF_PAK_001;</span></blockquote></span>3.在Oracle中编写查询语句,执行包体中的分页存储过程,看是否能够正确执行。
로그인 후 복사

<span><blockquote>
<p></p>
<pre class="brush:php;toolbar:false"><span>declare<br>v_cur MF_PAK_001.t_cursor;<br>v_job jobs%rowtype;<br>v_totalRecords number;<br>begin<br>  MF_PAK_001.GetDataByPage('jobs','job_id,job_title,min_salary,max_salary','min_salary>0','job_id asc',</span>
로그인 후 복사
<span>  1,10,v_cur,v_totalRecords);<br>  fetch v_cur into v_job;<br>  while v_cur%found loop<br>    dbms_output.put_line(v_job.job_id||','||v_job.job_title);<br>    fetch v_cur into v_job;<br>  end loop;<br>  dbms_output.put_line('总记录数为:'||v_totalRecords);<br>end;</span>
로그인 후 복사
4.在.NET中调用该分页存储过程。

<span><blockquote>
<pre class="brush:php;toolbar:false"><span>string connString = "Data Source=ORCL;User Id=hr;Password=Pwd123456";<br>OracleConnection conn = new OracleConnection(connString);<br><br>OracleCommand cmd = new OracleCommand();<br>cmd.Connection = conn;<br>cmd.CommandText = "MF_PAK_001.GetDataByPage";<br>cmd.CommandType = CommandType.StoredProcedure;<br><br>cmd.Parameters.Add("p_tableName", OracleType.VarChar).Value = "jobs";<br>cmd.Parameters.Add("p_fields", OracleType.VarChar).Value = "job_id,job_title,min_salary,max_salary";<br>cmd.Parameters.Add("p_filter", OracleType.VarChar).Value = "";<br>cmd.Parameters.Add("p_sort", OracleType.VarChar).Value = "job_id asc";<br>cmd.Parameters.Add("p_curPage", OracleType.Number).Value = 1;<br>cmd.Parameters.Add("p_pageSize", OracleType.Number).Value = 10;<br>cmd.Parameters.Add("p_cursor", OracleType.Cursor).Direction =ParameterDirection.Output;<br>cmd.Parameters.Add("p_totalRecords", OracleType.Number).Direction = ParameterDirection.Output;<br><br>conn.Open();<br>OracleDataReader dr = cmd.ExecuteReader();<br><br>while (dr.Read())<br>{<br>    for (int i = 0; i         Response.Write(dr[i].ToString() + ";");<br>    Response.Write("<br>");<br>}<br>conn.Close();</span>
로그인 후 복사
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

mysql에서 varchar 유형을 사용하여 날짜 비교, 정렬 및 기타 작업을 구현하는 방법 mysql에서 varchar 유형을 사용하여 날짜 비교, 정렬 및 기타 작업을 구현하는 방법 May 31, 2023 pm 01:49 PM

MySQL을 사용하는 동안 날짜는 일반적으로 날짜/시간, 타임스탬프 및 기타 형식으로 저장됩니다. 그러나 때로는 특별한 필요나 역사적 이유로 인해 날짜가 varchar 형식으로 저장됩니다. 함수 사용: STR_TO_DATE(str,format) STR_TO_DATE(str,format) 함수는 DATE_FORMAT() 함수의 역함수입니다. 문자열 str과 형식 문자열 형식을 사용합니다. STR_TO_DATE()는 형식 문자열에 날짜 및 시간 구성 요소가 포함되어 있거나 단어가 다음과 같은 경우 DATETIME 값을 반환합니다.

mysql에서 char과 varchar의 차이점은 무엇입니까 mysql에서 char과 varchar의 차이점은 무엇입니까 Sep 04, 2023 pm 02:16 PM

mysql에서 char과 varchar의 차이점은 다음과 같습니다. 1. CHAR는 고정 길이이고 VARCHAR은 가변 길이입니다. 2. CHAR 저장 및 검색 효율성은 높지만 VARCHAR 저장 및 검색 효율성은 높지 않습니다. 3. CHAR는 저장 공간을 차지합니다. , VARCHAR을 사용하면 저장 공간을 절약할 수 있습니다.

CSS 보조 스타일 속성 구문 분석: 커서 및 포인터 이벤트 CSS 보조 스타일 속성 구문 분석: 커서 및 포인터 이벤트 Oct 20, 2023 am 11:21 AM

CSS 보조 스타일 속성 분석: 웹 사이트 개발 시 커서 및 포인터 이벤트는 종종 일부 보조 스타일 속성을 통해 달성해야 하는 특별한 요구 사항에 직면합니다. 커서 및 포인터 이벤트는 사용자가 페이지와 상호 작용할 때 더 나은 피드백과 제어를 제공하는 일반적으로 사용되는 두 가지 스타일 속성입니다. 이 기사에서는 이 두 가지 속성을 자세히 분석하고 구체적인 코드 예제를 제공합니다. 1. 커서 속성 커서 속성은 마우스를 정의하는 데 사용됩니다.

MySQL은 VARCHAR의 크기를 어떻게 결정합니까? MySQL은 VARCHAR의 크기를 어떻게 결정합니까? May 27, 2023 pm 09:20 PM

우선 TEXT 유형을 사용하는 것은 효율성에 심각한 영향을 미치기 때문에 권장되지 않습니다. 가장 좋은 방법은 VARCHAR을 사용하고 필드의 최대 길이를 결정하는 것입니다. 먼저 테이블에서 rule_value 필드를 정의하고 길이를 255로 설정한 다음 가장 작은 json 문자열을 입력할 수 있습니다. MySQL의 CHAR_LENGTH 함수를 사용하여 rule_value의 크기를 계산합니다: SELECTid, rule_type, rule_value, CHAR_LENGTH(rule_value) as rule_value_length, rule_markFROMtest_tableWHEREr

不用数据库来实现用户的简单的下载,代码如下,但是却不能下载,请高手找下原因,文件路劲什么的没有关问题 不用数据库来实现用户的简单的下载,代码如下,但是却不能下载,请高手找下原因,文件路劲什么的没有关问题 Jun 13, 2016 am 10:15 AM

不用数据库来实现用户的简单的下载,代码如下,但是却不能下载,请高手找下原因,文件路劲什么的没问题。

图片消失怎么解决 图片消失怎么解决 Apr 07, 2024 pm 03:02 PM

图片消失如何解决先是图片文件上传$file=$_FILES['userfile'];  if(is_uploaded_file($file['tmp_name'])){$query=mysql_query("INSERT INTO gdb_banner(image_src ) VALUES ('images/{$file['name'

为什么小弟我在php上写的这个代码,在浏览器上什么都不显示 为什么小弟我在php上写的这个代码,在浏览器上什么都不显示 Jun 13, 2016 am 10:24 AM

为什么我在php上写的这个代码,在浏览器上什么都不显示啊

See all articles