- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要帮助来查看以下查询,我有如下表格:
CREATE TABLE "MasterDivision"
(
"DivisionID" bigserial NOT NULL,
"DivisionName_EN" character varying(70) NOT NULL,
"DivisionName_HI" character varying(70) NOT NULL,
"DivisionCode" character varying(70) NOT NULL,
"StateID" bigint NOT NULL,
"CreatedBy" bigint NOT NULL,
"UpdatedBy" bigint NOT NULL,
"CreatedIP" character varying(50) NOT NULL,
"UpdatedIP" character varying(70) NOT NULL,
"IsActive" boolean NOT NULL,
"CreationDate" date NOT NULL,
"UpdationDate" date NOT NULL,
CONSTRAINT "PK_MasterDivision_DivisionID" PRIMARY KEY ("DivisionID")
)
WITH (
OIDS=FALSE
);
ALTER TABLE "MasterDivision"
OWNER TO postgres;
GRANT ALL ON TABLE "MasterDivision" TO public;
GRANT ALL ON TABLE "MasterDivision" TO postgres;
我创建了以下自定义类型:
create type type_selectmasterdivisionwithpagging
as
(
row bigint,
DivisionID bigint,
DivisionName_EN character varying(70),
DivisionName_HI character varying(70),
DivisionCode character varying(70),
StateID bigint,
StateName_EN character varying(70),
StateName_HI character varying(70)
);
和下面的函数...
CREATE OR REPLACE FUNCTION selectmasterdivisionwithpagging("PageNumber" integer, "PageSize" integer, "WhereClause" text, "OrderByClause" text)
RETURNS SETOF type_selectmasterdivisionwithpagging AS
$BODY$declare
_SQL text;
Begin
IF $1 <> -1 and $2 <> -1 then
_SQL:='Select * ' ||
'from ' ||
'( ' ||
'SELECT ROW_NUMBER() OVER ('|| $4 ||' ) AS Row' ||
',MD."DivisionID" ' ||
',MD."DivisionName_EN" '||
',MD."DivisionName_HI" '||
',MD."DivisionCode" '||
',MD."StateID" '||
',MS."StateName_EN" '||
',MS."StateName_HI" '||
'from "MasterDivision" as MD ' ||
'left join "MasterState" as MS ' ||
'on MD."StateID"=MS."StateID" ' ||
$3 ||
' ) as t' ||
' where 1=1 and t.Row between ' || ((($1-1)*$2)+1)||' and ' || ($1*$2) ;
RETURN query execute _SQL;
else
RETURN query execute 'SELECT ROW_NUMBER() OVER ('|| $4 ||' ) AS Row' ||
',MD."DivisionID" ' ||
',MD."DivisionName_EN" '||
',MD."DivisionName_HI" '||
',MD."DivisionCode" '||
',MD."StateID" '||
',MS."StateName_EN" '||
',MS."StateName_HI" '||
'from "MasterDivision" as MD ' ||
'left join "MasterState" as MS ' ||
'on MD."StateID"=MS."StateID" ';
end IF;
end;$BODY$
LANGUAGE plpgsql IMMUTABLE
COST 100
ROWS 1000;
ALTER FUNCTION selectmasterdivisionwithpagging(integer, integer, text, text)
OWNER TO postgres;
以上所有查询都执行得很好,但是当我使用 select selectmasterdivisionwithpagging(1,2,' where 1=1 ','Order by MS."StateName_EN"')
时出现错误:
错误:查询结构与函数结果类型不匹配
详细信息:返回的类型字符 varying(70)[] 与第 7 列中预期的类型字符 varying(70) 不匹配。
如果需要更多信息,请告诉我。谢谢大家
最佳答案
请在不需要时停止使用EXECUTE
。如果这样做,请使用参数化形式。您当前的函数容易受到各种函数内 sql 注入(inject)的攻击。</p>
停止编写依赖 SQL 注入(inject)漏洞工作的函数。如果我在你的 where 子句中输入 '1=1;从“MasterDivision”中删除; --'
然后你会得到一个非常令人讨厌的惊喜。
您的错误表明 "MasterState"."StateName_EN"
不是您认为的类型。检查那里。在我看来,您可能将其作为 varchar(70)[] 而不是 varchar 字段。
关于postgresql - 返回类型字符 varying(70)[] 与预期类型不匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17669909/
我对java有点陌生,所以如果我犯了一个简单的错误,请原谅我,但我不确定我哪里出错了,我收到的错误是“预期的.class,预期的标识符,而不是声明, ';'预期的。”我尝试了不同的方法,并从这些方法中
This question already has answers here: chai test array equality doesn't work as expected (3个答案) 3年前
我正在学习 Java(对不起,我的英语很差,这不是我的母语),当我在 Eclipse (JavaSE-1.7) 中在我输入的每个“try”中执行“try-finally” block 时,会出现以下消
我收到两个错误,指出 token 上的语法错误,ConstructorHeaderName expected instead & token “(”上的语法错误,< expected 在线: mTM.
我找不到错误。 Eclipse 给我这个错误。每个 { } 都是匹配的。请帮忙。 Multiple markers at this line - Syntax error on token “)”,
代码: import java.awt.*; import javax.swing.*; import java.awt.event.*; public class DoubleIt extends
我正在用 python(Vs 代码)编写代码,但出现此错误: Expected ")" Pylance 错误发生在:def main() 我试着运行我的 main 并将它打印到我的屏幕上。我用谷歌搜
我正在尝试按照 documentation 中的建议使用异步函数。但我收到此错误 意外的 token ,预期 ( async function getMoviesFromApi() { try
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
第一行包含一个表示数组长度的整数p。第二行包含用空格分隔的整数,这些整数描述数组中的每个元素。第三行打印一个整数,指示负数组的数量。 package asgn3; import java.util.*
好的,我是初学者,我必须修复此 java 表达式语言代码才能在我的系统 (Windchill) 中工作,但看起来我在语法中遗漏了一些内容: LWCNormalizedObject lwc =
我无法编译我的程序! 我想我缺少一个花括号,但我怎么也看不出在哪里! import javax.swing.*; import java.awt.*;
我的 jQuery 代码有问题,我的 Firebug 向我发出警告:需要选择器。 这是代码: $("img[id$='_tick']").each(function() { $(this).c
我的新类(class) Fountainofyouth 遇到了问题。尝试构建整个项目后,调试器显示 warning: extended initializer lists only available
我已经从 Java 转向 CPP,并且正在努力围绕构造构造函数链进行思考,我认为这是我的问题的根源。 我的头文件如下: public: GuidedTour(); GuidedTour(string
鉴于以下 for(var i=0; i< data.cats.length; i++) list += buildCategories(data.cats[i]); jsLint 告诉我 Expect
我有这个 json,但 Visual Studio Code 在标题中给了我警告。 [ { "title": "Book A", "imageUrl": "https:
我正在尝试编写一个有条件地禁用四个特殊成员函数(复制构造、移动构造、复制赋值和移动赋值)的包装类,下面是我用于测试目的的快速草稿: enum class special_member : uint8_
所以我用 F# 编写了一个非常简单的程序,它应该对 1000 以下的所有 3 和 5 的倍数求和: [1..999] |> List.filter (fun x -> x % 3 = 0 || x %
我是一名优秀的程序员,十分优秀!