php 调用mssql存储过程,php调用mssql存储过程实例应用

本文介绍了如何使用PHP连接到MSSQL数据库,并通过mssql_init、mssql_bind和mssql_execute函数执行存储过程进行大数据处理。示例代码展示了如何初始化存储过程,绑定参数并执行,从而获取和处理数据。存储过程`Bigdatabase`用于分页查询大量人员信息,注意在处理text类型字段时需要将其转换为varchar。
摘要由CSDN通过智能技术生成

用mssql_init语句用于初始化存储过程,而后调用mssql_bind语句指定存储过程参数,最后调用mssql_execute执行存储过程.

连接mssql数据库教程服务器,代码如下:$link = mssql_connect("127.0.0.1", "sa", "sa") or die("Can't connect sql server");

mssql_select_db("frrc", $link) or die("Select database failure");

//初始化并加载存储过程 Bigdatabase

$stmt = mssql_init("Bigdatabase", $link) or die("initialize stored procedure failure");

mssql_bind($stmt, "@pagesize", $pagesize, SQLINT4);

mssql_bind($stmt, "@start", $start, SQLINT4);

@$ms_result = mssql_execute($stmt, false);

mssql_query("DUMP TRANSACTION tempdb WITH NO_LOG");

do{

}while( $ms_rs = mssql_fetch_object($ms_result) )

{

//进行数据处理

}

// msssql 存储过程 Bigdatabase如下

//开源代码phprm.com

/*

CREATE PROCEDURE Bigdatabase

@pagesize int,

@start int

AS

declare @bsql nvarchar(4000)

set @bsql = 'select top ' + str(@pagesize) + ' username,jobid,password,useremail,zcdata,ip,name,xingbie,minzu,xueli,hunyin,age,xuexiao,zyclass,zhuanye,x_suozaidi,x_suozaidi1,huji,huji1,shengao,byear,birthyear,birthmonth,birthday,dianhua,qq,gerenzhuye,selectedjob1,selectedjob2,selectedjob3,s_PWL1,s_PWL2,s_PWL3,daiyuyaoqiu,Negotiable,provideHouseNeeded,availOpts,availNotice,llcs,CONVERT(varchar(100),dlsj, 25) as dlsj,xgsj,dlcs,jsjshuiping,language_one,l_OneAbility,language_two,l_twoAbility,mandarinLevel,skillkey,jingyan,photopb,photo,phototre,mbsys,codetype,code,shouji,posts,address,jobtype,convert(varchar(8000),pingjia) as pingjia ,convert(varchar(8000),jinengzhuanchang) as jinengzhuanchang ,convert(varchar(8000),fazhanfangxiang) as fazhanfangxiang,convert(varchar(8000),other) as other from person where id not in(select top ' + str(@start) + ' id from person order by id asc) order by id asc '

execute sp_executesql @bsql

GO

注:必须把text转换成varchar来处理,否则会出问题.

教程链接:

随意转载~但请保留教程地址★

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值