java使用mybatis 呼叫函式返回一個遊標結果集
瀚高資料庫
@Override @Transactionalpublic List<HighgoFunOneRefcursorEntity> getOneRefcursor(Integer id) { HashMap<String, Object> map = new HashMap<String, Object>(); map.put("id", id); highgoFunOneRefcursorDao.getOneRefcursor(map); List<HighgoFunOneRefcursorEntity> list = (List<HighgoFunOneRefcursorEntity>)map.get("result"); return list;}
@Mapperpublic interface HighgoFunOneRefcursorDao extends BaseMapper<HighgoFunOneRefcursorEntity> { ArrayList<Map<String, Object>> getOneRefcursor(HashMap map); }
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.database.mybatisplus.modules.demo.dao.HighgoFunOneRefcursorDao"> <!-- 可根據自己的需求,是否要使用 --> <resultMap type="com.database.mybatisplus.modules.demo.entity.HighgoFunOneRefcursorEntity" id="highgoFunOneRefcursorMap"> <result property="hanzi" column="hanzi"/> <result property="quanpin" column="quanpin"/> <result property="szm" column="szm"/> <result property="duyin" column="duyin"/> <result property="numbersd" column="numbersd"/> <result property="sd" column="sd"/> <result property="repsd" column="repsd"/> <result property="hzascii" column="hzascii"/> </resultMap> <!-- 呼叫函式程返回一個遊標 --> <select id="getOneRefcursor" parameterType="map" statementType="CALLABLE" resultType="java.util.Map"> {#{result,mode=OUT,jdbcType=OTHER,javaType=ResultSet,resultMap=highgoFunOneRefcursorMap} = call fn_one_refcursor(#{id,mode=IN})} </select></mapper>
CREATE OR REPLACE FUNCTION test.fn_one_refcursor(integer) RETURNS refcursor LANGUAGE plpgsql AS $function$ declare $2 refcursor;begin if $1 = 1 then open $2 for select * from hzpyszm limit 100; elseif $1 = 2 then open $2 for select hanzi,quanpin,szm,duyin from hzpyszm limit 100; else open $2 for select hanzi,quanpin from hzpyszm limit 100; end if; return $2; exception when others then raise exception 'sql exception--%',sqlerrm;end;$function$;
url: jdbc:highgo://192.168.21.138:5870/test?escapeSyntaxCallMode=callIfNoReturn
CREATE TABLE hzpyszm ( hanzi varchar(4) NULL, quanpin varchar(10) NULL, szm varchar(5) NULL, duyin varchar(10) NULL, numbersd varchar(1) NULL, sd varchar(5) NULL, repsd varchar(5) NULL, hzascii int8 NULL);CREATE INDEX hzpyszm_hanzi_idx ON test.hzpyszm USING btree (hanzi varchar_pattern_ops);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('唔', 'ngn', 'n', 'ńgń', '2', NULL, NULL, 21780);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匌', 'ge', 'g', 'gé', '2', 'é', 'e', 21260);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匍', 'pu', 'p', 'pú', '2', 'ú', 'u', 21261);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匎', 'e', 'e', 'è', '4', 'è', 'e', 21262);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匏', 'pao', 'p', 'páo', '2', 'á', 'a', 21263);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匐', 'fu', 'f', 'fú', '2', 'ú', 'u', 21264);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匑', 'gong', 'g', 'gōng', '1', 'ō', 'o', 21265);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匒', 'da', 'd', 'dá', '2', 'á', 'a', 21266);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, repsd, hzascii) VALUES('匓', 'jiu', 'j', 'jiù', '4', 'ù', 'u', 21267);INSERT INTO hzpyszm (hanzi, quanpin, szm, duyin, numbersd, sd, r
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69994931/viewspace-2884862/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- java使用mybatis 呼叫儲存過程返回一個遊標結果集JavaMyBatis儲存過程
- PostgreSQL函式:返回表查詢結果集SQL函式
- python中函式如何返回多個結果?Python函式
- MyBatis 返回結果MyBatis
- iOS FMDB有返回結果集和無返回結果集iOS
- Python 工匠:讓函式返回結果的技巧Python函式
- Mybatis使用小技巧-自定義結果集MyBatis
- vue在一個函式中呼叫另外一個函式Vue函式
- SpringCloud FeignClient呼叫返回結果為null。SpringGCCloudclientNull
- mysql返回一個結果集的儲存過程小例子MySql儲存過程
- 如何使用函式指標呼叫類中的函式和普通函式函式指標
- Python返回多個結果Python
- 第 8 節:函式-函式巢狀呼叫與返回值函式巢狀
- C++ 返回函式指標的函式C++函式指標
- Mybatis 查詢語句結果集總結MyBatis
- 記錄個Java/Groovy的小問題:空字串呼叫split函式返回非空陣列Java字串函式陣列
- springboot返回結果包裝統一返回格式Spring Boot
- 小程式呼叫上一個頁面的函式函式
- javascript學習筆記--函式的返回值可以是一個函式JavaScript筆記函式
- Python中定義(建立)、呼叫函式及返回值Python函式
- Laravel 手動建立分頁返回物件結果集Laravel物件
- 編譯通過的 foo函式返回一個int編譯函式
- 將使用回撥函式作為引數的函式改造為返回 Promise 的一個具體例子函式Promise
- 全域性統一返回結果類
- Go語言:編寫一個 WebsiteRacer 的函式,用來對比請求兩個 URL 來「比賽」,並返回先響應的 URL。如果兩個 URL 在 10 秒內都未返回結果,返回一個 error。GoWeb函式Error
- Mybatis 強大的結果集對映器resultMapMyBatis
- 函式呼叫時用const保護指標函式指標
- Solon 統一的返回結果調整
- java統一返回標準型別Java型別
- js 使用 DotNetObjectReference 呼叫 c# 函式JSObjectC#函式
- 【Python基礎】Python 函式返回多個值和函式註解Python函式
- Gin 框架 JSON 格式返回結果的使用方式框架JSON
- go 如何處理資料庫返回的多結果集Go資料庫
- Python學習之函式返回多個值Python函式
- Python的函式能返回多個值嗎Python函式
- Python中將函式作為另一個函式的引數傳入並呼叫Python函式
- Swift 函式提前返回Swift函式
- strcmp()函式,如果兩個字串引數相同,該函式就返回0,否則返回非零值函式字串