.NET调用osql.exe执行sql脚本创建表和存储过程

简介: 文章出处:http://wenjl520.cnblogs.com/  或  http://www.cnblogs.com/using System;using System.Diagnostics;using System.
文章出处:http: // wenjl520.cnblogs.com/  或   http://www.cnblogs.com/

using System;
using System.Diagnostics;
using System.Windows.Forms;

namespace WindowsFormsApplication1
{
     public  partial  class Form1 : Form
    {
         public Form1()
        {
            InitializeComponent();
        }

         private  void button1_Click( object sender, EventArgs e)
        {
             // 参数
             string[] args =  new  string[ 5];
            args[ 0] =  " -U  " + txtUserName.Text;  // 用户名
            args[ 1] =  " -P  " + txtPassword.Text;  // 用户密码
            args[ 2] =  " -S  " + txtServer.Text;  // 服务器
            args[ 3] =  " -d  " + txtDatabase.Text;  // 数据库
            args[ 4] =  " -i  " + AppDomain.CurrentDomain.BaseDirectory +  " Install.sql "// sql脚本路径

            
// 执行
            textBox1.Text = CommandLine( " osql.exe ", args);
        }

         #region 调用命令行工具

         ///   <summary>
        
///  调用命令行工具
        
///   </summary>
        
///   <param name="name"> 命令行工具名称 </param>
        
///   <param name="args"> 可选命令行参数 </param>
        
///   <remarks> 注意:所有命令行工具都必须保存于system32文件夹中 </remarks>
        
///   <returns></returns>
         private  string CommandLine( string name,  params  string[] args)
        {
             return CommandLine(name,  "", args);
        }

         ///   <summary>
        
///  调用命令行工具
        
///   </summary>
        
///   <param name="name"> 命令行工具名称 </param>
        
///   <param name="workingDirectory"> 设置工作目录 </param>
        
///   <param name="args"> 可选命令行参数 </param>
        
///   <remarks> 注意:所有命令行工具都必须保存于system32文件夹中 </remarks>
        
///   <returns></returns>
         private  string CommandLine( string name,  string workingDirectory,  params  string[] args)
        {
             string returnValue =  "";

             using (Process commandline =  new Process())
            {
                 try
                {
                    commandline.StartInfo.UseShellExecute =  false;
                    commandline.StartInfo.CreateNoWindow =  true;
                    commandline.StartInfo.WindowStyle = ProcessWindowStyle.Hidden;
                    commandline.StartInfo.RedirectStandardOutput =  true;
                    commandline.StartInfo.FileName = name;
                    commandline.StartInfo.WorkingDirectory = workingDirectory;
                     // 添加命令行参数
                     if (args.Length >  0) commandline.StartInfo.Arguments =  string.Join( "   ", args);
                    commandline.Start();
                    commandline.WaitForExit();
                    returnValue = commandline.StandardOutput.ReadToEnd();
                    commandline.Close();
                }
                 catch
                {
                    commandline.Dispose();
                     throw;
                }
            }

             return returnValue;
        }

         #endregion
    }
}

复制代码
 
 
 

目录
相关文章
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
66 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
2月前
|
SQL 测试技术 数据库
SQL注入,跨站脚本,跨站请求伪造,傻傻分不清楚
SQL注入,跨站脚本,跨站请求伪造,傻傻分不清楚
|
3月前
|
SQL 存储 关系型数据库
sql语句,索引,视图,存储过程
sql语句,索引,视图,存储过程
30 0
|
3月前
|
存储 SQL 缓存
4.2.1 SQL语句、索引、视图、存储过程
4.2.1 SQL语句、索引、视图、存储过程
|
1月前
|
存储 SQL 数据库
sql serve存储过程
sql serve存储过程
14 0
|
1月前
|
存储 SQL
物料清单应用输入模板的SQL存储过程设计
物料清单应用输入模板的SQL存储过程设计
|
2月前
|
SQL 开发框架 .NET
ASP.NET Web——GridView完整增删改查示例(全篇幅包含sql脚本)大二结业考试必备技能
ASP.NET Web——GridView完整增删改查示例(全篇幅包含sql脚本)大二结业考试必备技能
33 0
|
3月前
|
存储 SQL Oracle
PL/SQL存储过程的使用
PL/SQL存储过程的使用
68 1
|
4月前
|
存储 SQL Oracle
|
23天前
|
存储 SQL 关系型数据库
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)