如果你是为SQL SERVER的写批处理,那么SQL 2000以前叫查询分析器的工具及以后的管理工作室(MANAGEMENT STUDIO)是非常好的工具,直接写脚本就可以了,通常不同的"GO"之间就是不同的任务。
场景:
DBA那边给我导出了所有的存储 函数等等对象的创建脚本 有上千个文件
现在需要将这些对象创建脚本导入到另外一个库 如何解决呢?
手动一个个执行显然不太现实
于是手动写了一个批处理 将所有的文件形成一个 SQL的脚本 最后以@生成的 SQL脚本方式导入到目标库中
OS环境:WINDOWS xp
脚本内容如下:
@echo off if exist list sql del list sql /q :input cls set input=: set /p input= 请输入要进行判断的路径 set "input=%input:"=%" :: 上面这句为判断%input%中是否存在引号 有则剔除 if "%input%"==":" goto input if not exist "%input%" goto input for /f "delims=" %%i in ( dir /b /a d /s "%input%" ) do echo @@%%~fnxi>>list sql if not exist list sql goto no_file start list sql exit :no_file cls echo %cur_dir% 出现错误 未成功生成list sql脚本! pause
使用:
另存为 BAT类型文件后 双击执行
输入你脚本的路径:
如我的E盘CRY文件夹下 有如下类型的文件:
TEST PRC
TEST FNC(有子文件夹 )
TEST VW
执行该批处理后 最后生成的list sql脚本文件内容如下(执行完批处理后会用默认的编辑器自动打开该文件):
@@E:cryTEST PRC
@@E:cry TEST FNC
@@E:cryTEST VW
打开SQLPLUS 以指定用户登录数据库 然后执行: (我的脚本文件生成在d盘)
@D:list sql
这样所有的对象就会自动在指定用户下生成
lishixinzhi/Article/program/SQLServer/201311/22286
使用逆向思维来解决这个问题:
感觉你的这个问题可以使用sql中的变量来实现,
drop database @dataname
然后就是声明这个dataname了
declare @dataname varchar(10)
但是现在问题就是如何给变量@dataname赋值,你的意思是想象从控制台接收一个参数吧,然后实现删除数据库的效果吧
但是感觉数据库好像没有这样的功能,如果你有变成语言的基础,可以把数据库和变成语言结合起来的话,要实现这个效果的话,就非常的简单啦
我会java、c#不知道这两个语言你会不 如果你同意我的建议 你还是不会的话 你可以再联系我
但愿可以帮助你 谢谢
数据库同时执行语句是有限制的,当数据库同时处理语句太多的时候,有可能造成数据库崩溃,所以一般数据库里的内容都是有备份的,但是可以对数据库进行优化,提高性能。我用的mysql数据库,在mysql数据库优化一般可以分为4部分,一、安装的时候各种软件搭配可以提高性能,二、在数据库的配置文件里可以更改,三、设计表的时候可以对表进行优化,如一个库里表不要超过300-400张、尽量把字符串转换成数字类型、索引等各种优化,四、在使用查询语句,添加语句的时候可以优化提高性能等
应该还是在双击运行的时候缺少路径所致(python27好像也有这个问题)
你试试在批处理中添加一下path变量:
set path=%path%;x:\xxx\osqlexe或者使用osqlexe的时候直接使用全路径:
"x:\xxx\osqlexe" -h -s xxxxxxx以上就是关于创建一个SQL数据库的批处理如何写全部的内容,包括:创建一个SQL数据库的批处理如何写、sql server自动生成批量执行SQL脚本的批处理、使用批处理命令,删除、分离指定SQL数据库的方法。等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)