十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
一、多数指令是相同的,包括创建和修正存储过程的指令。
在海珠等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都做网站、网站建设 网站设计制作定制设计,公司网站建设,企业网站建设,成都品牌网站建设,成都全网营销,外贸网站制作,海珠网站建设费用合理。
二、很多细微的指令有不同,具体如下(不仅):
1 mysql支持enum,和set类型,sql server不支持
2 mysql不支持nchar,nvarchar,ntext类型
3 mysql的递增语句是AUTO_INCREMENT,而mssql是identity(1,1)
MYSQL:create table basic(id int key auto_increment,name varchar(20));
MSSQL: create table basic(id int identity(1,1) , name varchar(20))
4 msms默认到处表创建语句的默认值表示是((0)),而在mysql里面是不允许带两括号的
5 mysql需要为表指定存储类型
6 mssql识别符是[],[type]表示他区别于关键字(可选用来包含表名、字段名),但是mysql却是 `(重音符,也就是按键1左边的那个符号)
7 mssql支持getdate()方法获取当前时间日期,但是mysql里面可以分日期类型和时间类型,获取当前日期是cur_date(),当前完整时间是 now()函数
8 mssql不支持replace into 语句,但是在最新的sql20008里面,也支持merge语法
9 mysql支持insert into table1 set t1 = ‘’, t2 = ‘’ ,但是mssql不支持这样写
10 mysql插入多行支持这样写 insert into tabl1 values (1,1), (1,1), (1,1), (1,1), (1,1), (1,1), (1,1) MSSQL不支持
11 mssql不支持limit语句,是非常遗憾的,只能用top 取代limt 0,N,row_number() over()函数取代limit N,M
12 mysql在创建表时要为每个表指定一个存储引擎类型,而mssql只支持一种存储引擎
13 mysql不支持默认值为当前时间的datetime类型(mssql很容易做到),在mysql里面是用timestamp类型
14 mssql里面检查是否有这个表再删除,需要这样:
if
exists (select * from dbo.sysobjects where id =
object_id(N'uc_newpm') and OBJECTPROPERTY(id, N'IsUserTable')
= 1)
但是在mysql里面只需要 DROP TABLE IF EXISTS cdb_forums;
15 mysql支持无符号型的整数,那么比不支持无符号型的mssql就能多出一倍的最大数存储
16 mysql不支持在mssql里面使用非常方便的varchar(max)类型,这个类型在mssql里面既可做一般数据存储,也可以做blob数据存储
17
mysql创建非聚集索引只需要在创建表的时候指定为key就行,比如:KEY displayorder (fid,displayorder)
在mssql里面必须要:create unique nonclustered index
index_uc_protectedmembers_username_appid on dbo.uc_protectedmembers
(username asc,appid asc)
18 mysql text字段类型不允许有默认值
19mysql的一个表的总共字段长度不超过65XXX。
20一个很表面的区别就是mysql的安装特别简单,而且文件大小才110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是.....
21mysql的管理工具有几个比较好的,mysql_front,和官方那个套件,不过都没有SSMS的使用方便,这是mysql很大的一个缺点。
22mysql的存储过程只是出现在最新的版本中,稳定性和性能可能不如mssql。
23 同样的负载压力,mysql要消耗更少的CPU和内存,mssql的确是很耗资源。
24php连接mysql和mssql的方式都差不多,只需要将函数的mysql替换成mssql即可。
25mysql支持date,time,year类型,mssql到2008才支持date和time。
26变量赋值
MYsql:变量赋值SELECT @min_price:=MIN(price),@max_price:=MAX(price) FROM shop
MSsql:变量赋值SELECT @min_price=MIN(price),@max_price=MAX(price) FROM shop
三、总的来说,如果是简单的存储过程代码,要修改,不会太难。如果是复杂的系统,要移植会很难很难。
SQL语句写错了
1.下载SQLyog工具,这个工具用图形化的方式来管理Mysql,很方便的
你把你的语句放到里面执行一下
2.下载mysql手册,网上到处都是
我写了一个数据库查询的例子(数据库名为tarena,表名为test),你运行一下就好了
?php
$link = mysql_connect('localhost', 'root', '');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
$result = mysql_query("SELECT * FROM tarena.test
where over='1' and showl='1' and aaa'aaa'
order by id desc limit 5")or die("Invalid query: " . mysql_error());
$num_rows = mysql_num_rows($result);
if($num_rows == NULL)
{
return NULL;
}
else
{
$num_fields = mysql_num_fields($result);
$fields=Array();
$i = 0;
echo "table border='1' width='200'";
echo 'tr';
while ($i $num_fields)
{
$currfield = mysql_fetch_field($result);
echo 'td'.$currfield-name.'/td';
array_push($fields,$currfield-name);
$i++;
}
echo '/tr';
echo 'tr';
while($row = mysql_fetch_array($result)) {
foreach ($fields as $field) {
echo 'td'.$row[$field].'/td';
}
}
echo '/tr';
echo '/table';
}
?
是不等号的意思,也有的语言可以写作:# 或者 !=
1、=表示 等于;
2、 表示不等于;(注释:在 SQL 的一些版本中,该操作符可被写成 !=);
3、 表示大于;
4、 表示小于;
5、= 表示大于等于;
6、= 表示小于等于;
7、BETWEEN表示在某个范围内;
8、LIKE表示搜索某种模式;
9、IN表示指定针对某个列的多个可能值。
sql 语句中 || 符号是连接的意思,相当于字符串中的连接符。
SQL中常见的符号:
1、=表示 等于。
2、 表示不等于。
3、 表示大于。
4、 表示小于。
5、= 表示大于等于。
6、= 表示小于等于。
7、BETWEEN表示在某个范围内。
扩展资料:
常用的SQL语句:
1、显示当前数据库服务器中的数据库列表:mysql SHOW DATABASES。注意:mysql库里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
2、进入数据库:mysql USE 库名。
3、显示数据库中的数据表:mysql SHOW TABLES。
4、显示数据表的结构:mysql DESCRIBE 表名。
5、建立数据库:mysql CREATE DATABASE 库名。
6、建立数据表:mysql USE 库名;mysql CREATE TABLE 表名 (字段名 VARCHAR(20), 字段名 CHAR(1))。
参考资料来源:百度百科-sql语句大全
echo $result;没用(没影响)
select * from ip where ip!='$ipa'
思路不对 在ip表中肯定有不止一条数据 所以$result 肯定有值 所以count($array) 肯定成立;
如果你ip表中保持一条数据就会一直执行else 因为你用的是一台电脑 ip一直没变
1、等于运算符:=
“=”是用来判断数字、字符串和表达式是否相等,如果相等,返回值为,否则返回值为0。
如:select 5=6,'9'=9,668=668,'luo'='luo',(2*3)=(4*5),NULL=NULL,0=NULL;
结论】
1)若有一个两个操作数为NULL,比较运算的结果就是NULL;
2)同一个比较运算符中两个操作数都是字符串,则按照字符串进行比较;
3)若同一个比较运算符中两个操作数都是数值,则按照数值进行比较;
4)若是一个数值和一个字符串进行比较,则MySQL自动将字符串转化为数值;
5)不管何种情况,“=”比较返回的确实只有1、0与NULL三类值。
2、安全等于运算符:=
“=”运算符在具备“=”所有功能的基础上增加了判断NULL值的功能。
【结论】
1)“=”运算符确实具备“=”所有功能,返回值也是1、0与NULL;
2)当两个操作数均为NULL时,“=”运算符返回的结果为1,而不是NULL;
3)当只有一个操作数为NULL时,“=”运算符返回的结果也不是NULL而是0。
3、不等于运算符:或!=
1)“”或“!=”运算符也是可以用于数字、字符串与表达式的判断;
2)其比较逻辑与“=”相反,但返回值也是1、0与NULL。
4、小于或等于运算符:=
1)“=”运算符也是可以用于数字、字符串与表达式的判断;
2)其逻辑:判断左边的操作数是否小于右边的操作数,如果是则返回1,否则返回0;
3)针对含有NULL的操作数则好不犹豫地返回NULL。
5、小于运算符:
6、大于或等于运算符:=
7、大于运算符:
这三类运算符与上面的“=”逻辑一致,大家可以自己去分析其过程并得到结论。
8、IS NULL(ISNULL)、IS NOT NULL运算符
1)这类比较运算符是用来判断数字、字符、表达式结果是否为NULL;
2)返回的结果值有1、0,没有NULL;
3)IS NULL(ISNULL)与IS NOT NULL返回的值相反。
9、BETWEEN AND运算符
其语法格式为“expr BETWEEN min AND max”。
1)这类比较运算符是用来判断数字、字符、表达式结果是否为NULL;
2)返回的结果值有1、0与NULL;
3)等同于:min = expr =max,即包含上下限的值。
10、IN与NOT IN运算符
1)这类比较运算符是用来判断数字、字符、表达式结果是否为NULL;
2)返回的结果值有1、0与NULL;
3)IN用来判断操作数是否为IN列表中的一个值,如果是则返回1,否则返回0,对于NULL则返回NULL。NOT IN则于IN相反。
11、LIKE运算符
其语法格式为“expr LIKE 匹配条件”。
1)LIKE运算符用于匹配字符串;
2)返回的结果值有1、0与NULL;
3)包含两种通配符。“%”匹配任何字符,甚至包括零字符;“_”只能匹配一个字符。
12、REGEXP运算符
REGEXP是LIKE的逆运算。语法格式类似:“expr REGEXP 匹配条件”。只是其包含的通配符更多。
1)^:匹配以该字符后面的字符开头的字符串;
2)$:匹配以该字符后面的字符结尾的字符串;
3).:匹配任何一个单字符;
4)[···]:匹配方括号内的任何字符;
5)*:匹配零个或多个在它前面的字符。
总结:
1、MySQL支持的比较运算符有12类;
2、一个比较运算符的结果总是1、0或NULL;
3、只有“=”才支持NULL的比较,其他对有NULL操作数时返回的结果就是NULL。