使用 gvim 处理sql语句

今天遇到了奇怪的事

使用navicat 导出的sql数据插入语句格式如下

inser into [table_name] values(1,'xxx','yyy');

go;

inser into [table_name] values(2,'yyy');

go;

inser into [table_name] values(3,'yyy');

go


把上面的语句一次性的拷贝在sqlserver查询分析器中执行,是提示成功了,可是这些语句一旦被删除了,就会提示此操作将导致n多行的记录被删除,郁闷啊。

于是想到了inser into[table_name] select 。。。

union all

select 。。。

union all

select 。。。

这种方式。但是insert语句非常多,一个一个手动该会累死。于是想到了使用gvim替换。步骤如下

1 1,$s/);//g 把每行末尾的);删除

2 1,$s/go/union all/g 把每行go替换为union all

3 1,$s/insert into \[table_name\] values (/select /g

4 把第一行改为 insert into table_name

于是,最后得到的就是形如

inser into[table_name] select 。。。

union all

select 。。。

union all

select 。。。

效果

相关文章

普通模式 >G 增加当前行到文档末尾处的缩紧层级 $ 移动到本行的末尾 . 相当于一个...
原文连接: https://spacevim.org/cn/layers/lang/elixir/ 模块简介 功能特性 启用模块 快捷键 语言专属...
原文连接: https://spacevim.org/cn/layers/lang/dart/ 模块简介 功能特性 依赖安装及启用模块 启用模...
 =   赋值操作符,可以用于算术和字符串赋值 +        加法计算     -        减法运算...
1.根据包名来查看指定的APP指定数据 adb shell "top | grep com.xxx.xxx" 由于这样打印出来的数...
ctrl+F 向下翻页 ctrl+B 向下翻页 u 取消最近一次操作 U 取消当前行的操作 ZZ 保存当前内容并退出 gg 跳...