Mybatis查询的字符串字段的顺序有些是逆序

下图是后台mybatis的返回值

图片说明

下图是数据库的查询结果

图片说明

下面是sql语句

     SELECT COUNT(1) as count, mc.calendar_year_month as calendarTime ,
    mc.calendar_month as calendarMonth,
    group_concat(mc.calendar_name) as calendarNames
    FROM kbpos_marketing.marketing_calendar mc
    WHERE mc.calendar_year_month <![CDATA[ >= ]]> #{beginDate}
    AND mc.calendar_year_month <![CDATA[ <= ]]> #{endDate} AND mc.delete_flag=0
    GROUP BY mc.calendar_year_month,mc.calendar_month
    ORDER BY mc.calendar_year_month,mc.calendar_month;

这个字段是string类型,数据库中也是字符串类型
private String calendarNames;
为什么会这个节日的顺序不一样呢?

5个回答

图片说明

用子查询先order by,再group by ,顺序应该就一致了。

没有说两句同样的sql执行结果一定会一样

这个跟mybatis没关系,你试试用sql去查看下,mybatis可以开启debug模式打印sql,你用那个sql查看看

因为你ORDER BY mc.calendar_year_month,mc.calendar_month;的是年月,而不是名字,所以它是无序的,顺序随机。
而且实际上中文排序本身对于老外写的程序来说就勉为其难。老外懂重音字么?你说重阳节的重是按照Chong参与排序还是Zhong排序?这可一个在前一个在后,差别大了。

我知道结果了各位,是因为group_concat排序,不一定是根据表中顺序来的,自己手动在group_concat(order by)里面加个order by就可以了。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
mybatis 如何模糊查询,某个字段包含参数字符串的所有对象?

