CREATE PROCEDURE sp_page
@tblName varchar(255),
@strGetFields varchar(1000) ,
@fldName varchar(255),
@PageSize int ,
@PageIndex int ,
@doCount bit,
@OrderType bit ,
@strWhere varchar(1500)
AS

declare @strSQL varchar(5000)
declare @strTmp varchar(110)
declare @strOrder varchar(400)

if @doCount != 0
begin
if @strWhere !=""
set @strSQL = "select count(*) as Total from [" + @tblName + "] where "+@strWhere
else
set @strSQL = "select count(*) as Total from [" + @tblName + "]"
end
else
begin
if @OrderType != 0
begin
set @strTmp = "<(select min"
set @strOrder = " order by [" + @fldName +"] desc"
end
else
begin
set @strTmp = ">(select max"
set @strOrder = " order by [" + @fldName +"] asc"
end

if @PageIndex =0
begin
if @strWhere !=""

set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from [" + @tblName + "] where " + @strWhere + " " + @strOrder
else

set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["+ @tblName + "] "+ @strOrder

end
else
begin
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["+ @fldName +
"]) from (select top " + str(@PageIndex*@PageSize) + " ["+ @fldName +
"] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"+ @strOrder

if @strWhere !=""
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
+ @fldName + "]) from (select top " + str(@PageIndex*@PageSize) + " ["
+ @fldName + "] from [" + @tblName + "] where " + @strWhere + " "
+ @strOrder + ") as tblTmp) and " + @strWhere + " " + @strOrder
end

end

exec (@strSQL)
GO

c#实现代码为:
using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.Data.SqlClient;
using System.Threading;
using System.Text;

namespace WindowsApplication4


{

/**//// <summary>
/// Form1 的摘要说明。
/// </summary>
public class Form1 : System.Windows.Forms.Form

{
private System.Windows.Forms.Button button1;
private System.Windows.Forms.Label label1;
int threadindex=0;

/**//// <summary>
/// 必需的设计器变量。
/// </summary>
private System.ComponentModel.Container components = null;

public Form1()

{
//
// Windows 窗体设计器支持所必需的
//
InitializeComponent();

//
// TODO: 在 InitializeComponent 调用后添加任何构造函数代码
//
}


/**//// <summary>
/// 清理所有正在使用的资源。
/// </summary>
protected override void Dispose( bool disposing )

{
if( disposing )

{
if (components != null)

{
components.Dispose();
}
}
base.Dispose( disposing );
}


Windows 窗体设计器生成的代码#region Windows 窗体设计器生成的代码

/**//// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()

{
this.button1 = new System.Windows.Forms.Button();
this.label1 = new System.Windows.Forms.Label();
this.SuspendLayout();
//
// button1
//
this.button1.Location = new System.Drawing.Point(208, 368);
this.button1.Name = "button1";
this.button1.Size = new System.Drawing.Size(144, 40);
this.button1.TabIndex = 0;
this.button1.Text = "button1";
this.button1.Click += new System.EventHandler(this.button1_Click);
//
// label1
//
this.label1.Location = new System.Drawing.Point(40, 8);
this.label1.Name = "label1";
this.label1.Size = new System.Drawing.Size(496, 336);
this.label1.TabIndex = 1;
this.label1.Text = "label1";
//
// Form1
//
this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);
this.ClientSize = new System.Drawing.Size(584, 422);
this.Controls.Add(this.label1);
this.Controls.Add(this.button1);
this.Name = "Form1";
this.Text = "Form1";
this.ResumeLayout(false);

}
#endregion


/**//// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main()

{
Application.Run(new Form1());
}

private void button1_Click(object sender, System.EventArgs e)

{
threadindex=0;
for(int i=0;i<30;i++)

{
// Thread myThread = new Thread(new ThreadStart(dosome));
// myThread.IsBackground=true;
// myThread.Name="dothread"+i.ToString();
// myThread.Start();
ThreadPool.QueueUserWorkItem(new WaitCallback(dosome));
}
//dosome();
}

public void dosome(Object obj)

{
SqlConnection _connection=new SqlConnection("server=192.168.0.8;uid=sa;pwd=;database=dbtest;persist security info=False;packet size=4096");




SqlParameter[] sqlParameters1 = new SqlParameter[]
{
new SqlParameter("@tblName",SqlDbType.VarChar,255),
new SqlParameter("@strGetFields", SqlDbType.VarChar, 1000),
new SqlParameter("@fldName",SqlDbType.VarChar,255),
new SqlParameter("@PageSize",SqlDbType.Int,4),
new SqlParameter("@PageIndex",SqlDbType.Int,4),
new SqlParameter("@doCount",SqlDbType.Bit),
new SqlParameter("@OrderType",SqlDbType.Bit),
new SqlParameter("@strWhere",SqlDbType.VarChar,1500)
};
sqlParameters1[0].Value = "songs";
sqlParameters1[1].Value = "*";
sqlParameters1[2].Value = "ssongname";
sqlParameters1[3].Value = 10;
sqlParameters1[4].Value =threadindex;
sqlParameters1[5].Value =false;
sqlParameters1[6].Value = true;
sqlParameters1[7].Value =" SongNameLength=4 ";
SqlDataReader dataread=null;
try

{
dataread=RunProcedure("sp_page",sqlParameters1,_connection);
}
catch (SqlException e)

{
MessageBox.Show(e.ToString());
}


StringBuilder sb=new StringBuilder();
if(dataread.Read())

{
while(dataread.Read())

{
sb.Append(dataread["ssongname"]);
sb.Append("\n");
}
}
dataread.Close();
label1.Text=String.Empty;
label1.Text=sb.ToString();
threadindex++;
}

private SqlCommand BuildQueryCommand(string storedProcName, IDataParameter[] parameters,SqlConnection _connection)

{
SqlCommand sqlCommand = new SqlCommand(storedProcName, _connection);
sqlCommand.CommandType = CommandType.StoredProcedure;
IDataParameter[] iDataParameters = parameters;
for (int i = 0; i < (int)iDataParameters.Length; i++)

{
SqlParameter sqlParameter = (SqlParameter)iDataParameters[i];
sqlCommand.Parameters.Add(sqlParameter);
}
return sqlCommand;
}


protected SqlDataReader RunProcedure(string storedProcName, IDataParameter[] parameters,SqlConnection _connection)

{
_connection.Open();
SqlCommand sqlCommand = BuildQueryCommand(storedProcName, parameters,_connection);
sqlCommand.CommandType = CommandType.StoredProcedure;
return sqlCommand.ExecuteReader(CommandBehavior.CloseConnection);
}


}
}

posted on 2005-06-30 16:30
MyRiverMan 阅读(250)
评论(0) 编辑 收藏 引用