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

2020/4/1 8:01:20

本文主要是介绍如何解决mysql的数据库导入sql server,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

最大的问题是id自增问题

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


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

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

点击查看更多内容


这篇关于如何解决mysql的数据库导入sql server的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程