|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
如果表有1000个记录,通过索引查找记录至少要比顺序扫描记录快100倍。 下文先容的MySql存储历程是带参数的存储历程(静态实行SQL语句),该MySql存储历程是依据用户输出的前提和排序体例查询用户的信息,排序前提能够没有挪用体例:
callGetUsersDynamic(age<=30,);- /********静态查询用户的信息********/CREATEPROCEDUREGetUsersDynamic(WhereConditionvarchar(500),OrderByExpressvarchar(100))begindeclarestmtvarchar(2000);ifLENGTH(OrderbyExpress)>0thenbeginset@sqlstr=concat(selectid,name,password,age,getdate(adddate)asAddDatefromuserswhere,WhereCondition,orderby,OrderByExpress);end;elsebeginset@sqlstr=concat(selectid,name,password,age,getdate(adddate)asAddDatefromuserswhere,WhereCondition);end;endif;preparestmtfrom@sqlstr;executestmt;end;
复制代码 getdate()是一个自界说的函数,感化是前往日期的短格局- CREATEDEFINER=`root`@`localhost`FUNCTION`getdate`($datedatetime)RETURNSvarchar(50)CHARSETlatin1returndate_format($date,%Y-%m-%d);
复制代码 静态拔出数据的MySql存储历程,(注重四个单引号暗示一个一引号):- CREATEDEFINER=`root`@`localhost`PROCEDURE`InsertUser`(inname2varchar(50),inpassword2varchar(32),inage2int,inadddate2datetime)beginDECLAREstmtvarchar(2000);set@sqlstr=concat(insertintousers(name,password,age,adddate)values();set@sqlstr=concat(@sqlstr,,name2,,,,,password2,,,,age2,,,,adddate2,,));preparestmtfrom@sqlstr;executestmt;end;
复制代码 <Pstyle="TEXT-INDENT:2em">
最近由权威调查机构Evans数据公司进行的一项调查显示,MySQL在过去两年已经获得了25%的市场份额。该调查公司还预测,相比其他的开源数据库和闭源数据库。 |
|