创建 Oracle 分页存储过程
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>
<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>
<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>

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



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

Bei der Verwendung von MySQL werden Daten im Allgemeinen in den Formaten datetime, timestamp und anderen gespeichert. Aus besonderen Gründen oder aus historischen Gründen werden die Datumsdaten jedoch im Varchar-Format gespeichert. Funktion verwenden: STR_TO_DATE(str,format) Die Funktion STR_TO_DATE(str,format) ist die Umkehrfunktion der Funktion DATE_FORMAT(). Es benötigt einen String str und einen Formatstring format. STR_TO_DATE() gibt einen DATETIME-Wert zurück, wenn die Formatzeichenfolge Datums- und Uhrzeitkomponenten enthält oder wenn das Wort

Die Unterschiede zwischen char und varchar in MySQL sind: 1. CHAR hat eine feste Länge, während VARCHAR eine variable Länge hat. 2. Die Speicher- und Abrufeffizienz von CHAR ist hoch, während die Speicher- und Abrufeffizienz von VARCHAR nicht hoch ist , VARCHAR kann Speicherplatz sparen.

Analyse von CSS-Hilfsstilattributen: Cursor- und Zeigerereignisse stoßen bei der Website-Entwicklung häufig auf besondere Anforderungen, die über einige Hilfsstilattribute implementiert werden müssen. Cursor- und Zeigerereignisse sind zwei häufig verwendete Stilattribute, die ein besseres Feedback und eine bessere Kontrolle bieten, wenn Benutzer mit der Seite interagieren. In diesem Artikel werden diese beiden Eigenschaften im Detail analysiert und spezifische Codebeispiele bereitgestellt. 1. Cursor-Attribut Das Cursor-Attribut wird zur Definition der Maus verwendet

Erstens wird die Verwendung des TEXT-Typs nicht empfohlen, da die Verwendung von TEXT die Effizienz erheblich beeinträchtigt. Der beste Weg ist die Verwendung von VARCHAR und die Bestimmung der maximalen Länge des Feldes. Wir können zuerst ein Feld „rule_value“ in der Tabelle definieren und die Länge auf 255 festlegen und dann die kleinste JSON-Zeichenfolge eingeben: Verwenden Sie die CHAR_LENGTH-Funktion von MySQL, um die Größe von „rule_value“ zu berechnen: SELECTid, „rule_type“, „rule_value“, „CHAR_LENGTH(rule_value)“ als „rule_value_length“, „rule_markFROMtest_tableWHEREr“.

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

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