zoukankan      html  css  js  c++  java
  • C# 调用*.sql第一种

    using System;
    using System.Xml;
    using System.Data;
    using System.IO;
    using System.Collections;
    using System.Data.SqlClient;

    namespace ExecuteSqlFile
    {
    /// <summary>
    /// DBAccess 的摘要说明。
    /// </summary>
    public class DBAccess
    {
    public DBAccess()
    {
    }

    #region 属性

    private static string ConStr = "";

    private static string ConString
    {
    get
    {
    if(ConStr == "")
    {
    try
    {
    XmlDocument doc = new XmlDocument();
    doc.Load("ServerConfig.xml");

    string userid = doc.SelectSingleNode("ServerConfig/UserId").InnerText;
    string password = doc.SelectSingleNode("ServerConfig/PassWord").InnerText;
    string servername = doc.SelectSingleNode("ServerConfig/ServerName").InnerText;
    string database = doc.SelectSingleNode("ServerConfig/DataBase").InnerText;
    ConStr = "server = " + servername + ";uid = "
    + userid + ";pwd = " + password + ";database = " + database;
    }
    catch(Exception ex)
    {
    throw ex;
    }
    }

    return ConStr;
    }
    }

    private static SqlConnection Con;


    public static SqlConnection MyConnection
    {
    get
    {
    if(Con == null)
    {
    Con = new SqlConnection(ConString);
    }
    return Con;
    }
    }

    #endregion


    /// <summary>
    /// 执行Sql文件
    /// </summary>
    /// <param name="varFileName">文件的名称</param>
    /// <returns></returns>
    public static bool ExecuteSqlFile(string varFileName)
    {
    if(!File.Exists(varFileName))
    {
    return false;
    }

    StreamReader sr = File.OpenText(varFileName);

    ArrayList alSql = new ArrayList();

    string commandText = "";

    string varLine = "";

    while(sr.Peek() > -1)
    {
    varLine = sr.ReadLine();
    if(varLine == "")
    {
    continue;
    }
    if(varLine != "GO")
    {
    commandText += varLine;
    commandText += "\r\n";
    }
    else
    {
    alSql.Add(commandText);
    commandText = "";
    }
    }

    sr.Close();

    try
    {
    ExecuteCommand(alSql);
    }
    catch
    {
    return false;
    }

    return true;
    }


    private static void ExecuteCommand(ArrayList varSqlList)
    {
    MyConnection.Open();
    SqlTransaction varTrans = MyConnection.BeginTransaction();

    SqlCommand command = new SqlCommand();
    command.Connection = MyConnection;
    command.Transaction = varTrans;

    try
    {
    foreach(string varcommandText in varSqlList)
    {
    command.CommandText = varcommandText;
    command.ExecuteNonQuery();
    }
    varTrans.Commit();
    }
    catch(Exception ex)
    {
    varTrans.Rollback();
    throw ex;
    }
    finally
    {
    MyConnection.Close();
    }
    }
    }
    }



    配置文件如下:
    <?xml version="1.0" encoding="utf-8" ?>
    <ServerConfig>
    <ServerName>localhost</ServerName>
    <DataBase>tttttt</DataBase>
    <UserId>sa</UserId>
    <PassWord>sa</PassWord>
    </ServerConfig>
    保存为ServerConfig.xml
    放到Bin/Debug/里面
  • 相关阅读:
    在JS和.NET中使用JSON (以及使用Linq to JSON定制JSON数据)
    转载JSON格式化工具
    bzoj3771 Triple
    hdu 2082 找单词
    bzoj 3143: [Hnoi2013]游走
    Wannafly挑战赛17 B
    基尔霍夫矩阵
    矩阵&行列式
    luogu P2421 [NOI2002]荒岛野人
    bzoj 2818: Gcd
  • 原文地址:https://www.cnblogs.com/nj0409/p/1365264.html
Copyright © 2011-2022 走看看