V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
AllOfMe
V2EX  ›  Java

关于 Mybatis 在 insert 之后 timestamp 依旧为 null 的问题,求解谢谢!

  •  
  •   AllOfMe · Apr 8, 2018 · 6416 views
    This topic created in 2942 days ago, the information mentioned may be changed or developed.

    最近刚接触 MyBatis,遇到 id 不能自增的问题已经有 selectedKey 来解决了,但是像 create_time 这种 timestamp 默认值为 CURRENT_TIMESTAMP 的,在 insert 之后依旧为 null,请问各位有啥好办法吗?谢谢

    Supplement 1  ·  Apr 8, 2018
    数据库的 createTime 是 not null 并且默认值为 CURRENT_TIMESTAMP,xml 文件的 insert 语句里面是有带 createTime 的, 而且我用 mapper.insert(user)之后,数据库也是有正常的非 null 值。现在问题是,插入是成功了,数据库也是正常的,但是 insert(user)这个 user 的 pojo 实例后,该 pojo 实例的 createTime 的值为 null,我希望 insert 之后能让 mybatis 自动给 pojo 的 createTime 赋值
    26 replies    2018-04-09 06:25:39 +08:00
    SbloodyS
        1
    SbloodyS  
       Apr 8, 2018
    判断一下插入的值是否为空即可
    AllOfMe
        2
    AllOfMe  
    OP
       Apr 8, 2018
    @SbloodyS 我是想用 MySQL 的 timestamp 来自增,没有用 new Date()这样的方式来赋值,因为我担心 Java 服务器的主机和数据库主机的时间不一致。如果是使用 TimeStamp 的 CURRENT_TIMESTAMP,insert 之后能否让 MyBatis 自动赋值上去呢
    SbloodyS
        3
    SbloodyS  
       Apr 8, 2018
    那可以每次插入的时候不给这个字段赋值,并且 Mysql 该字段 NOT NULL,直接使用 Mysql 自动赋值就好啦
    daimazha
        4
    daimazha  
       Apr 8, 2018
    insert 的时候 没有包含这列的时候 才会用默认值也就是 CURRENT_TIMESTAMP。 你应该是包含了这个字段,但是值为 null。你可以写死 这列的值为 NOW()
    AllOfMe
        5
    AllOfMe  
    OP
       Apr 8, 2018
    @daimazha
    @SbloodyS

    额,,可能我表达的不太对。。我说的 timestamp 依旧为 null,是对 Java 的对象来说的,比如:
    ```
    User user = new User();
    user.setUsername("10");
    user.setPassword("232")
    userMapper.insert(user);
    user.getId(); // 使用 SelectedKey 的赋值,是在这里 Java 环境是有值的
    user.getCreateTime(); // 但是在这里,是为 null。数据库里查询刚刚插入的记录,createTime 也是有值的,只不过我想在 insert 之后,能对这个 user 实例获取一下 createTime 做点别的事情,不想再这个 id 去查询一遍

    ```
    dovme
        6
    dovme  
       Apr 8, 2018
    你这个获取的方式有问题吧,你不从数据库查你插入的 user? user.getCreateTime()这个 user 是你自己 new 出来的啊.
    dovme
        7
    dovme  
       Apr 8, 2018   ❤️ 2
    User user = new User();
    user.setUsername("10");
    user.setPassword("232")
    userMapper.insert(user);
    user.getId(); // 此处的 user 还是你刚才 new 出来的 user,不是你从数据库查出来的..
    user.getCreateTime();
    -------------------------------------------
    // 这样试试??
    User user = new User();
    user.setUsername("10");
    user.setPassword("232");
    userMapper.insert(user);
    //从数据库查询刚插入的 user
    User user1 = xxxService.selectByPrimaryKey(xx);
    user1.getId();
    user1.getCreateTime();
    zjp
        8
    zjp  
       Apr 8, 2018 via Android
    我刚刚也以为楼主说 current_timestamp 没有生效…
    还是在代码里指定时间戳来的容易。如果说 Java 和 MySQL 的时间不一致,还可能会出其他的问题,绕不过去的
    AllOfMe
        9
    AllOfMe  
    OP
       Apr 8, 2018
    @dovme 我以为和 hibernate 一样,在插入之后 hibernate 就能赋值 timestamp 了。我担心如果是几千万的表,这样查询不知道有没有性能问题。 还是如果是本身这个表结构没有主键 id 的话,我又应该如何获取 createTime 呢?
    AllOfMe
        10
    AllOfMe  
    OP
       Apr 8, 2018
    我贴一下我的 mapper xml 文件,大家看一下
    <insert id="insert" parameterType="com.min.User" >
    <selectKey resultType="java.lang.Integer" keyProperty="id" order="AFTER" >
    SELECT LAST_INSERT_ID()
    </selectKey>
    insert into user (username, password, create_time
    )
    values (#{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR}, #{createTime,jdbcType=TIMESTAMP}
    )
    </insert>
    dovme
        11
    dovme  
       Apr 8, 2018
    @AllOfMe 你的 mapper.xml 全部手写的??? MyBatis Generator 可以自动生成的
    Shynoob
        12
    Shynoob  
       Apr 8, 2018
    楼主的问题是否是 insert 方法返回的插入对象的 creat_time 为空?
    pelloz
        13
    pelloz  
       Apr 8, 2018
    很简单,你直接将 XML 里面的 create_time 和#{createTime,jdbcType=TIMESTAMP}删掉就好了
    AllOfMe
        14
    AllOfMe  
    OP
       Apr 8, 2018
    @dovme 我是用 generator 来生成,手写可能会疯。。
    AllOfMe
        15
    AllOfMe  
    OP
       Apr 8, 2018
    @Shynoob 对的
    anheiyouxia
        16
    anheiyouxia  
       Apr 8, 2018
    @dovme 你可能对 MyBatis 有什么误解

    User user = new User();
    user.setUsername("10");
    user.setPassword("232")
    userMapper.insert(user);
    user.getId();

    这里的 user.getId()是可行的,只要 insert 定义好了 SelectKey,mybatis 会自动把自增的 IDset 到传进去的 User 对象中
    jackqian
        17
    jackqian  
       Apr 8, 2018 via iPhone
    @dovme 居然能自动生成,我都是手写。
    AllOfMe
        18
    AllOfMe  
    OP
       Apr 8, 2018
    lrh3321
        19
    lrh3321  
       Apr 8, 2018
    膜拜下你们这些收些 XML 的大佬,我都是用注解的。
    night98
        20
    night98  
       Apr 8, 2018 via Android
    insert 语句中不要带 createtime,不然就把 java 中的 null 插入进数据库的 createtime 里了,这个是基础常识吧?
    AllOfMe
        21
    AllOfMe  
    OP
       Apr 8, 2018
    @night98 数据库的 createTime 是 not null 并且默认值为 CURRENT_TIMESTAMP,xml 文件的 insert 语句里面是有带 createTime 的, 而且我用 mapper.insert(user)之后,数据库也是有正常的非 null 值。现在问题是,插入是成功了,数据库也是正常的,但是 insert(user)这个 user 的 pojo 实例后,该 pojo 实例的 createTime 的值为空,我希望 insert 之后能让 mybatis 自动给 pojo 的 createTime 赋值
    night98
        22
    night98  
       Apr 8, 2018
    @AllOfMe #21 那就只能再查一次,我记得 mybatis 默认只支持 id 插入后 getid()
    AllOfMe
        23
    AllOfMe  
    OP
       Apr 8, 2018
    @night98 好的,谢谢
    JohnZorn
        24
    JohnZorn  
       Apr 8, 2018
    user = UserMapper.selectByPrimaryKey(user.getId())。。。不要打我
    flight2006
        25
    flight2006  
       Apr 8, 2018
    用 insertSelective 方法,insert 方法会用你的实体所有字段包括 null 的
    tedzhou1221
        26
    tedzhou1221  
       Apr 9, 2018 via Android
    说个题外话,好像 Mysql5.7 开始时间类字段不能为 null,以前版本的数据导过来可能会有问题
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5543 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 139ms · UTC 06:01 · PVG 14:01 · LAX 23:01 · JFK 02:01
    ♥ Do have faith in what you're doing.