本文将主要列出MySql与SqlServer不同的地方,且以常用的存储过程的相关内容为主。
1. 标识符限定符
SqlServer []
MySql ``
2. 字符串相加
SqlServer 直接用 +
MySql concat()
3. isnull()
SqlServer isnull()
MySql ifnull()
注意:MySql也有isnull()函数,但意义不一样
4. getdate()
SqlServer getdate()
MySql now()
5. newid()
SqlServer newid()
MySql uuid()
6. @@ROWCOUNT
SqlServer @@ROWCOUNT
MySql row_count()
注意:MySql的这个函数仅对于update, insert, delete有效
7. SCOPE_IDENTITY()
SqlServer SCOPE_IDENTITY()
MySql last_insert_id()
8. if ... else ...
SqlServer IF Boolean_expression
{ sql_statement | statement_block }
[ ELSE
{ sql_statement | statement_block } ]
-- 若要定义语句块,请使用控制流关键字 BEGIN 和 END。
MySql IF search_condition THEN statement_list
[ELSEIF search_condition THEN statement_list] ...
[ELSE statement_list]
END IF
注意:对于MySql来说,then, end if是必须的。类似的还有其它的流程控制语句,这里就不一一列出。
9. declare
其实,SqlServer和MySql都有这个语句,用于定义变量,但差别在于:在MySql中,DECLARE仅被用在BEGIN ... END复合语句里,并且必须在复合语句的开头,在任何其它语句之前。这个要求在写游标时,会感觉很BT.
10. 游标的写法
SqlServer declare @tempShoppingCart table (ProductId int, Quantity int)
insert into @tempShoppingCart (ProductId, Quantity)
select ProductId, Quantity from ShoppingCart where UserGuid = @UserGuid
declare @productId int
declare @quantity int
declare tempCartCursor cursor for
select ProductId, Quantity from @tempShoppingCart
open tempCartCursor
fetch next from tempCartCursor into @productId, @quantity
while @@FETCH_STATUS = 0
begin
update Product set SellCount = SellCount + @quantity where productId = @productId
fetch next from tempCartCursor into @productId, @quantity
end
close tempCartCursor
deallocate tempCartCursor
MySql declare m_done int default 0;
declare m_sectionId int;
declare m_newsId int;
declare _cursor_SN cursor for select sectionid, newsid from _temp_SN;
declare continue handler for not found set m_done = 1;
create temporary table _temp_SN select sectionid, newsid from SectionNews group by sectionid, newsid having count(*) > 1;
open _cursor_SN;
while( m_done = 0 ) do
fetch _cursor_SN into m_sectionId, m_newsId;
if( m_done = 0 ) then
-- 具体的处理逻辑
end if;
end while;
close _cursor_SN;
drop table _temp_SN;
注意:为了提高性能,通常在表变量上打开游标,不要直接在数据表上打开游标。
11. 分页的处理
SqlServer create procedure GetProductByCategoryId(
@CategoryID int,
@PageIndex int = 0,
@PageSize int = 20,
@TotalRecords int output
)
as
begin
declare @ResultTable table
(
RowIndex int,
ProductID int,
ProductName nvarchar(50),
CategoryID int,
Unit nvarchar(10),
UnitPrice money,
Quantity int
);
insert into @ResultTable
select row_number() over (order by ProductID asc) as RowIndex,
p.ProductID, p.ProductName, p.CategoryID, p.Unit, p.UnitPrice, p.Quantity
from Products as p
where CategoryID = @CategoryID;
select @TotalRecords = count(*) from @ResultTable;
select *
from @ResultTable
where RowIndex > (@PageSize * @PageIndex) and RowIndex <= (@PageSize * (@PageIndex+1));
end;
当然,SqlServer中并不只有这一种写法,只是这种写法是比较常见而已。
MySql create procedure GetProductsByCategoryId(
in _categoryId int,
in _pageIndex int,
in _pageSize int,
out _totalRecCount int
)
begin
set @categoryId = _categoryId;
set @startRow = _pageIndex * _pageSize;
set @pageSize = _pageSize;
prepare PageSql from 'select sql_calc_found_rows * from product where categoryId = ? order by ProductId desc limit ?, ?';
execute PageSql using @categoryId, @startRow, @pageSize;
deallocate prepare PageSql;
set _totalRecCount = found_rows();
end
MySql与SqlServer的差别实在太多,以上只是列出了本人认为经常在写存储过程中会遇到的一些具体的差别之处。
分享到:
相关推荐
通过这样的设计,项目可以同时连接和操作MySQL与SQLServer,提供了一种灵活且高效的多数据库支持方案,尤其适合需要跨数据库系统协同工作的复杂系统。在实际部署时,还需要考虑数据同步、事务一致性等问题,确保整个...
这些只是 MySQL 和 SQL Server 在存储过程和常用用法上的一些基本差异。在实际应用中,开发者需要根据具体数据库系统的特点来编写相应的查询和存储过程。了解这些差异对于跨平台的软件开发至关重要,能够帮助开发者...
MySQL和SQLServer都是广泛使用的数据库管理系统。MySQL以其开源、高性能、易用性受到许多开发者的青睐,适合中小型应用。而SQLServer则由微软公司提供,具有强大的企业级特性,适用于大型企业应用。在本项目中,两个...
千万级数据Sql Server 与Mysql分析 在本文中,我们将对千万级数据下的Sql Server 2008与Mysql 5.5进行对比分析。本文将从研究背景、测试分析和结论三个方面进行讨论。 研究背景 在我们的热量表系统中,用户的现场...
### Java连接SQL Server与MySQL的方法 #### 一、概述 在Java开发中,与数据库进行交互是一项非常重要的技能。无论是企业级应用还是个人项目,掌握如何有效地与数据库沟通是必不可少的。本文将详细介绍如何使用Java...
String url = "jdbc:sqlserver://localhost:1433;databaseName=myDatabase"; String username = "myUsername"; String password = "myPassword"; try { Class.forName(...
本文将详细介绍Java中针对SQLServer、MySQL和Oracle这三种常见数据库的驱动及其使用方法。 首先,我们来了解一下**SQLServer驱动**。在Java中,微软的SQLServer数据库通常通过`sqljdbc42.jar`驱动进行连接。这个...
《SQLserver、Oracle、Mysql语法与用法对比》 SQLserver、Oracle和Mysql是当前最主流的三种关系型数据库管理系统,它们在语法和用法上存在一些共性,但也各自具有特色。以下是对这三种数据库在常用操作上的对比分析...
本压缩包包含Oracle、MySQL和SQL Server这三种常用数据库的驱动jar包,它们分别是用于连接Oracle数据库的ojdbc.jar,连接MySQL数据库的mysql-connector.jar,以及连接SQL Server数据库的mssql-jdbc.jar。 首先,...
`sqlserver`和`mysql`这两个文件名可能分别对应着SQL Server和MySQL数据库的相关配置或使用指南,同样值得参考。 总之,理解和掌握MySQL与SQL Server的JDBC连接方法是Java开发者必备的技能之一,这有助于实现高效、...
6. **性能优化**:在SQL Server中,使用`ROW_NUMBER()`配合`OVER()`函数进行分页可能更高效,而在MySQL中,`LIMIT`和`OFFSET`是常用方法,但`OFFSET`过大可能导致性能下降,此时可以考虑使用子查询或联合查询优化。...
本压缩包集合包含了几个常用数据库的JDBC驱动jar文件,包括MySQL、Oracle、SQL Server和Access,这些都是开发人员进行数据库操作的必备组件。 1. **MySQL**:MySQL是一款开源、免费的关系型数据库管理系统,广泛...
在IT领域,Oracle、MySQL和SQL Server是三种广泛使用的数据库管理系统,每一种都有其特定的数据库驱动。 Oracle驱动,通常指的是Oracle JDBC驱动,Java Database Connectivity(JDBC)是Java语言中用来规范客户端...
2. **建立连接**:使用`DriverManager.getConnection()`,参数包括数据库URL(格式为`jdbc:microsoft:sqlserver://<服务器地址>:<端口号>;databaseName=<数据库名>`)、用户名和密码。 3. 创建Statement或...
JDBC(Java Database Connectivity)是与MySQL交互的常用方式。MySQL的JDBC驱动分为几个版本,如mysql-connector-java.jar,它实现了Java的Driver接口,使得Java程序能够通过`java.sql.DriverManager`类建立与MySQL...
为了实现 Java 应用程序与 MySQL 数据库之间的通信,我们需要使用 JDBC(Java Database Connectivity)驱动。对于 MySQL 数据库,最常用的驱动是 `mysql-connector-java`。 **步骤一:添加 MySQL 驱动** 下载 ...
除了上述关于多表查询的内容之外,还可以进一步了解SQL的基本查询结构,如`SELECT`、`FROM`、`WHERE`、`ORDER BY`等子句的使用方法,以及一些基本的数据处理函数。 - **基础查询语句:** ```sql SELECT FIRST_...
SQL Server中分页可以通过多种方式实现,其中一种常用的方法是使用`TOP`关键字结合子查询。此外,还可以使用`OFFSET`和`FETCH`关键字来实现更简单的分页查询。 #### 使用TOP关键字: 1. **第一步**:创建一个子...
在C++编程中,ADO(ActiveX Data Objects)是一种常用的数据访问接口,它允许程序员连接到各种数据库系统,包括MySQL、SQL Server、Access和Oracle。本文将深入探讨如何使用C++封装ADO技术来实现对这些数据库的操作...