扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
1231231231231231312
创新互联"三网合一"的企业建站思路。企业可建设拥有电脑版、微信版、手机版的企业网站。实现跨屏营销,产品发布一步更新,电脑网络+移动网络一网打尽,满足企业的营销需求!创新互联具备承接各种类型的网站设计制作、成都做网站项目的能力。经过十年的努力的开拓,为不同行业的企事业单位提供了优质的服务,并获得了客户的一致好评。
触发器
1. 什么是触发器
触发器是一种特殊类型的存储过程,不由用户直接调用。创建触发器时会对其进行定义,以便在对特定表或列作特定类型的数据修改时执行。
触发器从本质上来说,是一个存储过程,但是它与普通的存储过程不一样的地方在于,普通的存储过程是通过CALL方法进行调用的,而触发器不是用CALL调用,触发器是在我们提前设定好的事件出现以后,自动被调用的。
2.为什么要用触发器
我们在MySQL 5.0中包含对触发器的支持是由于以下原因:
(1)MySQL早期版本的用户长期有需要触发器的要求。
(2)我们曾经许诺支持所有ANSI标准的特性。
(3)您可以使用它来检查或预防坏的数据进入数据库。
(4)您可以改变或者取消INSERT, UPDATE以及DELETE语句。
(5)您可以在一个会话中监视数据改变的动作。在这里我假定大家都读过"MySQL新特性"丛书的第一集--"MySQL存储过程",那么大家都应该知道MySQL至此存储过程和函数,那是很重要的知识,因为在触发器中你可以使用在函数中使用的语句。特别举个例子:
①复合语句(BEGIN / END)是合法的.
②流控制(Flow-of-control)语句(IF, CASE, WHILE, LOOP, WHILE, REPEAT, LEAVE,ITERATE)也是合法的.
③变量声明(DECLARE)以及指派(SET)是合法的.
④允许条件声明.
⑤异常处理声明也是允许的.
⑥但是在这里要记住函数有受限条件:不能在函数中访问表.
因此在函数中使用以下语句是非法的。
ALTER 'CACHE INDEX' CALL COMMIT CREATE DELETE
DROP 'FLUSH PRIVILEGES' GRANT INSERT KILL
LOCK OPTIMIZE REPAIR REPLACE REVOKE
ROLLBACK SAVEPOINT 'SELECT FROM table'
'SET system variable' 'SET TRANSACTION'
SHOW 'START TRANSACTION' TRUNCATE UPDATE
在触发器中也有完全一样的限制.触发器相对而言比较新,因此会有(bugs)缺陷.所以我在这里给大家警告,就像我在存储过程书中所说那样.不要在
含有重要数据的数据库中使用这个触发器,如果需要的话在一些以测试为目的的数据库上使用,同时在你对表创建触发器时确认这些数据库是默认的。
2.1 触发器的主要用途
触发器主要用于在多个有相互关系的表之间,做一些相互关联的操作。
2.2 临时表
更新:更新是用一条新的数据 替换一条旧的数据。在系统中,更新操作分为以下2个步骤:
(1)首先,把旧的数据删掉
(2)把新的数据插入表中。
在进行以上两个步骤之前,系统又进行了3个步骤:
(1) 系统创建两张临时表,临时表与要操作的表的结构完全相同,仅是结构相同,但是临时表中并无数据。
(2) 系统向其中一张临时表插入要更新的数据,
(3) 系统把要删除的,即要被更新的数据,插入另外一张临时表当中。
2.2.1 临时表的叫法:
NEW:用来插入新数据的临时表
OLD:数据要被替换的临时表
2.2.2 临时表的使用
NEW 列名获取插入值
2.2.3 使用不同的语句与使用临时表的关系
使用UPDATA语句:可以使用NEW和OLD两张临时表
使用INSERT语句:只能使用NEW临时表
使用DELETE语句:只能使用OLD临时表
如果公司里有上百个表要做触发器,如果手动写代码的话。很累,一个小程序,自动生成mysql的触发代码。
?php
$dbname = 'test';//数据库
$tab1 = 'user'; //执行的表
$tab2 = 'user_bak'; //被触发的表
$conn = mysql_connect("localhost","root", "root",$dbname) or
die("请检查你的主机名数据库用户名和密码");
mysql_select_db($dbname, $conn) or die("数据库还没有连接");
$query = mysql_query("SHOW COLUMNS FROM $tab1");mysql_query("");
while($row=mysql_fetch_array($query,MYSQL_NUM)){//得到表的字段数组
$temp[] = $row[0];
$str1 .= '`'.$row[0].'`,';
$str2 .= 'new.'.$row[0].',';
$str3 .= $row[0].'=new.'.$row[0].',';
}
//insert触发器
$inser_str = "h1{$tab1}表的insert触发器/h1";
$inser_str .= "create trigger ".$tab1."_insert brAFTER INSERT
bron ".$tab1."br";
$inser_str .="for each rowbr INSERT INTO {$tab2}
(".rtrim($str1,',').') VALUES ('.rtrim($str2,',').');';
//update触发器
$update_str = "h1{$tab1}表的update触发器/h1";
$update_str .= "create trigger ".$tab1."_updatebr";
$update_str .= "after updatebr";
$update_str .= "on ".$tab1.'br';
$update_str .= "for each rowbr";
$update_str .= "update ".$tab2." set ".rtrim($str3,',')." where id =
new.id;//这里的where id = new.id要手动改一下。改成主键的字段名";
//delete触发器
$delete_str = "h1{$tab1}表的delete触发器/h1";
$delete_str .= "create trigger ".$tab1."_deletebr";
$delete_str .= "after deletebr";
$delete_str .= "on ".$tab1."br";
$delete_str .= "for each row br";
$delete_str .= "delete from ".$tab2." where id=OLD.id//这里的where id =
new.id要手动改一下。改成主键的字段名br";
echo $inser_str;
echo $update_str;
echo $delete_str;
echo
'p注意:br1.触发器可用于InnoDB或MyISAM类型的表br2.插入的时候用AFTER INSERT
更好的保证数据ID的对应,如果用before
INSERT有可能造成ID不对应br3.如new.id则是表示主表中的字段br4.sql语句太多,用
begin..endbr5.使用show triggers语句查看数据库中的触发器。br6.删除触发器DROP TRIGGER
IF EXISTS `test`br7.作者:a
href=""华夏之星/a';
echo EOT
h3语法:/h3
create trigger 触发器名称br
{ before | after}br
{insert | update | delete}br
on 表名br
for each rowbr
触发器SQL语句br
参数详解如下:br
create trigger 触发器名称:创建一个新触发器,并指定触发器的名称。br
{ before | after}:用于指定在insert、update或delete语句执行前触发还是在语句执行后触发。br
on 表名:用于指定响应该触发器的表名。br
for each row:触发器的执行间隔,for each row
通知触发器每隔一行执行一次动作,而不是对整个表执行一次。br
触发器SQL语句:触发器要执行的SQL语句,如果该触发器要执行多条SQL语句,要将多条语句放在begin…end块中。
br如:begin…end块(它不能上phpadmin上运行。因为phpmyadmin没有对begin...end解析。)br
mysql_query("br
create trigger user_deletebr
after deletebr
on userbr
for each row BEGINbr
delete from user_bak where id=OLD.id;br
delete from aaa where id=OLD.id;br
END;");br
brbrbrbr
EOT;
?
需求描述不准确。
你是需要在客户端同时访问几个接口(接口端用的php)?
1.如果是这个需求的话,客户端js自带异步属性,用ajax,同时做几个调用,在回调里处理数据就行了,只是服务器端,如果有session,需要确保耗时操作前写入并关闭session,不然同一个客户端的访问会被session卡住(默认的文件模式的session)
2.还是需要在php代码中同时进行多个接口并发调用,在各自返回时处理,然后整合结果输出 ?
这种的话,php本身不支持异步并发编程,可以考虑用nodejs或者php的扩展 swoole 之类的去做
PHP的定时任务可以使用以下几个函数实现。
ignore_user_abort()
set_time_limit(0)
sleep(60*10)
此代码只要运行一次后关闭浏览器即可。
ignore_user_abort();//关掉浏览器,PHP也会继续执行
set_time_limit(0);// 通过set_time_limit(0)可以让程序无限制的执行
do{
//业务逻辑代码
sleep(60*10);// 等待5分钟后再次运行
}while(true);
如果你有对服务器操作的权限,还是建议用系统的Cron来写比较适合。
对于你后面的问题我最好还是通过直接调你写的接口比较合适,当然我不太明白你说的对方直接把数据入到你的数据库和PHP触发器有什么关系。
你先告诉我你要交换些什么数据嘛
请看这个例子:
几个人要共用一段数据:
Mysql数据表:share
字段:id,value
这样一设计你就可以用ID来获得一段数据
假设id=5 那么你就在每个用户里面都用select * from share where id=5
就可以查询获得这个公共数据了,如果想每个人都更改那么你可以用update share set value=*** where id=5
当然最好不好让每个人都可以delete,否则其它用户可能因查询不到数据而出错。
没有!
请使用事件(onblur或者keyup等)与异步交互处理(ajax)来实现!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流