基于mysql事务、视图、存储过程、触发器的应用分析
一 ,mysql事务
MYSQL中只有INNODB类型的数据表才能支持事务处理。
启动事务有两种方法
(1) 用begin,rollback,commit来实现
代码如下:
begin 开始一个事务
rollback 事务回滚
commit 事务确认
(2)直接用set来改变mysql的自动提交模式
代码如下:
set autocommit=0 禁止自动提交
set autocommit=1 开启自动提交
header("Content-type:text/html;charset=utf-8");
mysql_pconnect("localhost","root","") or die("数据库连接失败");
mysql_select_db("test");
mysql_query("set names utf8");
//开启一个事务
//mysql_query("BEGIN");
//mysql_query("START TRANSACTION");
//mysql_query("SET AUTOCOMMIT=1");//设置事务不自动提交 mysql默认是自动提交
mysql_query("SET AUTOCOMMIT=1");//开启事务
$sql1 = "INSERT INTO `test`values ('2222','测试数据')";
$sql2 = "INSERT INTO `test` values ('111','sss','22')";//特地写的错误
$res1 = mysql_query($sql1);
$res2 = mysql_query($sql2);
if($res1 && $res2)
{
mysql_query("COMMIT");
echo "事务提交";
}else{
mysql_query("ROLLBACK");
echo "事务回滚";
}
mysql_query("END");
相关推荐
-
MySQL 视图 第1349号错误解决方法
复制代码 代码如下: CREATE OR REPLACE VIEW BLOG_V_ADMIN (ID,NICKNAME,SEX,EMAIL,PHONE,QQ,MSN,HTTP,REGISTER_TIME, IP,LAST_LOGIN_IP,LOGIN_TIME) AS SELECT A.ID,A.NICKNAME,A.SEX,A.EMAIL,A.PHONE,A.QQ,A.MSN,A.HTTP,A.REGISTER_TIME, B.IP AS LAST_LOGIN_IP,B.LOG
-
MySQL入门教程(七)之视图
相关阅读: MySQL入门教程(五)之表的创建.修改和删除 视图是从一个或多个表中导出来的虚拟表.视图就像一个窗口,通过这个窗口可以看到系统专门提供的数据. 1.视图简介 1.1 视图的含义 视图是从一个或多个表中导出来的虚拟表,还可以从已经存在的视图的基础上定义. 数据库中只存放视图的定义,而不存放视图中的数据,这些数据仍存放在原来的表中.一旦表中的数据发生变化,显示在视图中的数据也会相应变化. MySQL的视图并不支持输入参数的功能,即交互性上较差,但对于变化不是很大的操作,使用视图可以很大
-
存储过程解密(破解函数,过程,触发器,视图.仅限于SQLSERVER2000)
复制代码 代码如下: create PROCEDURE sp_decrypt(@objectName varchar(50)) AS begin begin tran declare @objectname1 varchar(100),@orgvarbin varbinary(8000) declare @sql1 nvarchar(4000),@sql2 nvarchar(4000),@sql3 nvarchar(4000),@sql4 nvarchar(4000),@sql5 nvarcha
-
sql 刷新视图
比如我们创建了一个表T1和一个T1的视图V1,然后更改T1,再看V1的结果: 首先创建表T1: 复制代码 代码如下: IF OBJECT_ID('T1') IS NOT NULL DROP TABLE T1 CREATE TABLE T1(col1 INT,col2 INT) INSERT INTO T1(col1,col2) VALUES(1,2) GO 然后创建T1的视图V1: 复制代码 代码如下: CREATE VIEW V1 AS SELECT * FROM T1 在现实实践中,要避免在
-
SQL SERVER先判断视图是否存在然后再创建视图的语句
如果我们的语句为: IF NOT EXISTS(SELECT 1 FROM sys.views WHERE name='Report_IndividualTicket') BEGIN create view Report_IndividualTicket as SELECT Ticket.TicketNumber, Ticket.TicketID, GisProcess.StageName, Content.DtReceived, Content.ContentText FROM (GisPro
-
MySQL笔记之视图的使用详解
什么是视图 视图是从一个或多个表中导出来的表,是一种虚拟存在的表. 视图就像一个窗口,通过这个窗口可以看到系统专门提供的数据. 这样,用户可以不用看到整个数据库中的数据,而之关心对自己有用的数据. 数据库中只存放了视图的定义,而没有存放视图中的数据,这些数据存放在原来的表中. 使用视图查询数据时,数据库系统会从原来的表中取出对应的数据. 视图中的数据依赖于原来表中的数据,一旦表中数据发生改变,显示在视图中的数据也会发生改变. 视图的作用 1.使操作简单化,可以对经常使用的查询定义一个视图,使用户
-
mysql触发器实现oracle物化视图示例代码
oracle数据库支持物化视图--不是基于基表的虚表,而是根据表实际存在的实表,即物化视图的数据存储在非易失的存储设备上. 下面实验创建ON COMMIT 的FAST刷新模式,在mysql中用触发器实现insert , update , delete 刷新操作 1.基础表创建,Orders 表为基表,Order_mv为物化视图表 复制代码 代码如下: mysql> create table Orders( -> order_id int not null auto_increment, -&g
-
MySQL 视图的基础操作(五)
1.为什么使用视图: 为了提高复杂SQL语句的复用性和表操作的安全性(例如:工资字段不想展示给所有能查看该查询结果的人),MySQL提供了视图特性.所谓视图,本质上是一种虚拟表,其内容与真实的表相似,包含一系列带有名称的列和行数据.但是,视图并不在数据库中以存储数据值的形式存在.行和列的数据来自定义视图的查询所引用基本表,并且在具体使用视图时动态生成. 视图有如下特点; 1. 视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系. 2. 视图是由基本表
-
MySQL中视图的使用及多表INNER JOIN的技巧分享
创建视图 Sql代码 CREATE VIEW view_name AS SELECT t1.xxx, t2.xxx, t3.xxx FROM (table1 t1 INNER JOIN table2 t2 ON t1.fid = t2.fid) INNER JOIN table3 t3 ON t1.mid = t3.mid; 这里使用了3表关联,对于多表关联的 INNER JOIN 写法有一个技巧 1. 先写最简单的2表关联 INNER JOIN 2. 然后使用 () 从 FROM 之后到语
-
sql server判断数据库、表、列、视图是否存在
1 判断数据库是否存在 if exists (select * from sys.databases where name = '数据库名') drop database [数据库名] 2 判断表是否存在 if exists (select * from sysobjects where id = object_id(N'[表名]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) drop table [表名] 3 判断存储过程是否存在 if exist
随机推荐
- jqgrid实现简单的单行编辑功能
- cmd批量打开网页和关闭网页的批处理代码
- 零基础学习AJAX之制作自动校验的表单
- 微信网页授权(OAuth2.0) PHP 源码简单实现
- 详解php实现页面静态化原理
- 在VB.NET应用中使用MySQL的方法
- 15个非常实用的JavaScript代码片段
- C调用lua函数需要考虑的问题
- C++ 简单实现MFC ListControl 点击列头排序
- 在B/S开发中经常用到的JavaScript技术第1/3页
- 使用FORFILES命令来删除SQLServer备份的批处理
- JQuery复制DOM节点的方法
- java,android,MD5加密算法的实现代码(16位,32位)
- Android 单线程模型详解及实例
- 浅谈关于Android WebView上传文件的解决方案
- 在ASP.NET 2.0中操作数据之四十一:DataList和Repeater数据分页
- PHP变量的定义、可变变量、变量引用、销毁方法
- Android快速开发之定制BaseTemplate
- Android自定义ViewGroup打造各种风格的SlidingMenu
- JavaScript实现多叉树的递归遍历和非递归遍历算法操作示例