如何解决mysql的数据库导入sql server
最大的问题是id自增问题
mysql的表经常有字段是id是自增长的,我们通过navicat的tools的data transfer
可以将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这栏的标识规范,是标识改成是
然后在执行我们导出去的脚本,记住要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' 中的标识列插入显式值
共同学习,写下你的评论
评论加载中...
作者其他优质文章