继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

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

nickcau
关注TA
已关注
手记 114
粉丝 6509
获赞 303

最大的问题是id自增问题

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


http://img3.mukewang.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这栏的标识规范,是标识改成是

http://img1.mukewang.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' 中的标识列插入显式值

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP