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

最大的问题是id自增问题

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

AAffA0nNPuCLAAAAAElFTkSuQmCC

可以将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这栏的标识规范,是标识改成是

AAffA0nNPuCLAAAAAElFTkSuQmCC

然后在执行我们导出去的脚本,记住要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 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})

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值