为了账号安全,请及时绑定邮箱和手机立即绑定

如何解决mysql的数据库导入sql server

标签:
Java SQL Server

最大的问题是id自增问题

mysql的表经常有字段是id是自增长的,我们通过navicat的tools的data transfer


https://img1.sycdn.imooc.com//5e82eb850001e6e017440106.jpg


可以将mysql的数据导入sql server

然后我们在sql server中通过数据库的任务->生成脚本

把这张表的插入语句导出去,类似下面这样

INSERT [dbo].[tb_admin] ([id], [username], [password], [salt], [role_id], [dept_id], [deptname], [child_dept_id]) VALUES (16, N'护理部', N'e10adc3949ba59abbe56e057f20f883e', NULL, 2, 21590150, N'护理部', 0)


alter table tb_admin drop column id
alter table tb_admin add id int identity(1,1)

执行上面的语句把id这栏的标识规范,是标识改成是

https://img1.sycdn.imooc.com//5e82ebf000019c5a11600820.jpg

然后在执行我们导出去的脚本,记住要IDENTITY改成on

set IDENTITY_INSERT [tb_admin]  on

INSERT [dbo].[tb_admin] ([id], [username], [password], [salt], [role_id], [dept_id], [deptname], [child_dept_id]) VALUES (15, N'厦门医院筹备小组', N'e10adc3949ba59abbe56e057f20f883e', NULL, 61, 1625494, N'厦门医院筹备小组', 0)

执行好这个以后,我们java代码就不能显示的写插入语句


<insert id="insert" parameterType="com.irs.pojo.TbAdmin" >
  insert into tb_admin (username, password,
    salt, role_id, dept_id,
    deptname, child_dept_id)
  values (#{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR},
    #{salt,jdbcType=VARCHAR}, #{roleId,jdbcType=INTEGER}, #{deptId,jdbcType=INTEGER},
    #{deptname,jdbcType=VARCHAR}, #{childDeptId,jdbcType=INTEGER})
</insert>


不要将id带上,不然会报错当 IDENTITY_INSERT 设置为 OFF 时,不能为表 'tb_users' 中的标识列插入显式值

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消