如何执行一个mysql的sql脚本文件

如何执行一个mysql的sql脚本文件,第1张

右键文本文件形式打面记录着mysql面执行代码 要执行sql文件面代码需要打mysql数据库执行新手推荐用软件形式执行sql软件navicatsqlyog等 打软件并且配置连接数据库信息打创建数据库右键数据库选执行sql接着选择要执行sql文件按提示步步走即 手推荐使用cmd指令执行sql速度比较快首先连接数据库创建并选择数据库: mysql>use 数据库名; mysql>set names utf吧; --设置传输编码,避免文乱码 mysql>source d:/xxxsql; -- source 文件路径 简单, 等着sql执行完毕即

场景:

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

1. 启动SQL Server Management Studio;

点击开始->所有程序->Microsoft SQL Server 2008 R2->SQL Server Management Studio,

服务器名称:服务器的名称或者IP地址,

登录名和密码:通常都为sa;

点击连接后登录SQL Server Management Studio;

2. 点击文件->打开-->文件(F)…,

选择你要打开的文件,如OptimeSql,打开即可,

3. 选择相应的数据库,如gerp,

点击即可。

using System;

using SystemCollectionsGeneric;

using SystemText;

using SystemIO;

using SystemDataSqlClient;

namespace openfile

{

class Program

{

static void Main(string[] args)

{

baseclass bs=new baseclass();

SystemConsoleWriteLine("请输入路径(例'c://cmdsql')");//输入你要执行文件的目录

string path=SystemConsoleReadLine();

string sql=bssql(path);

int i = 0;

SqlConnection con = new SqlConnection("server=;database=oracle9i;user id=sa;password=123");//可以根据你自己的机子设置的数据库,用户名,密码而定

SqlCommand com = new SqlCommand(sql,con);

conOpen();

for (; i < sqlLength; i++)

{

if (sqlSubstring(i, 0) != " ")

break;

}

if(sqlSubstring(i,6)=="select")

{

SqlDataReader dr;

dr=comExecuteReader();

while(drRead())

{

SystemConsoleWriteLine(dr[0]ToString());

}

}

else

{

comExecuteNonQuery();

SystemConsoleWriteLine(" *** 作成功!");

}

SystemConsoleReadLine();

}

}

class baseclass

{

public string sql(string filepath)

{

StreamReader str = null;

string sm="";

try

{

str = FileOpenText(filepath);

while (strPeek() != -1)

{

sm = strReadLine();

}

strClose();

}

catch

{

sm = "";

}

return sm;

}

public void resoust(string sql)

{

}

}

}

以sqlserver为例

首先创建一张表

create table database_info

(databasename varchar(50));

然后,将所有数据库名的信息录入到这张表中。这步可参考sqlserver中都有哪些数据库。

然后,执行存储过程:

declare @sql nvarchar(4000),@i int,@maxdatabase

select @maxdatabase=count() from database_info

set @i=1

while @i<=@maxdatabase

begin

set @sql='update '

select @sql=sql+datebase_name from database_info where id =@i

select @sql=sql+'masterdbotbl1 set tbl1aaa=tbl2bbb from '

select @sql=sql+datebase_name from database_info where id =@i

eselect @sql=sql+'masterdbotbl2 where tbl1ccc=tbl2ccc'

exec sp_executesql @sql

set @i=@i+1

end

注意事项:其中update语句,可根据自己的实际需要进行修改。

以上就是关于如何执行一个mysql的sql脚本文件全部的内容,包括:如何执行一个mysql的sql脚本文件、sql server自动生成批量执行SQL脚本的批处理、怎么在sql server中执行脚本等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9318198.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存