时间:2021-07-01 10:21:17 帮助过:19人阅读
(1),优点分析:MYSQL短小精悍,容易上手,操作简单,免费供用的。相对其它数据库有特色又实用的语法多一些。SQL怎么也算是大型数据库,稳定,能做一般大系统的数据仓库,运行速度明显比MYSQL快N多(海量数据下这个优势显而易见)。
(2),缺点分析:MYSQL难担当大系统的数据仓库,运行速度慢,不够稳定,有掉线的情况。SQLSERVER价格贵(当然没说5元盗版),使用起来比MYSQL要难一些,毕竟东西大了说道多点。
(3),按你的补充(如何登录):MySQL自己有文字界面客户端,用起来咋说也没鼠标点方便(不过习惯了也好),当然配对MYSQL有专业的客户端软件,我是用SQLYOG519版的,各种操作真的是很方便的说。SQLSERVER 就用自带的查询分析器登录了:)两者的前提是数据库服务都带打开,而且你得知道安装时的用户名密码哦:)
三,MySQL
Web网站系统:安装配置简单,性能优越,开源。
日志管理系统:高效的插入和查询功能,如果设计地较好,在使用MyISAM存储引擎的时候,两者可以做到互不锁定,达到很高的并发性能。
数据仓库系统:在急需大量存储的空间和高效率的数据分析的需求下,目前基本有三种方式可以解决这一问题:1,采用昂贵的高性能主机以提高计算性能,用高端存储设备提高I/O性能,效果理想,但是成本非常高;2,通过将数据复制到多台使用大容量硬盘的廉价pcserver上,以提高整体计算性能和I/O能力,效果尚可,存储空间有一定限制,成本低廉;,3,通过将数据水平拆分,使用多台廉价的pcserver和本地磁盘来存放数据,每台机器上面都只有所有数据的一部分,解决了数据量的问题,所有pcserver一起并行计算,也解决了计算能力问题,通过中间代理程序调配各台机器的运算任务,既可以解决计算性能问题又可以解决I/O性能问题,成本也很低廉。对于第二个和第三个,MySQL都有很大的优势(跨域的简单复制、免费)。
嵌入式系统:嵌入式环境对软件系统最大的限制是硬件资源非常有限,在嵌入式环境下运行的软件系统,必须是轻量级低消耗的软件。MySQL有专门针对嵌入式系统的版本。
1,支持5000万条记录的数据仓库;2,适应于所有的平台;3,是开源软件,版本更新较快;4,性能很出色。纯粹就性能而言,MySQL是相当出色的,因为它包含一个缺省桌面格式MyISAM。MyISAM 数据库与磁盘非常地兼容而不占用过多的CPU和内存。MySQL可以运行于Windows系统而不会发生冲突,在UNIX或类似UNIX系统上运行则更好。可以通过使用64位处理器来获取额外的一些性能。因为MySQL在内部里很多时候都使用64位的整数处理;5,价格便宜
缺点: 缺乏一些存储程序的功能,不支持陌生的关键字,采用缺省的端口IP(也是优点),容易被黑客侵入。MyISAM(MySQL的默认存储引擎,另一个是innoDB)并不支持事务处理。
MySQL的基本语法和SQL Server基本相同。
四:SQLserver
(1) 扩展性强:当系统要更高数据库处理速度时,只要简单地增加数据库服务器就 可以得到扩展。
(2) 可维护性:当某节点发生故障时,系统会自动检测故障并转移故障节点的应用,保证数据库的持续工作。
(3) 安全性:因为数据会同步的多台服务器上,可以实现数据集的冗余,通过多份数据来保证安全性。另外它成功地将数据库放到了内网之中,更好地保护了数据库的安全性。
(4) 易用性:对应用来说完全透明,集群暴露出来的就是一个IP
(1) 不能够按照Web服务器的处理能力分配负载。
(2) 负载均衡器(控制端)故障,会导致整个数据库系统瘫痪。
增:insert into 目标数据表 select * from 源数据表" (把源数据表的记录添加到目标数据表)
删:delete from 数据表 where 条件表达式
改:update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式
查:select * from 数据表 where 字段名=字段值 order by 字段名 [desc]
MySQL(用法):
一,基本概念
1, 常用的两种引擎:
(1) InnoDB
a,支持ACID,简单地说就是支持事务完整性、一致性;
b,支持行锁,以及类似ORACLE的一致性读,多用户并发;
c,独有的聚集索引主键设计方式,可大幅提升并发读写性能;
d,支持外键;
e,支持崩溃数据自修复;
InnoDB设计目标是处理大容量数据库系统,它的CPU利用率是其它基于磁盘的关系数据库引擎所不能比的。
它是一个可靠地事务处理引擎,不支持全文本搜索
(2) MyISAM
a,不支持 每次查询具有原子性
b,只支持表所
c,强调的是性能,其执行数 度比InnoDB类型更快,但是不提供事务支持
d,如果执行大量的SELECT,MyISAM是更好的选择
2, 介绍:
a,数据库-database
保存有组织的数据的容器(通常是一个文件或一组文件)
b,表-table
某种特定类型数据的结构化清单
c,模式-schema
关于数据库和表的布局及特性的信息
d,列-column
表中的一个字段,所有表都是由一个或多个列组成的
e,行-row
表中的一个记录
f,数据类型-datatype
所容许的数据的类型。每个表列都有相应的数据类型,它限制(或容许)该列中存储的数据
二,mysql命令行
1,连接mysql
格式: mysql -h主机地址 -u用户名 -p用户密码
a, 连接到本地MYSQL
首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root -p,
回车后提示你输密码。 MYSQL的提示符是: mysql> 。(默认root用户没有密码)
b,连接到远程主机上的MYSQL
假设远程主机的IP为:218.105.110.116,用户名为root,密码为abcd123456。
则键入以下命令:mysql -h218.105.110.116 -u root -p abcd123456;(注:u与root之间可以不用加空格,其它也一样)。
2, 启动mysql服务
net start mysql
3,停止mysql服务
net stop mysql
4,查询端口是否冲突
netstat –na | findstr 8080 查看被监听的端口 , findstr用于查找后面的端口是否存在。
5,退出mysql
quit或者exit退出
6,修改密码:
格式:mysqladmin -u用户名 -p旧密码 password 新密码
例如给root修改密码:
mysqladmin -u root -p ab12 password djg345
三,显示命令
1.显示当前数据库服务器中的数据库列表
mysql> SHOW DATABASES;
2.显示某个数据库中的数据表
mysql> USE 库名;//使用某个库
mysql> SHOW TABLES;//列出库中所有的表
3.显示数据表的结构
mysql> DESCRIBE 表名;
4.建立数据库
mysql> CREATE DATABASE 库名;。
5.建立数据表
mysql> USE 库名。
mysql> CREATE TABLE 表名 (字段名 VARCHAR(20), 字段名 CHAR(1));。
6.删除数据库
mysql> DROP DATABASE 库名;。
7.删除数据表
mysql> DROP TABLE 表名;。
8.将表中记录清空
mysql> DELETE FROM 表名;。
9.显示表中的记录
mysql> SELECT * FROM 表名;。
10.往表中插入记录
mysql> INSERT INTO 表名 VALUES (”hyq”,”M”);。
11.更新表中数据
mysql-> UPDATE 表名 SET 字段名1=’a‘,字段名2=’b’ WHERE 字段名3=’c‘;。
12.用文本方式将数据装入数据表中
mysql> LOAD DATA LOCAL INFILE “D:/mysql.txt” INTO TABLE 表名;。
13.导入.sql文件命令
mysql> USE 数据库名;。
mysql> SOURCE d:/mysql.sql;。
14.命令行修改root密码
mysql> UPDATE mysql.user SET password=PASSWORD(’新密码’) WHERE User=’root’;。
mysql> FLUSH PRIVILEGES;。
15.显示use的数据库名
mysql> SELECT DATABASE();。
16.显示当前的user
mysql> SELECT USER();。
一、索引的创建
二、视图的创建
三、添加数据的存储过程
四、修改数据的存储过程
SQLserver(分页) :
--分页显示 查询go create proc [orderinfo](@pagesize int,@pageindex int out,@pageName nvarchar(50),@pagecount int out,@totalpage int out) as begin -- 纠正当前页 < 1 的问题 if @pageindex < 1 set @pageindex = 1 --求出总记录数,算出总页数 select @pagecount = count(*) from Student where StuName like ‘%‘+@pageName+‘%‘ -- 算出总页数-- (方法一) -- if @pagecount % @pagesize = 0 -- set @totalpage = @pagecount / @pagesize -- else -- set @totalpage = @pagecount / @pagesize + 1 -- (方法二)向上取整 set @totalpage = CEILING (@pagecount * 1.0 / @pagesize) -- 纠正当前页 > 总页数的问题 if @pageindex > @totalpage set @pageindex = @totalpage -- 分页查询出所有数据 select * from (select a.Id,a.StuName,a.BirthDay,a.Age,a.Status,a.ClassId,b.ClassName,ROW_NUMBER() over (order by StuName)rn from Student a join Class b on a.ClassId=b.ClassId where StuName like ‘%‘+@pageName+‘%‘)t1 where rn between (@pageindex - 1) * @pagesize + 1 and @pageindex * @pagesize end go declare @pageindex int, @totalpage int exec [orderinfo] 4,2,‘‘,@pageindex out,@totalpage out select @pageindex , @totalpage
SQLserver-MySQL的区别和用法
标签:sid nbsp 优点 特点 轻量级 class over 包含 代理