![图片说明](https://img-ask.csdn.net/upload/201612/26/1482731611_723709.png) 就是将查询条件改成 like %#{pd.SEARCH}% ,大概就是这个意思 ,具体应该怎么写?

mybatis查询 字符串key无法被识别为sql关键字问题

查询代码如下 ``` <!-- 根据params(匹配) searchPram(模糊字段) sortPram(排序) 查询 返回单个数据--> <select id="getByParam" resultMap="User" parameterType="java.util.Map" > select <include refid="Base_Column_List" /> from user <if test="params!= null" > where <trim suffixOverrides=" and " > <foreach collection ="params.keys" item="key" index= "index" separator =" and " > ${key}= #{params[${key}]} </foreach> </trim> </if> <if test="searchParams!=null" > <if test="params==null" > where </if> <if test="params!=null" > and </if> </if> <if test="searchParams != null" > <trim prefix="(" suffix=")" suffixOverrides=" or " > <foreach collection ="searchParams.keys" item="key" index= "index" separator =" or " > ${key} like #{searchParams[${key}]} </foreach> </trim> </if> <if test="sortParams != null" > order by <trim suffixOverrides=","> <foreach collection ="sortParams.keys" item="key" index= "index" separator=","> #{sortParams[${key}]} ${key} </foreach> </trim> </if> limit 0,1 </select> ``` 执行结果 ``` 22:05:44.292 [http-bio-80-exec-8] DEBUG com.xjt.dao.UserDao.getByParam - ==> Preparing: select id, userName, password, age from user where userName= ? order by ? desc limit 0,1 22:05:44.292 [http-bio-80-exec-8] DEBUG com.xjt.dao.UserDao.getByParam - ==> Parameters: 230(String), id(String) 22:05:44.293 [http-bio-80-exec-8] DEBUG com.xjt.dao.UserDao.getByParam - <== Total: 1 ``` 从结果上看 order by 后的?无法被识别为关键字。求有经验的大神指点!

mybatis返回字符串异常

不知道为什么返回string就一直都出异常说没有找到result map类型的areaUser,可是我也没用areaUser这个对象。而且我查询使用的都是parameterType和resultType呀,不知道问题出现在哪里,请大神帮忙 ! ``` <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "mybatis-3-mapper.dtd" > <mapper namespace="com.boco.eoms.portal.user.mapper.AreaUserMapper"> <select id="selectAreaIdByAreaName" parameterType="string" resultType="string"> SELECT AREAID FROM PORTAL_SYSTEM_AREA WHERE AREANAME = #{areaName} </select> <!-- <insert id="addAreaUserInfo" parameterType="java.util.List"> INSERT INTO PORTAL_SYSTEM_AREA_USER (ID,AREA_ID,USER_ID,AREA_NAME,USER_NAME,CREATE_TIME) <foreach close=")" collection="list" item="item" index="index" open="(" separator="union all"> select #{item.id,jdbcType=VARCHAR}, #{item.areaId,jdbcType=VARCHAR}, #{item.userId,jdbcType=VARCHAR}, #{item.areaName,jdbcType=VARCHAR}, #{item.userName,jdbcType=VARCHAR}, #{item.createTime,jdbcType=TIMESTAMP} from dual </foreach> </insert> --> </mapper> ``` ``` //查询areaid String areaName = element.elementText("L"); user.setAreaName(areaName); String areaId = this.areaUserService.selectAreaIdByAreaName(areaName); user.setAreaId(areaId); ``` ``` org.apache.ibatis.builder.IncompleteElementException: Could not find result map com.boco.eoms.portal.user.model.AreaUser at org.apache.ibatis.builder.MapperBuilderAssistant.setStatementResultMap(MapperBuilderAssistant.java:346) at org.apache.ibatis.builder.MapperBuilderAssistant.addMappedStatement(MapperBuilderAssistant.java:284) at org.apache.ibatis.builder.xml.XMLStatementBuilder.parseStatementNode(XMLStatementBuilder.java:107) at org.apache.ibatis.session.Configuration.buildAllStatements(Configuration.java:698) at org.apache.ibatis.session.Configuration.hasStatement(Configuration.java:668) at org.apache.ibatis.session.Configuration.hasStatement(Configuration.java:663) at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:180) at org.apache.ibatis.binding.MapperMethod.<init>(MapperMethod.java:43) at org.apache.ibatis.binding.MapperProxy.cachedMapperMethod(MapperProxy.java:58) at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:51) at com.sun.proxy.$Proxy22.selectAreaIdByAreaName(Unknown Source) at com.boco.eoms.portal.user.service.impl.AreaUserServiceImpl.selectAreaIdByAreaName(AreaUserServiceImpl.java:26) at com.boco.eoms.portal.user.controller.UserInterfaceController.addUserInfo(UserInterfaceController.java:80) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at org.apache.cxf.service.invoker.AbstractInvoker.performInvocation(AbstractInvoker.java:180) at org.apache.cxf.service.invoker.AbstractInvoker.invoke(AbstractInvoker.java:96) at org.apache.cxf.jaxws.AbstractJAXWSMethodInvoker.invoke(AbstractJAXWSMethodInvoker.java:178) at org.apache.cxf.jaxws.JAXWSMethodInvoker.invoke(JAXWSMethodInvoker.java:68) at org.apache.cxf.service.invoker.AbstractInvoker.invoke(AbstractInvoker.java:75) at org.apache.cxf.interceptor.ServiceInvokerInterceptor$1.run(ServiceInvokerInterceptor.java:57) at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:439) at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303) at java.util.concurrent.FutureTask.run(FutureTask.java:138) at org.apache.cxf.workqueue.SynchronousExecutor.execute(SynchronousExecutor.java:37) at org.apache.cxf.interceptor.ServiceInvokerInterceptor.handleMessage(ServiceInvokerInterceptor.java:106) at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:272) at org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:121) at org.apache.cxf.transport.http.AbstractHTTPDestination.invoke(AbstractHTTPDestination.java:239) at org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:248) at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:222) at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:153) at org.apache.cxf.transport.servlet.CXFNonSpringServlet.invoke(CXFNonSpringServlet.java:167) at org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:286) at org.apache.cxf.transport.servlet.AbstractHTTPServlet.doPost(AbstractHTTPServlet.java:206) at javax.servlet.http.HttpServlet.service(HttpServlet.java:650) at org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:262) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:123) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:77) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:956) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:436) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:625) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2517) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2506) at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:662) Caused by: java.lang.IllegalArgumentException: Result Maps collection does not contain value for com.boco.eoms.portal.user.model.AreaUser at org.apache.ibatis.session.Configuration$StrictMap.get(Configuration.java:797) at org.apache.ibatis.session.Configuration.getResultMap(Configuration.java:550) at org.apache.ibatis.builder.MapperBuilderAssistant.setStatementResultMap(MapperBuilderAssistant.java:344) ... 67 more ```

mybatis查询结果字段与实体类中对应的字段名不相同

实体类 ``` package com.example.main.domain; import java.util.Date; public class User { private Integer MU_ID; private String MU_NO; private String MU_NAME; private Integer MI_ID; private Integer MR_ID; private String MU_PASSWORD; private String DEL_FLAG; private Date ADD_DATETIME; private String ADD_USER; private Date UPD_DATETIME; private String UPD_USER; private Date DEL_DATETIME; private String DEL_USER; public Integer getMU_ID() { return MU_ID; } public void setMU_ID(Integer MU_ID) { this.MU_ID = MU_ID; } public String getMU_NO() { return MU_NO; } public void setMU_NO(String MU_NO) { this.MU_NO = MU_NO; } public String getMU_NAME() { return MU_NAME; } public void setMU_NAME(String MU_NAME) { this.MU_NAME = MU_NAME; } public Integer getMI_ID() { return MI_ID; } public void setMI_ID(Integer MI_ID) { this.MI_ID = MI_ID; } public Integer getMR_ID() { return MR_ID; } public void setMR_ID(Integer MR_ID) { this.MR_ID = MR_ID; } public String getMU_PASSWORD() { return MU_PASSWORD; } public void setMU_PASSWORD(String MU_PASSWORD) { this.MU_PASSWORD = MU_PASSWORD; } public String getDEL_FLAG() { return DEL_FLAG; } public void setDEL_FLAG(String DEL_FLAG) { this.DEL_FLAG = DEL_FLAG; } public Date getADD_DATETIME() { return ADD_DATETIME; } public void setADD_DATETIME(Date ADD_DATETIME) { this.ADD_DATETIME = ADD_DATETIME; } public String getADD_USER() { return ADD_USER; } public void setADD_USER(String ADD_USER) { this.ADD_USER = ADD_USER; } public Date getUPD_DATETIME() { return UPD_DATETIME; } public void setUPD_DATETIME(Date UPD_DATETIME) { this.UPD_DATETIME = UPD_DATETIME; } public String getUPD_USER() { return UPD_USER; } public void setUPD_USER(String UPD_USER) { this.UPD_USER = UPD_USER; } public Date getDEL_DATETIME() { return DEL_DATETIME; } public void setDEL_DATETIME(Date DEL_DATETIME) { this.DEL_DATETIME = DEL_DATETIME; } public String getDEL_USER() { return DEL_USER; } public void setDEL_USER(String DEL_USER) { this.DEL_USER = DEL_USER; } } ``` 表的字段名 ![图片说明](https://img-ask.csdn.net/upload/201904/27/1556351780_468723.png) 查询出来的数据 [{"del_FLAG":"0","add_DATETIME":"2019-04-26T12:21:33.000+0000","mr_ID":1,"add_USER":"s","upd_DATETIME":"2019-04-03T12:21:50.000+0000","del_DATETIME":"2019-04-10T12:21:43.000+0000","upd_USER":"adad","del_USER":"dada","mu_PASSWORD":"123456","mu_ID":1,"mu_NO":"95927","mi_ID":1,"mu_NAME":"admin"},{"del_FLAG":"0","add_DATETIME":null,"mr_ID":1,"add_USER":null,"upd_DATETIME":null,"del_DATETIME":null,"upd_USER":null,"del_USER":null,"mu_PASSWORD":"123456","mu_ID":2,"mu_NO":"95544","mi_ID":1,"mu_NAME":"dada"}] 为什么下划线前面的字段会变成小写 有什么办法能变成大写吗

mybatis数据库中如何比较两个时分秒的字符串大小

mybatis数据库中如何比较两个时分秒的字符串大小 12:00:00 和03:00:59比较

SSM返回值丢失字符串两端空格?

数据库存入了两端带空格或换行符,但使用MyBatis查出的数据转为表对象时,空格就已经丢失了。 怎样配置才能保留返回值两端的空格呢?

MyBatis如何保存带有双引号的字符串

今天用MyBatis保存数据的时候突然发现报错了! org.apache.ibatis.exceptions.PersistenceException: ### Error updating database. Cause: java.sql.SQLException: Syntax error or access violation message from server: "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'desc,link,pubDate,source,title,channelId,imageurls) values ('杭州西湖湖' at line 2" ### The error may involve /.addNews-Inline ### The error occurred while setting parameters ### SQL: insert into News (desc,link,pubDate,source,title,channelId,imageurls) values (?,?,?,?,?,?,?) 初步估计应该是因为保存的字符串有双引号的关系!求大神致电如何解决这种问题<insert id="addNews" parameterType="News" statementType="PREPARED" keyProperty="id" useGeneratedKeys="true"> insert into News (desc,link,pubDate,source,title,channelId,imageurls) values (#{desc},#{link},#{pubDate},#{source},#{title},#{channelId},#{imageurls}) </insert> ``` ``` ``` ``` ``` ```

关于SpringBoot+myBatis实体的字段返回前端后格式变化的问题

我的架构是 springBoot(1.5.9)+myBatis ,连接池用的是阿里的druid,以下是配置信息: 启动类: import java.sql.SQLException; import java.util.HashMap; import java.util.Map; import org.apache.ibatis.plugin.Interceptor; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.EnableAutoConfiguration; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.web.servlet.FilterRegistrationBean; import org.springframework.boot.web.servlet.ServletRegistrationBean; import org.springframework.context.annotation.Bean; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import com.alibaba.druid.pool.DruidDataSource; import com.alibaba.druid.support.http.StatViewServlet; import com.alibaba.druid.support.http.WebStatFilter; import com.github.pagehelper.PageHelper; /** * * @author wangxufei * */ @SpringBootApplication @EnableAutoConfiguration @MapperScan("com.mofangge.mapper") public class MfgAgencyApplication { @Value("${spring.datasource.username}") private String userName; @Value("${spring.datasource.password}") private String password; @Value("${spring.datasource.url}") private String url; @Bean public ServletRegistrationBean druidServletRegistrationBean() { ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(); servletRegistrationBean.setServlet(new StatViewServlet()); servletRegistrationBean.addUrlMappings("/druid/*"); return servletRegistrationBean; } /** * 注册DruidFilter拦截 * * @return */ @Bean public FilterRegistrationBean duridFilterRegistrationBean() { FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(); filterRegistrationBean.setFilter(new WebStatFilter()); Map<String, String> initParams = new HashMap<String, String>(); // 设置忽略请求 initParams.put("exclusions", "*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*"); filterRegistrationBean.setInitParameters(initParams); filterRegistrationBean.addUrlPatterns("/*"); return filterRegistrationBean; } /** * 配置DruidDataSource * * @return * @throws SQLException */ @Bean public DruidDataSource druidDataSource() throws SQLException { DruidDataSource druidDataSource = new DruidDataSource(); druidDataSource.setUsername(userName); druidDataSource.setPassword(password); druidDataSource.setUrl(url); druidDataSource.setMaxActive(100); druidDataSource.setFilters("stat,wall"); druidDataSource.setInitialSize(10); return druidDataSource; } @Bean public SqlSessionFactory sqlSessionFactoryBean() throws Exception { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(druidDataSource()); PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); sqlSessionFactoryBean.setMapperLocations(resolver.getResources("classpath:/mybatis/*.xml")); sqlSessionFactoryBean.setTypeAliasesPackage("com.mofangge.model,com.mofangge.dto"); Interceptor[] interceptors = {new PageHelper()}; sqlSessionFactoryBean.setPlugins(interceptors); return sqlSessionFactoryBean.getObject(); } public static void main(String[] args) { SpringApplication.run(MfgAgencyApplication.class, args); } } properties文件: #server #server.port=8080 server.port=8081 #server.port=8099 #server.servlet-path=/agency ## log logging.level.org.springframework.web: error logging.level.com.mofangge:info logging.file:mfg-agency.log # JPA (JpaBaseConfiguration, HibernateJpaAutoConfiguration) spring.data.jpa.repositories.enabled=true spring.jpa.database=mysql spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect spring.jpa.generate-ddl=false spring.jpa.hibernate.ddl-auto=none spring.jpa.open-in-view=true spring.jpa.show-sql=false 现在遇到的问题是: 实体类中的格式 返回到页面后,字段格式变化了,如下图: 实体: ![图片说明](https://img-ask.csdn.net/upload/201803/08/1520520274_791208.png) 数据库: ![图片说明](https://img-ask.csdn.net/upload/201803/08/1520520307_858101.png) 返回到页面后的值(controller注解了@RestController): ![图片说明](https://img-ask.csdn.net/upload/201803/08/1520520354_282352.png) 第二个字母 应该是大写C 结果变成了小写c。 而且有个现象是: 如果你的字段是 sName 那么前端拿到的是sname 如果你的字段是seName 那么前端拿到的就是seName **不会变化** 也就是说 如果驼峰前字母是2个或2个以上 他就按照原来的格式了,不知道具体是什么原因,求大佬教导。 ps: 我试过很多种方法,只有一种有效果 就是给字段注解 @JsonProperty 但是这种方法会造成我的返回值里会有2个 sname 一个是sname 一个是sName 2个字段都是同样的值 给我一种复制的感觉。。

怎么解决MyBatis中查询新生成的字段问题??

在MyBatis中查询时根据表内其余的字段,经过计算生成新的字段,但是查询的结果是地址。有办法解决没??

mybatis数据库模糊查询多字段语句问题

之前单表可以对表中数据进行连接字符串 现在连接多字段提示找不到o.delivery__name等字段 怎么办_ ```__ <select id="showorder" resultMap="BaseResultMap" parameterType="java.util.Map"> select o.*,g.goods_repertory,g.goods_code,g.goods_name,g.goods_standard,g.goods_master_name from qry_order as o left join cfg_goods as g on o.goods_coding=g.goods_coding <where> <if test="key != null and key != '' "> CONCAT(`o.delivery_name`,`o.order_lpn`,`o.order_remark`) LIKE CONCAT(CONCAT('%', #{key}),'%') </if> <if test="type == null or type == '' "> and o.order_type !=2 </if> <if test="type !=null and type != ''"> and o.order_type =#{type} </if> and order_create_time >adddate(now(), INTERVAL -6 HOUR) </where> <if test="sortName != null and sortName != '' "> order by o.${sortName} ${order} </if> limit #{offset},#{limit} </select> ```

mybatis 增加字段sql文

mybatis 增加字段sql文 怎么把下面这句话注解到xml alter table docdsp add dspcode char(200)

mybatis 查询 表中类型是clob的字段

在配置文件中定义了一个resultMap 但是在查询的时候查不出东西,查出来的对象里面也没有这个字段,有没有大神,求帮助

MyBatis怎么在程序不变的情况下,把两个字段映射到一个字段中。

比如有firstName和lastName两个字段,怎么将两个字段映射到一个字段中,在resultMap中怎么实现。或者还有什么其它方式,急急急

用mybatis查询数据返回的对象中有一个字段值始终不变? (已解决)

很奇怪的问题,查询后返回的对象里有个字段是integer类型的,始终都是0,但是数据库里并不是0,查询语句放到数据库里执行也是没问题的,不知道是不是mybatis有什么问题?我试了该对象里同样数据类型的另外字段可以返回正确的结果,偏偏有一个字段始终不行。查询语句是最基本的单表查询。有没有人碰到过这种奇怪的事情?

mybatis的实体类的字段类型如何和sql的类型对应起来

mybatis的实体类的字段类型如何和sql的类型对应起来,还有假如和多个表呢,实体类,如何创建

mybatis mysql xml字段解析

String str = “a-b”,现在 mapper.xml (mybatis)里接收到了 str。 xml里将 str 拆成 字段1 = a and 字段2 = b, 怎么在xml实现? 数据库mysql

mybatis 对于特殊字符问题处理

``` <select id="getVagueQuery" parameterType="java.lang.String" resultType="com.kangwei.pojo.tz.T_SB_SCFZSS_SD"> SELECT OBJ_ID, JMLX, DMCC, SDCD, JSL, SGDW, JGRQ, YWDWMC, WHBZMC, SDMC, SDBH, WHBZ, ZCXZ, DAMC FROM SCYW.T_SB_SCFZSS_SD WHERE SCYW.T_SB_SCFZSS_SD.SDBH LIKE concat(concat('%', #{value}), '%') OR SCYW.T_SB_SCFZSS_SD.SDMC LIKE concat(concat('%', #{value }), '%') </select> ``` ![图片说明](https://img-ask.csdn.net/upload/201710/11/1507688310_910291.png) 输入%,传进去的也是一个%,但是查询出来了所有数据,网上查的对传入的百分号加上[]就可以了,试了一下确实可以.我是在java代码里判段的,感觉我这个方法还是不好,如果遇到其他特殊字符还是不行,下面是我代码,大神们还有其他方法吗 ``` if(newContent.equals("%")){ String newContent1 = "[%]"; System.out.println(newContent1); return sdService.getVagueQuery(newContent1, page, limit); } ```

date类型的属性封装后,将get方法的返回值类型改为String,使用Mybatis查询时报错

![图片说明](https://img-ask.csdn.net/upload/201708/04/1501809891_638589.png) org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException: ### Error querying database. Cause: java.lang.NullPointerException ### Cause: java.lang.NullPointerException at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:75) at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:371) at com.sun.proxy.$Proxy7.selectList(Unknown Source)

mybatis中级联查询后如何处理两个表的相同字段

**mybatis中级联查询后如何处理两个表的相同字段** 现在出来了一个问题:我级联查询出来后,放置一个在Dept中,发现其中List中的employee对象中的status它直接是Dept的内容,并没有去找自己的内容。 部门: ```java public class Dept { private Integer id ; private String name ; private String address ; private String status ; private List<Employee> employees ; ``` 员工: ``` public class Employee { private int id ; private String name; private String address ; private String status ; ``` 级联映射表: ```xml <resultMap type="Dept" id="resultDeptMap"> <result property="id" column="d_id" /> <result property="name" column="d_name" /> <result property="address" column="d_address" /> <result property="status" column="status" /> <!-- 一对多 List 列表 collection:对关联查询到的多条记录映射到集合中 --> <collection property="employees" ofType="com.wm.mybatis.POJO.Employee" column="d_id" > <id property="id" column="e_id" javaType="int" jdbcType="INTEGER"/> <result property="name" column="e_name" javaType="string" jdbcType="VARCHAR"/> <result property="address" column="e_address" javaType="string" jdbcType="VARCHAR"/> <result property="d_id" column="d_id" javaType="int" jdbcType="INTEGER"/> <result property="status" column="status" /> </collection> </resultMap> ``` 查询出来的结果:List<Employee>中Employee的status状态都是Dept的status,它没有对应到自己的状态位去。 请问大神们,怎么解决??有遇到过的没呢?

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

外包程序员的幸福生活

今天给你们讲述一个外包程序员的幸福生活。男主是Z哥,不是在外包公司上班的那种,是一名自由职业者,接外包项目自己干。接下来讲的都是真人真事。 先给大家介绍一下男主,Z哥,老程序员,是我十多年前的老同事,技术大牛,当过CTO,也创过业。因为我俩都爱好喝酒、踢球,再加上住的距离不算远,所以一直也断断续续的联系着,我对Z哥的状况也有大概了解。 Z哥几年前创业失败,后来他开始干起了外包,利用自己的技术能...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

深入剖析Springboot启动原理的底层源码,再也不怕面试官问了!

大家现在应该都对Springboot很熟悉,但是你对他的启动原理了解吗?

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

你期望月薪4万,出门右拐,不送,这几个点,你也就是个初级的水平

先来看几个问题通过注解的方式注入依赖对象,介绍一下你知道的几种方式@Autowired和@Resource有何区别说一下@Autowired查找候选者的...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《经典算法案例》01-08:如何使用质数设计扫雷(Minesweeper)游戏

我们都玩过Windows操作系统中的经典游戏扫雷(Minesweeper),如果把质数当作一颗雷,那么,表格中红色的数字哪些是雷(质数)?您能找出多少个呢?文中用列表的方式罗列了10000以内的自然数、质数(素数),6的倍数等,方便大家观察质数的分布规律及特性,以便对算法求解有指导意义。另外,判断质数是初学算法,理解算法重要性的一个非常好的案例。

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

字节跳动面试官竟然问了我JDBC?

轻松等回家通知

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

立即提问
相关内容推荐