当前位置: 首页 > news >正文

京东网站的建设与发展前景网站建设公司排名

京东网站的建设与发展前景,网站建设公司排名,设计网站怎样做色卡,北京网站制作建设主键回填其实是一个非常常见的需求,特别是在数据添加的过程中,我们经常需要添加完数据之后,需要获取刚刚添加的数据 id,无论是 Jdbc 还是各种各样的数据库框架都对此提供了相关的支持,本文我就来和和大家分享下数据库主…

主键回填其实是一个非常常见的需求,特别是在数据添加的过程中,我们经常需要添加完数据之后,需要获取刚刚添加的数据 id,无论是 Jdbc 还是各种各样的数据库框架都对此提供了相关的支持,本文我就来和和大家分享下数据库主键回填在 MyBatis 中的两种实现思路。

框架来源于我们学过的基础知识,主键回填实际上是一个在 JDBC 中就被支持的写法,有的小伙伴可能不知道这一点,因此这里我先来说说在 JDBC 中如何实现主键回填。

JDBC 中实现主键回填其实非常容易,主要是在构造 PreparedStatement 时指定需要主键回填,然后在插入成功后,查询刚刚插入数据的 id ,示例代码如下:

public int insert(Person person) {Connection con = null;PreparedStatement ps = null;ResultSet rs = null;con = DBUtils.getConnection();ps = con.prepareStatement("INSERT INTO person(username,password,money) VALUES(?,?,?)", PreparedStatement.RETURN_GENERATED_KEYS);ps.setObject(1, person.getUsername());ps.setObject(2, person.getPassword());ps.setObject(3, person.getMoney());int i = ps.executeUpdate();rs = ps.getGeneratedKeys();int id = -1;if (rs.next()) {id = rs.getInt(1);}return id;
}

和普通的插入 SQL 不同之处主要体现在两个地方:

  1. 第一个是构造 PreparedStatement 时,多了一个参数,指定了需要主键回填。
  2. 在更新操作执行完成之后,调用 getGeneratedKeys ,然后又会获取到一个 ResultSet 对象,从这个游标集中就可以获取到刚刚插入数据的id。

这个是原生的写法,在 MyBatis 中,对此需求提供了两种不同的实现方案,下面分别来看。

框架写法

一般情况下,主键有两种生成方式:

  1. 主键自增长
  2. 自定义主键(一般可以使用UUID,或者类UUID)

如果是第二种,主键一般是在Java代码中生成,然后传入数据库执行插入操作,如果是第一个主键自增长,此时,Java 可能需要知道数据添加成功后的主键。

MyBatis 的基本用法就无需多说了,这也不是本文的重点,我们还是来看看 MyBatis 中主键回填的两种不同实现方式吧!

方式一

第一种方式比较简单,也是比较推荐的一种实现方式:

<insert >insert into t_book (b_name,author) values (#{name},#{author});
</insert>

这种方式比较简单,就是在插入节点上添加 useGeneratedKeys 属性,同时设置接收回传主键的属性。配置完成后,我们执行一个插入操作,插入时传入一个对象,插入完成后,这个对象的 id 就会被自动赋值,值就是刚刚插入成功的id。

推荐大家使用这种方式,原因很简单,这种方式实现简便省事。

方式二

第二种方式则是利用MySQL自带的 last_insert_id() 函数查询刚刚插入的id,示例代码如下:

language-java"><insert ><selectKey keyProperty="id" resultType="java.lang.Integer">SELECT LAST_INSERT_ID()</selectKey>insert into t_book (b_name,author) values (#{name},#{author});
</insert>

这种方式是在 insert 节点中添加 selectKey 来实现主键回填,实际上这种方式的功能更加丰富,因为 selectKey 节点中的 SQL 我们既可以在插入之前执行,也可以在插入之后执行(通过设置节点的 Order 属性为 AFTER 或者 BEFORE 可以实现),具体什么时候执行,还是要看具体的需求,如果是做主键回填,我们当然需要在插入 SQL 执行之后执行 selectKey 节点中的 SQL。

注意第二种方式一样也要通过设置 keyProperty 来指定将查询到的数据绑定到哪个属性上。

http://www.tj-hxxt.cn/news/43850.html

相关文章:

  • 川菜餐馆网站建设模板美食餐厅企业建站php源码程序seo网站推广的主要目的包括
  • 企业做的网站计入什么科目网络推广计划书范文
  • 甘南州住房和城乡建设局网站网站seo优化服务
  • 网站双语版的怎么制作百度网页版怎么切换
  • 哈尔滨网站建设制作搜狐视频
  • 网站开发工程师月薪平均青岛百度快速优化排名
  • 网站的产品图片怎样做清晰怎么去推广自己的公司
  • 重庆住房城乡建设厅网站首页营销排名seo
  • 建设部网站 绿色建筑评价表百度营销登录平台
  • 泉州模板建站源码seo教程自学网
  • 网站开发是否属于技术合同互联网十大企业
  • 查看网站有多少空间百度搜索引擎的网址是多少
  • 网站设置不安全google推广技巧
  • bgp 网站重庆百度推广电话
  • 自己电脑做服务器建网站郑州官网关键词优化公司
  • 网站网页优化怎么做郑州怎么优化网站排名靠前
  • 网站背景浙江seo博客
  • 义乌做网站海南网站推广
  • 如何创建一个免费的网站网页制作接单平台
  • 电子商务网站建设汉狮如何做好企业网站的推广
  • 做视频网站需要多大空间百度一下你知道
  • 广州网站建设如何做seo发帖网站
  • 免费手机网站制作浏览器下载大全
  • 外贸公司网站如何做网上推广南宁推广软件
  • 营销型网站建设费用优化排名推广关键词
  • 农家乐网站免费模板全渠道营销管理平台
  • 网站建设中系统实现做关键词优化的公司
  • 现在在百度做网站要多少钱百度云盘资源共享链接群组链接
  • 广告联盟做网站网站关键词优化推广哪家快
  • 怎么做网站的关键词个人免费开发app