c#连接sql数据库并调用

1、导入命名空间
  using System.Data.SqlClient;  //连接SQLServer 数据库专用

2、创建连接
  SqlConnection lo_conn = New SqlConnection("Server=服务器名字或IP;Database=数据库名字;uid=用户名;pwd=密码");

3、打开连接,第2步并没有真正连接数据库
  lo_conn.Open();    //真正与数据库连接

4、向数据库发送SQL命令要使用SqlCommand:
  SqlCommand lo_cmd = new SqlCommand();   //创建命令对象
  lo_cmd.CommandText = "这里是SQL语句";   //写SQL语句
  lo_cmd.Connection = lo_con;             //指定连接对象,即上面创建的

5、处理SQL命令或返回结果集
  lo_cmd.ExecuteNonQuery();  //这个仅仅执行SQL命令,不返回结果集,实用于建表、批量更新等不需要返回结果的操作。
  SqlDataReader lo_reader = lo_cmd.ExecuteReader();//返回结果集

6、以数据集的方式反回结果集
  SqlDataAdapter dbAdapter = new SqlDataAdapter(lo_cmd); //注意与上面的区分开
  DataSet ds = new DataSet(); //创建数据集对象
  dbAdapter.Fill(ds); //用返回的结果集填充数据集,这个数据集可以被能操作数据的控件DataBind,其它的就自己发挥了吧

7、关闭连接
  lo_conn.Close();
上面是转了某位好友的,感觉写的不错,其实基本原理就是这样的,下面上个例子:


    /// <summary>
    /// 数据库操作处理器
    /// </summary>
    public class SQLProcessor
    {
        private SqlConnection conn;
        public SqlConnection Conn
        {
            get
            {
                if (conn == null)
                {
                    conn = ConnUtil.CreateConnection();//此处直接是一个连接串:"Initial Catalog=TOPJOIN;Data Source=130.1.0.15;User ID=sa;Password=topdj@123;Connect Timeout=30"
                }
                return conn;
            }
            set
            {
                conn = value;
            }
        }     

        /// <summary>
        /// 执行sql
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="parameters"></param>
        /// <returns></returns>
        public DataSet ExecuteQuery(string sql, SqlParameter[] parameters)
        {
            DataSet ds = new DataSet();
            Conn.Open();
            SqlCommand sc = new SqlCommand(sql, conn);
            sc.Transaction = Conn.BeginTransaction();
            try
            {
                if (!BaseUtil.isArrayEmpty(parameters))
                {
                    sc.Parameters.AddRange(parameters);
                }
                SqlDataAdapter command = new SqlDataAdapter(sc);

                command.Fill(ds);
            }
            catch (Exception e)
            {
                if (sc != null && sc.Transaction != null)
                    sc.Transaction.Rollback();
                if (Conn != null)
                    Conn.Close();
                throw new Exception(e.Message);
            }
            finally
            {
                if (sc != null && sc.Transaction != null)
                    sc.Transaction.Commit();
                if (Conn != null)
                    Conn.Close();
            }
            return ds;
        }

        /// <summary>
        /// 执行存储过程
        /// </summary>
        /// <param name="spname"></param>
        /// <param name="parameters"></param>
        /// <returns></returns>
        public DataSet ExecuteStoredProcedure(string spname, SqlParameter[] parameters)
        {
            DataSet ds = new DataSet();
            Conn.Open();
            SqlCommand cmd = new SqlCommand();
            cmd.CommandType = CommandType.StoredProcedure;//设置cmd的类型为存储过程     
            cmd.CommandText = spname;
            cmd.Connection = conn;
            try
            {
                if (!BaseUtil.isArrayEmpty(parameters))
                {
                    cmd.Parameters.AddRange(parameters);
                }
                SqlDataAdapter command = new SqlDataAdapter(cmd);

                command.Fill(ds);
            }
            catch (Exception e)
            {
                if (Conn != null)
                    Conn.Close();
                throw new Exception(e.Message);
            }
            finally
            {
                if (cmd != null && cmd.Transaction != null)
                    cmd.Transaction.Commit();
                if (Conn != null)
                    Conn.Close();
            }
            return ds;
        }

下面是一个调用的例子:

            string sql = " select * from User where code = @Code ";
            List<SqlParameter> lsp = new List<SqlParameter>();
            lsp.Add(new SqlParameter("Code", code));//code为参数值哈
            SQLProcessor sp = new SQLProcessor();
            DataSet ds = sp.ExecuteQuery(sql, lsp.ToArray()) as DataSet;
或者这样用:

            StringBuilder sb = new StringBuilder();
            sb.Append(" select * from User ");
            sb.Append(string.Format(" where code ='{0}' ",new String[]{code}));//code为参数值哈
            SQLProcessor sp = new SQLProcessor();
            DataSet ds = sp.ExecuteQuery(sb.ToString(),null) as DataSet;


(存储过程的调用时一样的哈,这里不举例子了)
好了,取到DataSet了,你就可以随便操作了!





  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
首先,确保已经安装了 SQL Server 数据库和 Visual Studio 编辑器。 然后,按照以下步骤进行操作: 1. 在 Visual Studio 中创建一个新的 C# 项目。 2. 在解决方案资源管理器中右键单击项目名称,选择“添加” ->“新建项” ->“数据” ->“数据集”。 3. 在“数据集设计器”中,右键单击空白处,选择“添加”->“新建连接”。 4. 在“添加连接”对话框中,输入 SQL Server 数据库的相关信息,例如服务器名称、身份验证方式、用户名和密码等。点击“测试连接”按钮,确保连接成功。 5. 点击“确定”按钮,返回“数据集设计器”。 6. 在“数据集设计器”中,右键单击空白处,选择“添加”->“查询”。 7. 在“查询设计器”中,输入 SQL 查询语句,例如“SELECT * FROM 表名”。 8. 点击“执行查询”按钮,确保查询结果正确。 9. 在“数据集设计器”中,右键单击查询结果,选择“生成数据表适配器”。 10. 在“配置数据表适配器向导”中,选择“使用 SQL 语句生成 SELECT 语句”,点击“下一步”按钮。 11. 在“配置数据表适配器向导”中,选择“使用现有的数据库连接”,选择之前创建的数据库连接,点击“下一步”按钮。 12. 在“配置数据表适配器向导”中,选择“生成更新、插入和删除语句”,点击“下一步”按钮。 13. 在“配置数据表适配器向导”中,选择“保存连接字符串以供应用程序使用”,点击“完成”按钮。 14. 在代码中调用数据表适配器的方法,例如 Fill、Update 等,即可对数据库进行增删改查操作。 以上就是使用 C# 在 Visual Studio 中连接 SQL Server 数据库的基本步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值