⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sqlcommandgenerator.cs

📁 SharpNuke源代码
💻 CS
字号:
using System;
using System.Data;
using System.Data.SqlClient;
using System.Diagnostics;
using System.Reflection;

//
// DotNetNuke -  http://www.dotnetnuke.com
// Copyright (c) 2002-2005
// by Shaun Walker ( sales@perpetualmotion.ca ) of Perpetual Motion Interactive Systems Inc. ( http://www.perpetualmotion.ca )
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
// documentation files (the "Software"), to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and
// to permit persons to whom the Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all copies or substantial portions
// of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
// TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
// CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//



//
// SQLCommandGenerator
//
// Generate Command Object based on Method
//
// Sample Usage:
//
// Dim myCommand As SqlCommand = SqlCommandGenerator.GenerateCommand(myConnection, _
//    CType(MethodBase.GetCurrentMethod(), MethodInfo), _
//    New Object() {MethodParameter1, MethodParameter2})
//
// Dim myCommand As SqlCommand = SqlCommandGenerator.GenerateCommand(myConnection, _
//    CType(MethodBase.GetCurrentMethod(), MethodInfo), _
//    New Object() {IIf(PortalId <> -1, PortalId, SqlInt16.Null)})
//

namespace DotNetNuke.Data
{
	
	public sealed class SqlCommandGenerator
	{
		
		private SqlCommandGenerator() 
		{
			throw (new NotSupportedException());
		}
		
		public static string ReturnValueParameterName = "RETURN_VALUE";
		public static object[] NoValues;
		
		public static SqlCommand GenerateCommand(SqlConnection connection, MethodInfo method, 
			object[] values, CommandType sqlCommandType, string sqlCommandText)
		{
			if (method == null)
			{
				method = ((MethodInfo) new StackTrace().GetFrame(1).GetMethod());
			}
			
			SqlCommand command = new SqlCommand();
			command.Connection = connection;
			command.CommandType = sqlCommandType;
			
			if (sqlCommandText.Length == 0)
			{
				command.CommandText = method.Name;
			}
			else
			{
				command.CommandText = sqlCommandText;
			}
			
			if (command.CommandType == CommandType.StoredProcedure)
			{
				GenerateCommandParameters(command, method, values);
				
				command.Parameters.Add(ReturnValueParameterName, SqlDbType.Int).Direction = ParameterDirection.ReturnValue;
			}
			
			return command;
		}
		
		private static void GenerateCommandParameters (SqlCommand command, MethodInfo method, object[] values)
		{
			ParameterInfo[] methodParameters = method.GetParameters();
			
			int paramIndex = 0;
			
			foreach (ParameterInfo paramInfo in methodParameters)
			{
				if (! Attribute.IsDefined(paramInfo, typeof(NonCommandParameterAttribute)))
				{
					SqlParameterAttribute paramAttribute = ((SqlParameterAttribute) Attribute.GetCustomAttribute(paramInfo, typeof(SqlParameterAttribute)));
					if (paramAttribute == null)
					{
						paramAttribute = new SqlParameterAttribute(null, 0, 0, 0);
					}

					SqlParameter sqlParameter = new SqlParameter();
					
					if (paramAttribute.IsNameDefined)
					{
						sqlParameter.ParameterName = paramAttribute.Name;
					}
					else
					{
						sqlParameter.ParameterName = paramInfo.Name;
					}
					if (! sqlParameter.ParameterName.StartsWith("@"))
					{
						sqlParameter.ParameterName = "@" + sqlParameter.ParameterName;
					}
					if (paramAttribute.IsTypeDefined)
					{
						sqlParameter.SqlDbType = paramAttribute.SqlDbType;
					}
					if (paramAttribute.IsSizeDefined)
					{
						sqlParameter.Size = paramAttribute.Size;
					}
					if (paramAttribute.IsScaleDefined)
					{
						sqlParameter.Scale = paramAttribute.Scale;
					}
					if (paramAttribute.IsPrecisionDefined)
					{
						sqlParameter.Precision = paramAttribute.Precision;
					}
					if (paramAttribute.IsDirectionDefined)
					{
						sqlParameter.Direction = paramAttribute.Direction;
					}
					else
					{
						if (paramInfo.ParameterType.IsByRef)
						{
							if (paramInfo.IsOut)
							{
								sqlParameter.Direction = ParameterDirection.Output;
							}
							else
							{
								sqlParameter.Direction = ParameterDirection.InputOutput;
							}
						}
						else
						{
							sqlParameter.Direction = ParameterDirection.Input;
						}
					}
					
					sqlParameter.Value = values[paramIndex];
					command.Parameters.Add(sqlParameter);
					
					paramIndex += 1;
				}
			}
			
		}
		
	}
	
}



⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -