zoukankan      html  css  js  c++  java
  • SqlParameter的用法

    1.SqlParameter表示SqlCommand的参数,也可以是他到DataSet列的映射

    到目前为止,我只理解了前半句话,SqlParameter类型的数组作为SqlCommand的参数存在,配合转义字符@,可以有效的防止' or 1=1--单引号而截断字符串,这一经典的注入语句,有效提高拼接型sql命令的安全性。

    例:

    #region   传入参数并且转换为SqlParameter类型
            /// <summary>
            /// 转换参数
            /// </summary>
            /// <param >存储过程名称或命令文本</param>
            /// <param >参数类型</param></param>
            /// <param >参数大小</param>
            /// <param >参数值</param>
            /// <returns>新的 parameter 对象</returns>
            public SqlParameter MakeInParam(string ParamName, SqlDbType DbType, int Size, object Value)
            {
                return MakeParam(ParamName, DbType, Size, ParameterDirection.Input, Value);
            }

            /// <summary>
            /// 初始化参数值
            /// </summary>
            /// <param >存储过程名称或命令文本</param>
            /// <param >参数类型</param>
            /// <param >参数大小</param>
            /// <param >参数方向</param>
            /// <param >参数值</param>
            /// <returns>新的 parameter 对象</returns>
            public SqlParameter MakeParam(string ParamName, SqlDbType DbType, Int32 Size, ParameterDirection Direction, object Value)
            {
                SqlParameter param;

                if (Size > 0)
                    param = new SqlParameter(ParamName, DbType, Size);
                else
                    param = new SqlParameter(ParamName, DbType);

                param.Direction = Direction;
                if (!(Direction == ParameterDirection.Output && Value == null))
                    param.Value = Value;
                return param;
            }
            #endregion

    #region   将命令文本添加到SqlCommand
            /// <summary>
            /// 创建一个SqlCommand对象以此来执行命令文本
            /// </summary>
            /// <param >命令文本</param>
            /// <param 命令文本所需参数</param>
            /// <returns>返回SqlCommand对象</returns>
            private SqlCommand CreateCommand(string procName, SqlParameter[] prams)
            {
                // 确认打开连接
                this.Open();
                SqlCommand cmd = new SqlCommand(procName, con);
                cmd.CommandType = CommandType.Text;     //执行类型:命令文本

                // 依次把参数传入命令文本
                if (prams != null)
                {
                    foreach (SqlParameter parameter in prams)
                        cmd.Parameters.Add(parameter);
                }
                // 加入返回参数
                cmd.Parameters.Add(
                    new SqlParameter("ReturnValue", SqlDbType.Int, 4,
                    ParameterDirection.ReturnValue, false, 0, 0,
                    string.Empty, DataRowVersion.Default, null));

                return cmd;
            }
            #endregion

       #region   执行参数命令文本(无数据库中数据返回)
            /// <summary>
            /// 执行命令
            /// </summary>
            /// <param >命令文本</param>
            /// <param >参数对象</param>
            /// <returns></returns>
            public int RunProc(string procName, SqlParameter[] prams)
            {
                SqlCommand cmd = CreateCommand(procName, prams);
                cmd.ExecuteNonQuery();
                this.Close();
                //得到执行成功返回值
                return (int)cmd.Parameters["ReturnValue"].Value;
            }
            /// <summary>
            /// 直接执行SQL语句
            /// </summary>
            /// <param >命令文本</param>
            /// <returns></returns>
            public int RunProc(string procName)
            {
                this.Open();
                SqlCommand cmd = new SqlCommand(procName, con);
                cmd.ExecuteNonQuery();
                this.Close();
                return 1;
            }

    #endregion

    public int InsertBaseZcmc(string zcmc)
            {
                SqlParameter[] prams = {
                           data.MakeInParam("@zcmc", SqlDbType.VarChar, 50, zcmc),
        };
                return (data.RunProc("INSERT INTO tb_BaseZcmc (zcmc) VALUES (@zcmc)", prams));
            }

    风雪七月花溅墨
  • 相关阅读:
    第一期知识点
    如何正确地停止一个线程?
    JVM知识点总览-高级Java工程师面试必备
    常见GC算法,CMS以及G1的垃圾回收过程,CMS的各个阶段哪两个是Stop the world的,CMS会不会产生碎片,G1的优势。
    深入理解分布式事务,高并发下分布式事务的解决方案
    JVM中的逃逸分析
    JVM内存初学 堆、栈、方法区
    JVM方法栈的工作过程,方法栈和本地方法栈有什么区别。
    JVM的基本结构和JVM的内存结构
    一致性hash算法应用场景、详解与实现(JAVA)
  • 原文地址:https://www.cnblogs.com/bobo41/p/3066433.html
Copyright © 2011-2022 走看看