大家好,感谢邀请,今天来为大家分享一下parametertype什么意思的问题,以及和parametertype可以不写吗的一些困惑,大家要是还不太明白的话,也没有关系,因为接下来将为大家分享,希望可以帮助到大家,解决大家的问题,下面就开始吧!
my batis怎样,实现mysql动态,分页
在这些控件里要达到分页的效果,一般都会传2个参数,第一个是表示当前页的索引(一般从0开始),第二个表示当前页展示多少条业务记录,然后将相应的参数传递给List<T>getList(PagenateArgsargs)方法,最终实现数据库中的分页时候可以使用limit关键词(针对mysql)进行分页,如果是oracle或者sqlserver他们都有自带的rownum函数可以使用。
针对上述思路,首先在demo.mybatis.model下面新建一个名为PagenateArgs的分页参数实体类与一个名为SortDirectionEnum的枚举类,里面包含当前页面索引pageIndex,当前页展示业务记录数pageSize,pageStart属性表示从第几条开始,(pageStart=pageIndex*pageSize)因为limit关键词用法是表示【limit起始条数(不包含),取几条】,orderFieldStr排序字段,orderDirectionStr排序方向,所以具体创建如下:
packagedavid.mybatis.model;/**分页参数实体类*/publicclassPagenateArgs{privateintpageIndex;privateintpageSize;privateintpageStart;privateStringorderFieldStr;privateStringorderDirectionStr;publicPagenateArgs(){//TODOAuto-generatedconstructorstub}publicPagenateArgs(intpageIndex,intpageSize,StringorderFieldStr,StringorderDirectionStr){this.pageIndex=pageIndex;this.pageSize=pageSize;this.orderFieldStr=orderFieldStr;this.orderDirectionStr=orderDirectionStr;pageStart=pageIndex*pageSize;}publicintgetPageIndex(){returnpageIndex;}publicintgetPageStart(){returnpageStart;}publicintgetPageSize(){returnpageSize;}publicStringorderFieldStr(){returnorderFieldStr;}publicStringgetOrderDirectionStr(){returnorderDirectionStr;}}
packagedavid.mybatis.model;/**排序枚举*/publicenumSortDirectionEnum{/**升序*/ASC,/**降序*/DESC}
完成上面的步骤以后在IVisitorOperation接口类中继续添加一个方法publicList<Visitor>getListByPagenate(PagenateArgsargs),这次的分页其实也就是在这个的基础上稍加改动即可,IVisitorOperation接口类改动后如下所示:
packagedavid.mybatis.demo;importjava.util.List;importdavid.mybatis.model.PagenateArgs;importdavid.mybatis.model.Visitor;importdavid.mybatis.model.VisitorWithRn;publicinterfaceIVisitorOperation{/**基础查询*/publicVisitorbasicQuery(intid);/**添加访问者*/publicintadd(Visitorvisitor);/**删除访问者*/publicintdelete(intid);/**更新访问者*/publicintupdate(Visitorvisitor);/**查询访问者*/publicVisitorquery(intid);/**查询List*/publicList<Visitor>getList();/**分页查询List*/publicList<Visitor>getListByPagenate(PagenateArgsargs);}
接下来改动VisitorMapper.xml配置文件了,新增一个<select>节点id与参数类型参照前几章的方式配置好,如下此处新增的id就为getListByPagenate,配置好以后如下
<?xmlversion="1.0"encoding="UTF-8"?><!DOCTYPEmapperPUBLIC"-//mybatis.org//DTDMapper3.0//EN""
http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mappernamespace="david.mybatis.demo.IVisitorOperation"><!--useGeneratedKeys="true"代表是否使用自增长序列,keyProperty="Id"指定自增长列是哪一列,parameterType="Visitor"指定IVisitorOperation接口类中定义中所传的相应类型--><insertid="add"parameterType="Visitor"useGeneratedKeys="true"keyProperty="Id">insertintoVisitor(Name,Email,Status,CreateTime)values(#{name},#{email},#{status},#{createTime})</insert><deleteid="delete"parameterType="int">deletefromVisitorwherestatus>0andid=#{id}</delete><updateid="update"parameterType="Visitor">updateVisitorsetName=#{name},Email=#{email},Status=#{status}whereid=#{id}andStatus>0;</update><selectid="query"parameterType="int"resultType="Visitor">selectId,Name,Email,Status,CreateTimefromvisitorwhereid=#{id}andStatus>0orderbyId</select><selectid="basicQuery"parameterType="int"resultType="Visitor">select*fromvisitorwhereid=#{id}andStatus>0orderbyId</select><selectid="getList"resultMap="visitorRs"><includerefid="getListSql"/></select><sqlid="getListSql">select*fromVisitorwherestatus>0</sql><!--以下为新增部分用来分页,orderBySql这个提取出来是为了后面有示例复用--><resultMaptype="Visitor"id="visitorRs"><idcolumn="Id"property="id"/><resultcolumn="Name"property="name"/><resultcolumn="Email"property="email"/><resultcolumn="Status"property="status"/><resultcolumn="CreateTime"property="createTime"/></resultMap><selectid="getListByPagenate"parameterType="PagenateArgs"resultType="Visitor">select*from(<includerefid="getListSql"/><includerefid="orderBySql"/>)t<!--#{}表示参数化输出,${}表示直接输出不进行任何转义操作,自己进行转移--><iftest="pageStart>-1andpageSize>-1">limit#{pageStart},#{pageSize}</if></select><sqlid="orderBySql">orderby${orderFieldStr}${orderDirectionStr}</sql></mapper>这里面的字段属性都是针对PagenateArgs参数类中的属性名,保持一致。
<iftest="pageStart>-1andpageSize>-1">limit#{pageStart},#{pageSize}</if>
在DemoRun类中创建测试方法:
/**分页参数*/publicstaticvoidqueryVisitorListWithPagenate(intpageIndex,intpageSize,StringorderField,StringorderDire){PagenateArgsargs=newPagenateArgs(pageIndex,pageSize,orderField,orderDire);SqlSessionsession=MybatisUtils.getSqlSession();IVisitorOperationvOperation=session.getMapper(IVisitorOperation.class);List<Visitor>visitors=vOperation.getListByPagenate(args);for(Visitorvisitor:visitors){System.out.println(visitor);}MybatisUtils.closeSession(session);MybatisUtils.showMessages(CRUD_Enum.List,visitors.size());}
DemoRun.queryVisitorListWithPagenate(0,100,"id",SortDirectionEnum.DESC.toString());
运行后下测试结果,先按Id倒序排列,查的Visitor表一共有14条记录,
假设取在第2页取5条,执行下面也就是6-10条数据,这样传参数就行了
DemoRun.queryVisitorListWithPagenate(1,5,"id",SortDirectionEnum.DESC.toString());
结果如下:
实现了一个分页逻辑.
怎么样才能学好java编程
不扯那些虚的,要来就来实质性的干货。
明确自己学习的原因问问自己是抱着什么目的要学习Java,没有目标的学习是效率极低的,并且容易半途而废;
了解Java可以做什么,Java可以从事的岗位以及软件行业的发展情况;
自己是否对Java方向感兴趣;
Java基础学习准备
推荐看视频入门,可以通过某宝以及某鱼购买相关的视频,别挑三拣四,选中一个视频看完再说,对于初学者,无论选哪一个都是值得你学习的。可以选择传智、黑马、尚学堂等教学视频,买一个系列的即可;
有人说编辑器等IDE环境不适合看视频,浪费时间,但是初学者在学习第一个编程IDE时,推荐看视频或者通过搜索引擎了解工具的使用,看书其实在刚开始可能更浪费时间;
看完基础视频对知识有个大概的了解,这时候看书就不会一头雾水,此时可以通过看书来深入学习,之后的学习可以自己选择看书还是看视频,最好的方法是花时间既看视频也看书;
学着学着忘掉前面的别总想着回头记住,先往后学,有些基础知识暂时用不上,当你学到应用的知识时自然会慢慢理解;
书籍推荐
入门书籍:《HeadFirstJava》、《Java核心技术》
进阶书籍:《Java编程思想》
JavaWeb学习完Java基础,接着适合学习JavaWeb,这个推荐看视频,学习数据库和JDBC基础知识以及基本的前端知识,然后学习SSM框架,学习路线为:
Mysql->JDBC->HTML、CSS、JavaScript、JSP->Spring->SpringMVC->Mybatis->SSM整合->SSM项目实战
推荐两本书:
《深入分析javaweb技术内幕》
《架构探险-从零开始写javaweb框架》:讲解ioc、aop通俗易懂,实现ioc、aop
实战之后返回深入学习Java相关知识,自顶向下学习,通过大概学习基础,实战之后返回深入学习基础知识,由广至深。
并发编程推荐书籍:
《Java并发编程的艺术》
设计模式《HeadFirst设计模式》
JVM《深入理解Java虚拟机》
要想超越别人,不仅仅要掌握实战技能,更重要的是基础扎实
算法《算法》第4版
计算机网络《图解TCP/IP》
《图解HTTP》
操作系统《操作系统概念》(恐龙书)
这么多已经够你学习了,主要是行动起来,还有更深入的,比如数据库方面以及Java相关的方面,等你学完以上知识相信你自己已经知道需要学习什么了,不要一次被这么多内容吓到,只要静下心来,下一个大神就是你。
附上一张可供参考的详细思维导图数据库的“EXEC”是什么意思应该怎么用
sqlserver中EXEC命令有两种用法,一种是执行一个存储过程,另一种是执行一个动态的批处理
1.使用系统存储过程sp_executesql运行Unicode命令字符串语法如下:sp_executesql[@stmt=]stmt[{,[@params=]N'@parameter_namedata_type[,...n]'}{,[@param1=]'value'[,...n]}]说明:必须先将各个包含所要运行的命令语句的Unicode字符串相加在一起,再交给系统存储过程sp_executesql来运行,而不能在sp_executesql的语句中来相加各个命令字符串。举例如下:declare@DBNamenvarchar(20),@Tbnamenvarchar(20),@SQLStringnvarchar(500)set@DBName=N'Northwind'set@Tbname=N'Customers'set@SQLString=N'USE'+@DBName+char(13)--char(13)换行SET@SQLString=@SQLString+N'select*from'+@Tbname--必须先将命令字符串组合完毕后再交给sp_executesql来运行execsp_executesql@SQLString
2.使用EXECUTE命令运行命令字符串要使用EXECUTE命令来运行一个命令字符串的语法如下:EXEC[UTE]({@string_variable|[N]'stql_string'}[+...n])从语法看出,可以先将包含所要运行的命令的字符串赋给一个局部变量@string_variable,再使用EXECUTE命令来运行,或是直接使用EXECUTE命令去运行一个包含所要运行的命令语句的字符串。此外,您也可以将多个包含所要运行的命令语句的字符串相加在一起,再交给EXECUTE命令来一次运行。例:declare@sqlnvarchar(4000)set@sql='select*from[表]whereemail=''test@163.com'''exec(@sql)
mybatis返回值什么时候用parametertype
mybatis查询数据返回时,需要用resulttype确定返回值的类型,parametertype用于确认请求值的类型
mysum函数是什么
计算机编程函数
mysum函数是一种常见的计算机编程函数,它的作用是对一组数值进行求和运算。在编程中,mysum函数通常被用来简化代码,提高程序的效率。mysum函数的使用非常简单,只需要将需要求和的数值作为参数传入函数中即可。例如,如果我们需要对数值1、2、3进行求和,可以使用如下代码:```result=mysum(1,2,3)```在这个例子中,mysum函数将返回数值6,即1+2+3的结果。除了可以对整数进行求和外,mysum函数还可以对浮点数、负数等进行求和。
如果你还想了解更多这方面的信息,记得收藏关注本站。