在ibatis中在sql语句判断的时候isEqual和isNull的区别是啥地方

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在ibatis中在sql语句判断的时候isEqual和isNull的区别是啥地方相关的知识,希望对你有一定的参考价值。

参考技术A isNull判断property字段是否是null,用isEmpty更方便,包含了null和空字符串
你如果用
<isNotNull
prepend="AND"
property="id">
a.id=#id#
</isNotNull>
即使你在bean中不设置id的值,id的初始值也是0而不是null;所以这样配置a.id会等于0
而你把name变量用isNotNull这样配置,name如果不设置值,初始就是null,name的条件不就添加在sql中;
isEqual相当于equals,数字用得多些,一般都是判断状态值
<isEqual
property="state"
compareValue="0">
</isEqual>

<isEqual
property="state"
compareProperty="nextState">
</isEqual>

delphi程序在使用adoquery执行SQL语句的时候,如何判断SQL语句全部已经执行完成

在Delphi中进行字符变量连接相加时单引号用('''),又引号用('''')表示
首先定义变量
var
AnInt:integer=123;//为了方便在此都给它们赋初值。虽然可能在引赋初值在某些情况下不对
AnIntStr:string='456';
AStr:string='abc';
AFieldName: string='字符型编号';
ATableName: string='YourTable';
ADate:Tdatetime=now;
Adoquery1:tadoquery;
1,Delphi语句
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 字符型编号='abc' and 整型编号=123';
等价于
adoquery1.sql.text:=
'select '+AFieldName+' from '+ATableName+' where '+AFieldName
+'='''+AStr+''' and 整型编号='+AnIntStr;
也等价于
adoquery1.sql.text:=
'select '+AFieldName+' from '+ATableName+' where '+AFieldName
+'='+QuotedStr(AStr)+' and 整型编号='+Inttostr(AnInt);
传到数据库服务器为:
select 字符型编号 from YourTable where 字符型编号='abc' and 整型编号=123
2,Delphi语句中日期表示
对于access数据库:
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 日期型字段=#2003-12-01#';
等价于:
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 日期型字段=#'+FormatDateTime('yyyy-MM-dd',now)+'#';
传到服务器为:
select 字符型编号 from YourTable where 日期型字段=#2003-12-01#
对于MSSQL数据库:
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 日期型字段='2003-12-01'';
等价于:
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 日期型字段='''+FormatDateTime('yyyy-MM-dd',now)+'''';
也等价于:
等价于:
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 日期型字段='+QuotedStr(FormatDateTime('yyyy-MM-dd',now));
传到服务器为:
select 字符型编号 from YourTable where 日期型字段='2003-12-01'
日期字段还可以这样表示
Delphi语句
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 日期型字段>='+QuotedStr(FormatDateTime('yyyy-MM-dd',now))

+' and 日期型字段<='+QuotedStr(FormatDateTime('yyyy-MM-dd',now+1));//明天
等价于
adoquery1.sql.text:=
'select 字符型编号 from YourTable where 日期型字段 between '+QuotedStr(FormatDateTime('yyyy-MM-dd',now))
+' and '+QuotedStr(FormatDateTime('yyyy-MM-dd',now+1));

如果用
adoquery1.sql.add();
形式又如何操作?请用Insert语句示例
adoquery1.sql.add(' insert into '+AtableName);
adoquery1.sql.add(' ( '+AFieldName+')');
adoquery1.sql.add(' values( '+quotedstr(AStr)+')');
参考技术A execsql执行完毕就是执行完所有的语句了,如果有错误,会跳出提示 参考技术B 如果未执行完语句, 程序应该不会往下跑吧!
只是速度很快你感觉不到他的停顿。本回答被提问者采纳
参考技术C 加 ShowMessage() 或 MessageBox()

以上是关于在ibatis中在sql语句判断的时候isEqual和isNull的区别是啥地方的主要内容,如果未能解决你的问题,请参考以下文章

如何配置ibatis语句带小于号的?

使用ibatis进行查询,我想查询一个字段有多个值得时候的结果,sql语句是这样的

ibatis批处理和把批量数据拼成一条sql语句,哪个效能更好?

java web中的表格排序

不需要配置log4j , 调试打印ibatis执行的sql语句和参数

ibatis 执行多条sql问题