SQL Server异常代码处理的深入讲解_MsSql

来源:脚本之家  责任编辑:小易  

mssql是sqlserver 的简称2113。这个是微软的重5261型数据库。你是不是想问mysql哦、这个是轻量级4102数据库,瑞典的1653AB公司开发2008年被SUN公司收购。而2009 年SUN又被甲骨文(Oracle)收购。Oracle是属于重型数据库。大型数据库的好处是:存储量大且查询速度快。轻量级的好处是方便占资源小,可以节省网站成本,一般企业宣传网站这类需要动态页面但是数据量小的就可以使用轻量级数据库,全称 Microsoft SQL Server一般简称 MS-SQL 或SQL Server微软公司的数据库产品,mssql就是sqlserver,都是微软旗下的产品追问软件都是一样的吗?用法都是一样吗?追答MS SQL是指微软的SQL Server数据库服务器,它是一个数据库平台,提供数据库的从服务器到终端的完整的解决方案,其中数据库服务器部分,是一个数据库管理系统,用于建立、使用和维护数据库。SQL Server一开始并不是微软自己研发的产品,而是当时为了要和IBM竞争时,与Sybase合作所产生的,其最早的发展者是Sybase,同时微软也和Sybase合作过 SQL Server 4.2版本的研发,微软亦将SQL Server 4.2移植到Windows NT(当时为3.1版),在与Sybase终止合作关系后,自力开发出SQL Server 6.0版,往后的SQL Server即均由微软自行研发。其实这两个是指同一个产品你说的mssql是不是mysql?是否打错字?如果是mysql那就是另外一种数据库了,学习下,sql2000和mssql一回事吧,可能叫法不同,都是microsoft的。。mysql是别一套数据库管理软件,常与php,liunx共用。别人说mysql速度快。ms的可能是功能全,用户多www.zgxue.com防采集请勿采集本网。

前言

SQL Server使用TRY...CATCH 结构实现TSQL语句的错误处理,TRY命令负责监控语句执行的情况,如果有TSQL语句发生异常,并且严重级别(Severity Level)大于10,并且小于20,那么CATCH命令会捕获到异常的错误。

SQLEXPRESS 和SQL Server(MSSQLSERVER)吧 是两个服务 都启动就ok ms是microsoft的缩写 微软

BEGIN TRY { sql_statement | statement_block } END TRY BEGIN CATCH [ { sql_statement | statement_block } ] END CATCH

直接到Sql2005安装位置可以找到你的数据库文件,可以直接拷贝备份

数据库开发工程师需要把一条或多条语句写入到TRY代码块中,如果TRY代码块中的代码在执行过程中发生错误,那么在错误发生的点之后的代码不再执行,程序的控制权转移到CATCH代码块块中。如果TRY代码块没有发生错误,那么不会执行CATCH代码块,程序的控制权转移到END CATCH之后的语句。

SQL SERVER的启动帐户有问题。很可能启动帐户是windows帐户,而windows帐户的密码修改过。解决方法是运行services.msc打开服务管理器,找到sqlserver服务(mssql开头的服务)双击,之后选择“登录”选项卡,把登录身份改成“本地系统帐户”或者修改正

注意,在CATCH代码块中捕获的异常不会返回给调用程序,如果需要把错误消息返回给调用程序,需要在CATCH代码块中使用THROW(或RAISERROR,不推荐使用)命令显式抛出错误。

1、查询SQL中的所有表: Select TABLE_NAME FROM 数据库名称.INFORMATION_SCHEMA.TABLES Where TABLE_TYPE='BASE TABLE' 执行之后,就可以看到数据库中所有属于自己建的表的名称 2、查询SQL中所有表及列: Select dbo.sysobjects.name as Table_

一,获取异常消息

mssql=sqlserver,都是Microsoft® SQL Server™,只是不同的简称。 mysql,是由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。 两者的区别是MSSQL是企业级数据库,mysql是轻量级数据库(当然也可以作为企业级数据库,但需要购买

在TSQL中,使用TRY和 CATCH编写异常处理代码块,在CATCH子句中,使用以下函数,能够获取异常发生时的信息。

--返回发生错误的代码行号(LineNumber)ERROR_LINE ( ) --返回错误号(ErrorNumber)ERROR_NUMBER ( ) @@ERROR --返回错误消息(ErrorMessage)ERROR_MESSAGE ( ) --返回发生错误的SP NameERROR_PROCEDURE ( ) --返回错误的严重度(Error Severity)ERROR_SEVERITY ( ) --返回错误的状态(Error State)ERROR_STATE()

SQL Server抛出的一个错误,通常包括错误代码(Error Number)、严重级别(Severity Level)、错误状态(Error State)和错误消息(Error Message)等信息。

1,错误代码

错误代码,可以由变量@@ERROR 和函数ERROR_NUMBER()获得,用于返回上一条语句的错误代码,该代码唯一标识该错误。

2,错误的严重级别

错误的严重程序(Severity Level)共有24个级别,表明SQL Sever遇到问题的类型,Severity Level是一个int类型,可以由函数ERROR_SEVERITY() 返回,数值越大,说明问题越严重。

按照错误对系统的影响程序,把严重级别分为四组: 0-10:信息,可以认为是warning 11-16:错误,是用户代码导致的 17-19:非常严重的错误,只能由系统管理员来修复 20-24:致命的错误,可能导致整个系统无法正常使用

从17-19,错误不能被用户修正,只能由系统管理员来修复问题。

从20-24,这个级别的错误遇到的情况比较少,一旦遇到,那么基本上表明整个数据库系统遇到了非常严重的错误:

3,错误状态

错误状态(Error State)是用户自定义的编码,用于使开发者能够轻易识别引起异常的确切位置。

4,错误消息

错误消息,是关于错误的描述性文本,可以是SQL Server系统预定义的错误信息,也可以是THROW命令抛出的用户自定义的文本。

二,抛出异常消息

在SQL Server 2012及之后的版本中,使用 Throw 关键字代替RAISERROR,用于抛出异常,并将执行控制权转移到Catch 代码块。

THROW [error_number, error_message, error_state];

参数注释: error_number:错误代码,是一个int类型,数值必须大于5000,小于 2147483647,这是用户自定义的错误代码。 error_message:错误消息,类型是nvarchar(2048) state:跟错误相关联的一个state,类型是tinyint,取值范围是:0-255

注意:在THROW语句之前的语句,必须以分号; 结尾。

当THROW语句用于抛出自定义的异常时,severty level 常常被设置为默认的16;当THROW用于re-throw,此时THROW 没有任何参数,处于CATCH代码块中,仅仅用于把CATCH捕获的异常重新抛出,severty level,state,错误消息跟原始异常相同。

例子1,抛出自定义的异常:

BEGIN TRY SELECT 1/0END TRY BEGIN CATCH ;THROW 51000, 'Divide by zero error encountered', 1; END CATCH;

SQL Server抛出的异常消息是,自定义的错误代码是51000,严重级别(Severity Level)是16,错误状态是1,错误行是5:

Msg 51000, Level 16, State 1, Line 5

Divide by zero error encountered

例子2,重抛异常,把系统检测到的错误从Catch代码块中抛出:

BEGIN TRY SELECT 1/0END TRY BEGIN CATCH ;THROW; END CATCH;

SQL Server抛出的异常消息是,错误代码是8134,严重级别(Severity Level)是16,错误状态是1,错误行是2:

Msg 8134, Level 16, State 1, Line 2

Divide by zero error encountered.

三,不受TRY...CATCH结构影响的错误

TRY...CATCH 只捕获严重级别从11到19的错误,不会捕获严重级别是1-10,20-24的错误。

如果session会系统管理员使用KILL命令杀掉,那么TRY...CATCH结构不会捕获。

四,在事务中处理异常

如果在TRY代码块生成的错误,导致当前事务的状态变成无效,那么该事务就是不可提交的事务(uncommittable transaction)。一个不可提交的事务,只能执行read操作,或者回滚(ROLLBACK TRANSACTION),不能执行TSQL语句来执行写操作,该事务也不能提交。函数XACT_STATE() 返回-1表示,当前的事务是不可提交的事务;返回1表示当前的事务是可以提交的。数据库开发人员需要通过XACT_STATE() 来对事务执行提交或回滚的操作。

例如,在事务中处理异常,可以参考以下代码,在实际应用程序,可以把异常信息记录在数据表中,便于进行故障排除:

-- SET XACT_ABORT ON will render the transaction uncommittable when the constraint violation occurs.SET XACT_ABORT ON; BEGIN TRY BEGIN TRANSACTION; -- A FOREIGN KEY constraint exists on this table. This statement will generate a constraint violation error. DELETE FROM Production.Product WHERE ProductID = 980; -- If the delete operation succeeds, commit the transaction. The CATCH block will not execute. COMMIT TRANSACTION; END TRY BEGIN CATCH -- Test XACT_STATE for 0, 1, or -1. -- If 1, the transaction is committable. -- If -1, the transaction is uncommittable and should be rolled back. -- XACT_STATE = 0 means there is no transaction and a commit or rollback operation would generate an error. -- Test whether the transaction is uncommittable. IF (XACT_STATE()) = -1 BEGIN --Logging Exception info, as the transaction is in an uncommittable state. Rolling back transaction. SELECT ERROR_NUMBER() AS ErrorNumber, ERROR_SEVERITY() AS ErrorSeverity, ERROR_STATE() AS ErrorState, ERROR_PROCEDURE() AS ErrorProcedure, ERROR_LINE() AS ErrorLine, ERROR_MESSAGE() AS ErrorMessage; ROLLBACK TRANSACTION; END; -- Test whether the transaction is active and valid. IF (XACT_STATE()) = 1 BEGIN --'The transaction is committable. Committing transaction.' COMMIT TRANSACTION; END; END CATCH;

总结

到此这篇关于SQL Server异常代码处理的文章就介绍到这了,更多相关SQLServer异常代码处理内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!

Call to undefined function mssql_connect() :这是因为没有开2113启mssql模块。1、在php.ini中找到:5261 extension=php_mssql.dll,和extension=php_pdo_mssql.dll,确定他们的前4102面没有“;”。2、在php.ini中找到:extension_dir = "C:\php\ext\"。这里是1653extension目录,确认这个目录下有php_mssql.dll、php_pdo_mssql.dll。(php.ini的位置,extension_dir的位置可以使用phpinfo()查看。)4、检查你的Mssql服务器有没有开起来。呵呵一般这个可能性不大,下载驱动程2113序,下载后安装释放程序,里5261面有以下文件:php_pdo_sqlsrv_52_nts.dllphp_pdo_sqlsrv_52_ts.dllphp_pdo_sqlsrv_53_nts_vc6.dllphp_pdo_sqlsrv_53_nts_vc9.dllphp_pdo_sqlsrv_53_ts_vc6.dllphp_pdo_sqlsrv_53_ts_vc9.dllphp_sqlsrv_52_nts.dllphp_sqlsrv_52_ts.dllphp_sqlsrv_53_nts_vc6.dllphp_sqlsrv_53_nts_vc9.dllphp_sqlsrv_53_ts_vc6.dllphp_sqlsrv_53_ts_vc9.dllSQLServerDriverForPHP.chm(手册,英4102文够好的话,可以看看,嘿嘿1653)SQLServerDriverForPHP_License.rtfSQLServerDriverForPHP_Readme.htm(自述文件)?关于VC6和VC9的区别VC6 版本是使用 Visual Studio 6 编译器编译的,如果你是在windows下使用Apache+PHP的,请选择VC6版本。VC9 版本是使用 Visual Studio 2008 编译器编译的,如果你是在windows下使用IIS+PHP的,请选择VC9版本。?开始配置选择php_sqlsrv_53_ts.dll和php_pdo_sqlsrv_53_ts.dll。把文件拷贝到PHP文件夹下的ext目录下,然后在配置文件php.ini 的Extensions后面加上:extension=php_sqlsrv_53_ts.dllextension=php_pdo_sqlsrv_53_ts.dll再重启Apache服务。最后测试一下是否成功,在PHP中执行phpinfo()的查看sqlsrv、看图画红线处、如图所示这样就表示连接成功了!!?1.Windows Authentication连接<?php$serverName = "(localhost)";$connectionInfo = array("Database"=>"test","ConnectionPooling"=>false);$conn = sqlsrv_connect( $serverName, $connectionInfo);if( $conn == false){echo "连接失败!";die( print_r( sqlsrv_errors(), true));}?>?2.SQL Server Authentication连接?<?php$serverName = "localhost"; //数据库服务器地址$uid = "sa"; //数据库用户名$pwd = "123"; //数据库密码$connectionInfo = array("UID"=>$uid, "PWD"=>$pwd, "Database"=>"cart");$conn = sqlsrv_connect( $serverName, $connectionInfo);if( $conn == false){echo "连接失败!";die( print_r( sqlsrv_errors(), true));}//执行有结果集的SQL语句$query = sqlsrv_query($conn, "select * from tb_goods");while($row = sqlsrv_fetch_array($query)){ echo $row[0]."-----".$row[1]."<br/>";}//执行增删改的SQL语句?$rs=sqlsrv_query($conn,"update tb_goods set name='中国劲酒' where name='劲酒'");?$num=sqlsrv_rows_affected($rs);//返回修改的行数?if($num>0) { echo '修改成功!'.$num?;} else { echo '修改失败!'; }?>?用于 SQL Server Driver for PHP 的 API 名称是 sqlsrv。所有 sqlsrv函数都以 sqlsrv_打头,SQL Server Driver for PHP 包含以下函数:函数 说明 sqlsrv_begin_transaction 开始事务。 sqlsrv_cancel 取消语句;并放弃相应语句的所有未决结果。 sqlsrv_client_info 提供有关客户端的信息。 sqlsrv_close 关闭连接。释放与相应连接关联的所有资源。 sqlsrv_commit 提交事务。 sqlsrv_configure 更改错误处理和日志记录配置。 sqlsrv_connect 创建一个连接,并将其打开。 sqlsrv_errors 返回关于上一操作的错误和/或警告信息。 sqlsrv_execute 执行预定义语句。 sqlsrv_fetch 使下一行的数据可供读取。 sqlsrv_fetch_array 以数值索引数组、关联数组或这两种数组的形式检索下一行的数据。 sqlsrv_fetch_object 以对象形式检索下一行的数据。 sqlsrv_field_metadata 返回字段元数据。 sqlsrv_free_stmt 关闭语句。释放与相应语句关联的所有资源。 sqlsrv_get_config 返回指定配置设置的值。 sqlsrv_get_field 按索引检索当前行中的字段。可以指定 PHP 返回类型。 sqlsrv_has_rows 检测结果集是否具有一行或多行。 sqlsrv_next_result 使下一结果可供处理。 sqlsrv_num_rows 报告结果集中的行数。 sqlsrv_num_fields 检索活动结果集中的字段数。 sqlsrv_prepare 准备 Transact-SQL 查询,但不执行该查询。隐式绑定参数。 sqlsrv_query 准备 Transact-SQL 查询,并将其执行。 sqlsrv_rollback 回滚事务。 sqlsrv_rows_affected 返回有所修改的行的数目。 sqlsrv_send_stream_data 在每次调用函数时向服务器发送最多八千字节 (8 KB) 的数据。 sqlsrv_server_info 提供有关服务器的信息。Linux下PHP 5.2.17测试成功tar zxvf freetds-0.8.2.tar.gzcd freetds-0.8.2/./configure --enable-msdblib --prefix=/usr/local/freetds --with-tdsver=8.0make && make installcd /home/lnmp0.9/php-5.2.17/ext/mssql/ 依个人可能不同/usr/local/php/bin/phpize ####php扩展信息./configure --with-php-config=/usr/local/php/bin/php-config --with-mssql=/usr/local/freetdsmake && make installvim /usr/local/php/etc/php.ini在extension = "pdo_mysql.so"下面添加extension = "mssql.so"保存后,/root/lnmp restart 即可若搜索的结果有中文乱码则vim /usr/local/freetds/etc/freetds.conf[global] 加上client charset = utf8$sql=mssql_connect('192.168.0.185','sa','1','1433'); mssql_select_db('test',$sql); $result=mssql_query("select top 10 * from test1") while($row=mssql_fetch_assoc($result)){ print_r($rows); } freetds-0.8.2.tar.gz下载地址:免费下载地址在 http://linux.linuxidc.com/用户名与密码都是www.linuxidc.com,看看那个extension目录下有没有php_mssql.dll ?,apachejames-2.3.2中如何配置sqlserver2008内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • sql server出现system.outofmemoryexception异常的解决方法
  • 解决sql server数据库备份时出现“操作系统错误5(拒绝访问)。backup database 正在异常终止。”错误的解决办法
  • sql server自定义异常raiserror使用示例
  • sqlserver 连接异常与解决方法小结
  • sqlserver2000 企业版 出现"进程51发生了严重的异常"错误的处理方法
  • sql server 2005 中使用 try catch 处理异常
  • sqlserver异常处理常用步骤
  • 解决sql server虚拟内存不足情况
  • sql server出现system.outofmemoryexception异常的解决方法
  • sql分组后二次汇总(处理表重复记录查询和删除)的实现方法
  • sql_server全文索引的使用实例演示
  • 如何查看sqlserver中某个查询用了多少tempdb空间
  • sql server误区30日谈 第8天 有关对索引进行在线操作的误区
  • mssql数据库系统崩溃后的一般处理步骤与方法
  • table 行转列的sql详解
  • supersocket 信息: (spnregister) : error 1355。解决方法
  • sql agent服务无法启动的解决方法
  • 怎么配置apache连接sqlserver
  • mssql和sqlserver是什么关系?
  • 启动sqlserver(mssqlserver)时提示请求失败或服务...
  • PHP连接SQLserver2000数据库
  • SQLSERVER 和MSSQLSERVER有什么区别
  • 启动SQL2005服务SqlServer(MSSQLSERVER)报错!
  • Sqlserver 2012 MSSQLSERVER怎么都起不来了
  • sqlserver快照复制报错,错误号:mssql_repl20052
  • mssql,mysql,sqlserver三者有何不同
  • mssql是什么,于sqlserver的区别是什么
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页sql server出现system.outofmemoryexception异常的解决方法解决sql server数据库备份时出现“操作系统错误5(拒绝访问)。backup database 正在异常终止。”错误的解决办法sql server自定义异常raiserror使用示例sqlserver 连接异常与解决方法小结sqlserver2000 企业版 出现"进程51发生了严重的异常"错误的处理方法sql server 2005 中使用 try catch 处理异常sqlserver异常处理常用步骤解决sql server虚拟内存不足情况sql server出现system.outofmemoryexception异常的解决方法sql分组后二次汇总(处理表重复记录查询和删除)的实现方法sql_server全文索引的使用实例演示如何查看sqlserver中某个查询用了多少tempdb空间sql server误区30日谈 第8天 有关对索引进行在线操作的误区mssql数据库系统崩溃后的一般处理步骤与方法table 行转列的sql详解supersocket 信息: (spnregister) : error 1355。解决方法sql agent服务无法启动的解决方法sql server 2012 安装图解教程(附sql server数据库入门学习总结microsoft sql server 2012 数据sql重复记录查询的几种方法win7系统安装sqlserver2000的详细sqlserver中distinct的用法(不重sql server错误代码大全及解释(sql-order by 多字段排序(升序、sql将一个表中的数据插入到另一个用sql语句添加删除修改字段、一些sql语句执行超时引发网站首页访问故障问题sql server2012 使用ip地址登录服务器的配介绍备份和还原mysql数据的两种方法sqlserver 三种分页方式性能比较[图文]sql server视图的讲解sql server编写通用脚本实现获取一年前日sql 判断字符串中是否包含数字和字母的方sql存储过程几个简单例子sql中 order by 和 group by的区别数据库sql中having和where的用法区别
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved