标签: Mysql

SQL Server,MySQL,Oracle三者的区别

Oracle 能在所有主流平台上运行(包括Windows)。完全支持所有的工业标准。采用完全开放策略。可以使客户选择*适合的解决方案。对开发商全力支持,Oracle并行服务器通过使一组结点共享同一簇中的工作来扩展Windows NT的能力,提供高可用性和高伸缩性的簇的解决方案。如果Windows NT不能满足需要,用户可以把数据库移到UNIX中。Oracle的并行服务器对各种UNIX平台的集群机制都有着相当高的集成度。Oracle获得*高认证级别的ISO标准认证.Oracle性能*高,保持开放平台下的TPC-D和TPC-C的世界记录Oracle多层次网络计 算,支持多种工业标准,可以用ODBC、JDBC、OCI等网络客户连接。
Oracle 在兼容性、可移植性、可联结性、高生产率上、开放性也存在优点。Oracle产品采用标准SQL,并经过美国国家标准技术所(NIST)测试。与 IBM SQL/DS,DB2,INGRES,IDMS/R等兼容。 Oracle的产品可运行于很宽范围的硬件与操作系统平台上。可以安装在70种以上 不同的大、中、小型机上;可在VMS、DOS、UNIX、WINDOWS等多种操作系统下工作。能与多种通讯网络相连,支持各种协议(TCP/IP、 DECnet、LU6.2等)。提供了多种开发工具,能*大的方便用户进行进一步的开发。Oracle良好的兼容性、可移植性、可连接性和高生产率是 Oracle RDBMS具有良好的开放性。
Oracle价格是比较昂贵的。据说一套正版的Oracle软件早在2006年年底的时候在市场上的价格已经达到了6位数。所以如果你的项目不是那种超级大的项目,还是放弃Oracle吧。

SQL Server

SQL Server 是 Microsoft推出一套产品,它具有使用方便、可伸缩性好、与相关软件集成程度高等优点,逐渐成为Windows平台下进行数据库应用开发较为理想的 选择之一。SQLServer是目前流行的数据库之一,它已广泛应用于金融、保险、电力、行政管理等与数据库有关的行业。而且,由于其易操作性及友好的界 面,赢得了广大用户的青睐,尤其是SQLServer与其它数据库,如Access、FoxPro、Excel等有良好的ODBC接口,可以把上述数据库 转成SQLServer的数据库,因此目前越来越多的读者正在使用SQLServer。
SQL Server由于是微软的产品,又有着如此强大的功能,所以他的影响力是几种数据库系统中比较大,用户也是比较多的。它一般是和同是微软产品的.net平台一起搭配使用。当然其他的各种开发平台,都提供了与它相关的数据库连接方式。因此,开发软件用SQL Server做数据库是一个正确的选择。

MySQL

MySQL不支持事务处理,没有视图,没有存储过程和触发器,没有数据库端的用户自定义函数,不能完全使用标准的SQL语法。
从数据库行家听说的*件事就是MySQL缺乏transactions,rollbacks, 和subselects的功能。如果你计划使用MySQL写一个关于银行、会计的应用程序,或者计划维护一些随时需要线性递增的不同类的计数器,你将缺乏transactions功能。在现有的发布版本的 MySQL下,请不要有任何的这些想法。(请注意,MySQL的测试版3.23.x系列现在已经支持transactions了)。
在非常必要的情况下,MySQL的局限性可以通过一部分开发者的努力得到克服。在MySQL中你失去的主要功能是subselect语句,而这正是其它的所有数据库都具有的。换而言之,这个失去的功能是一个痛苦。
MySQL没法处理复杂的关联性数据库功能,例如,子查询(subqueries),虽然大多数的子查询都可以改写成join
另一个MySQL没有提供支持的功能是事务处理(transaction)以及事务的提交(commit)/撤销(rollback)。一个事务指的是被当作一个单位来共同执行的一群或一套命令。如果一个事务没法完成,那么整个事务里面没有一个指令是真正执行下去的。对于必须处理线上订单的商业网站来说,MySQL没有支持这项功能,的确让人觉得很失望。但是可以用MaxSQL,一个分开的服务器,它能通过外挂的表格来支持事务功能。
外键(foreignkey)以及参考完整性限制(referentialintegrity)可以让你制定表格中资料间的约束,然后将约束 (constraint)加到你所规定的资料里面。这些MySQL没有的功能表示一个有赖复杂的资料关系的应用程序并不适合使用MySQL。当我们说 MySQL不支持外键时,我们指的就是数据库的参考完整性限制–MySQL并没有支持外键的规则,当然更没有支持连锁删除(cascadingdelete)的功能。简短的说,如果你的工作需要使用复杂的资料关联,那你还是用原来的Access吧。
你在MySQL中也不会找到存储进程(storedprocedure)以及触发器(trigger)。(针对这些功能,在Access提供了相对的事件进程(eventprocedure)。
MySQL+php+apache三者被软件开发者称为“php黄金组合”。

Oracle和MySQL的主要区别

Oracle:客户端和命令窗口,都是由用户决定内容-> conn user_name/password;

MySQL:客户端和命令窗口,都是由数据库决定内容-> use datebase;

都可以创建多数据库多用户,个人倾向于Oracle一个数据库中多个用户的形式,MySQL多个数据库多个用户形式(*好每个数据库对应一个用户)

Oracle是大型数据库而MySQL是中小型数据库,Oracle市场占有率达40%,MySQL只有20%左右,同时MySQL是开源的而Oracle价格非常高。

Oracle支持大并发,大访问量,是OLTP(On-Line Transaction Processing联机事务处理系统)*好的工具。

安装所用的空间差别也是很大的,MySQL安装完后才152M而Oracle有3G左右,且使用的时候Oracle占用特别大的内存空间和其他机器性能。

Oracle也与MySQL操作上的一些区别

组函数用法规则

MySQL中组函数在select语句中可以随意使用,但在Oracle中如果查询语句中有组函数,那其他列名必须是组函数处理过的,或者是group by子句中的列否则报错
eg:
select name,count(money) from user;这个放在MySQL中没有问题在Oracle中就有问题了。

自动增长的数据类型处理

MySQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。Oracle没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。
CREATE SEQUENCE序列号的名称(*好是表名+序列号标记)INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;
其中*大的值按字段的长度来定,如果定义的自动增长的序列号NUMBER(6),*大值为999999
INSERT语句插入这个字段值为:序列号的名称.NEXTVAL

单引号的处理

MySQL里可以用双引号包起字符串,Oracle里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。

翻页的SQL语句的处理

MySQL处理翻页的SQL语句比较简单,用LIMIT开始位置,记录个数;PHP里还可以用SEEK定位到结果集的位置。Oracle处理翻页的SQL语句就比较繁琐了。每个结果集只有一个ROWNUM字段标明它的位置,并且只能用ROWNUM<100,不能用ROWNUM>80。
以下是经过分析后较好的两种Oracle翻页SQL语句(ID是唯一关键字的字段名):
语句一:
SELECT ID, [FIELD_NAME,…] FROM TABLE_NAME WHERE ID IN ( SELECT ID FROM (SELECT ROWNUM AS NUMROW, ID FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 条件3;

语句二:
SELECT * FROM (( SELECT ROWNUM AS NUMROW, c.* from (SELECT [FIELD_NAME,…] FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) c) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 条件3;

长字符串的处理

长字符串的处理Oracle也有它特殊的地方。INSERT和UPDATE时*大可操作的字符串长度小于等于4000个单字节,如果要插入更长的字符串,请考虑字段用CLOB类型,方法借用Oracle里自带的DBMS_LOB程序包。插入修改记录前一定要做进行非空和长度判断,不能为空的字段值和超出长度字段值都应该提出警告,返回上次操作。

日期字段的处理

MySQL日期字段分DATE和TIME两种,Oracle日期字段只有DATE,包含年月日时分秒信息,用当前数据库的系统时间为SYSDATE,精确到秒,或者用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)年-月-日24小时:分钟:秒的格式YYYY-MM-DD HH24:MI:SS TO_DATE()还有很多种日期格式,可以参看Oracle DOC.

日期型字段转换成字符串函数TO_CHAR(‘2001-08-01’,’YYYY-MM-DD HH24:MI:SS’)
日期字段的数学运算公式有很大的不同。MySQL找到离当前时间7天用DATE_FIELD_NAME > SUBDATE(NOW(),INTERVAL 7 DAY)Oracle找到离当前时间7天用 DATE_FIELD_NAME >SYSDATE – 7;
MySQL中插入当前时间的几个函数是:NOW()函数以`’YYYY-MM-DD HH:MM:SS’返回当前的日期时间,可以直接存到DATETIME字段中。CURDATE()以’YYYY-MM-DD’的格式返回今天的日期,可以直接存到DATE字段中。CURTIME()以’HH:MM:SS’的格式返回当前的时间,可以直接存到TIME字段中。例:insert into tablename (fieldname) values (now())
而Oracle中当前时间是sysdate

空字符的处理

MySQL的非空字段也有空的内容,Oracle里定义了非空字段就不容许有空的内容。按MySQL的NOT NULL来定义Oracle表结构,导数据的时候会产生错误。因此导数据时要对空字符进行判断,如果为NULL或空字符,需要把它改成一个空格的字符串。

字符串的模糊比较

MySQL里用字段名like%’字符串%’,Oracle里也可以用字段名like%’字符串%’但这种方法不能使用索引,速度不快,用字符串比较函数instr(字段名,’字符串’)>0会得到更精确的查找结果。

程序和函数里,操作数据库的工作完成后请注意结果集和指针的释放。

主键

MySQL一般使用自动增长类型,在创建表时只要指定表的主键为auto increment,插入记录时,不需要再指定该记录的主键值,MySQL将自动增长;Oracle没有自动增长类型,主键一般使用的序列,插入记录时将序列号的下一个值付给该字段即可;只是ORM框架是只要是native主键生成策略即可。

Oracle实现了ANSIISQL中大部分功能,如,事务的隔离级别、传播特性等而MySQL在这方面还是比较的弱

MySQL客户端/服务器架构

MySQL的客户端/服务器架构
本文主要参考作者小孩子写的MySQL小册子,整理

MySQL的服务器程序直接和我们存储的数据打交道,客户端程序连接服务器,发送增删改查的请求,服务器操作维护的数据响应请求。

MySQL服务器程序的进程也被称为MySQL数据库实例。我们启动的MySQL服务器进程的默认名称是mysqld,而常用的MySQL客户端进程默认名称为mysql。

安装
不论通过哪种方式安装,MySQL的服务器程序和客户端都会被安装到我们的机器上。

不过在Linux下使用RPM包时会有单独的服务器RPM包和客户端RPM包,需要分别安装。

启动服务器程序
mysqld
代表着mysql服务器程序,运行这个可执行文件就可以直接启动一个服务器进程。

mysqld_safe
是一个启动脚本,会间接的调用mysqld。

还顺便启动了另外一个监控进程,这个监控进程在服务器进程挂了的时候,可以帮助重启它。

会将服务器程序的出错信息和其他诊断信息重定向到某个文件中,产生出错日志。

mysql.server
也是一个启动脚本,会间接的调用mysqld_safe,使用时跟上start/stop参数就OK。

不过这个文件其实是一个链接文件,实际文件是../support-files/mysql.server.

mysqld_multi
一台计算机上可以运行多个MySQL服务器进程,这个可执行文件可以对每一个服务器进程的启动或停止进行监控。

启动客户端程序
格式:

mysql -h主机名 -u用户名 -p密码
小贴士: 像 h、u、p 这样名称只有一个英文字母的参数称为短形式的参数,使用时前边需要加单短划线,像 host、user、password 这样大于一个英文字母的参数称为长形式的参数,使用时前边需要加双短划线。

客户端与服务器连接的过程
本质上进程间通信的过程,MySQL支持以下的通信方式

TCP/IP
MySQL服务器默认监听3306端口。

命名管道和共享内存
这种通信方式是windows操作系统中的

Unix域套接字文件
这种方式要求客户端和服务器运行在同一台类Unix的操作系统上。
MySQL服务器程序默认监听的套接字文件路径是/tmp/mysql.sock,客户端也默认监听这个文件。

改变文件:

# 服务器改变套接字文件
mysqld –socket=/tmp/a.txt
# 客户端改变
mysql -hlocalhost -uroot –socket=/tmp/a.txt -p
架构
%title插图%num

MYSQL 客户端与服务器关系

数据库概念

 

如果想要知道MySQL数据库客户端与服务器之间的关系.首先要明白什么是”数据库”.

从字面意思理解,所谓”数据库”,就是存放数据的库.现实中,大家都知道仓库,粮食库,车库,快递库,它们是放各种实体东西的库.而数据库,放的只有数据.

它是一个软件,它是一个能帮我们管理数据的地方.什么样的东西算数据?一篇文章,一个人的年龄,名字,一件商品的名称,数量,价格等等…把它们放在数据库中稳妥的管理起来,且效率挺高,这就是数据库.

 

数据库与PHP配合的重要性

 

我们就拿我*擅长的PHP开发来说,PHP*主要做的就是WEB开发.也就是所谓的网站开发.当然,PHP也能做别的东西,但相比其他语言来说优势并不这么明显.PHP主要得做的就是,怎么样把用户过来的数据写入数据库,又怎么样从数据库取出数据扔给用户. PHP与MYSQL的关系更像炼钢与采钢的关系.学会了PHP只会采钢,但矿石从哪里来?还得会采矿.

 

PHP工作的大部分过程都是:

PHP–>连接数据库–>写入数据–>查出数据–>格式化数据–>显示出来给用户

WEB网站开发的好,学好数据库的只是非常重要.

 

安装mysql

 

这里我们集成环境xampp,不需要我们单独配置安装mysql,安装也非常方便,几乎就是一直下一步就安装好了.这里不做过多的阐述.如果想要知道xampp这种集成环境怎么安装,请关注我的另一篇基础篇文章,常用PHP开发软件安装使用教程.

 

客户端概念

 

我们安装完成后,会看到图1,那如何连接呢?

%title插图%num%title插图%num

只需要在mysql那个选项后面把Start打开.左侧会有一个绿灯常亮,表示已经开启了.我们在window任务栏的进程中找一个有没有一个mysqld.exe的映像名称.如果有,表示已经开启了mysql服务.那就有个疑问了,这个进程是干嘛的?我们通过这个进程,可以写数据,查数据,所有与数据库写入读取有关的操作,都与这个exe有关.

但目前我们只是开启了这个进行,如何与这个进程”说话”?这个时候就需要客户端.之前我们安装的xampp,是开启mysql进程的客户端,至于开启了以后怎么与mysql对话,同样需要客户端.

 

服务器

 

我们安装在window下的xampp就是服务器的一种环境.因为它简洁易用,所以不需要我们做什么,另一个问题需要重点说一下.虽然我们在自己的电脑上安装了xampp集成环境,但它已经被赋予了另一个角色,就是服务器,那什么是服务器?

服务器:也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

举个简单的例子,我们玩的游戏,访问的网站,逛的淘宝等等,你打开浏览器,输入网址,一敲回车,人家凭什么就展示给你一个网站?当然这里面不只是服务器,还有大量的其他网络和计算机知识.这里我们只说服务器.

当键入网址,敲下回车的那一刻,你的那个网址,会顺着网线,去远程寻找对应的服务器,服务器根据你的需要响应给你一个页面,就是你看到的网站.

比如说,我们输入www.taobao.com,远程的淘宝机房,接收到你的请求,会根据你的需要返回给你一个结果,这个结果就是淘宝的首页,那么那个能接受请求并返回给你结果的电脑,就是服务器.

之前我说我们的电脑多了一个功能,就是服务器,我们在自己的电脑上安装xampp集成环境,这个时候我们的电脑就已经具备了接受请求和响应给你结果的能力,这就是服务器.只不过我们没有远程连接,而是在自己电脑上搭建了服务器功能.自己电脑访问自己的电脑上的服务器.

 

MYSQL 客户端与服务器关

 

既然我们的能顺利开启mysql服务了,如何跟这个进程交流通话,这个时候mysql客户端就非常有必要了.

%title插图%num%title插图%num

与服务器mysql通话的客户端不止一种,比如说,纯window下或者liunx下的命令行,可以直接通过命令建立与mysql数据库的通话,另外还有像phpmyadmin,它是xampp提供给我们的一种图形化连接方式.还有navcat,mysqlworkbench等等.

建议:初学者使用纯命令行的方式进行操作,多多练习,会起到事倍功半的效果.

云数据库六大优势是什么 如何学好云计算技能

云数据库六大优势是什么?如何学好云计算技能?数据库是前端还是后台开发人员都需要了解和掌握的工具,传统的数据库工程师需要掌握基础理论知识、数据库基础知识、数据库运维知识以及数据库性能调优技能。不过随着云时代的到来,云数据库的应用及大规模普及,给数据库工程师的日常工作带来了很大的积*影响,下面就给大家详细介绍一下云数据库的六大优势:

%title插图%num

1、免部署。云数据库种类丰富,关系型数据库如MySQL、PostgreSQL、SQL Server,非关系型数据库如MongoDB、Redis、Memcache,兼容和支持各种版本。通过简单的购买操作,分钟级甚至秒级交付,云数据库一键部署。

2、高性能。云数据库软硬件深度调优,具有理想的性能表现。同时,底层硬件较快引入*新高性能硬件,多种性能加持下,DBA可聚焦在应用层优化。

3、高可靠性。云数据库能够自动探测,及时容灾,保证数据库服务不中断。对于数据库工程师来说,也不需要再额外部署高可用架构。

4、强大的灵活性和扩展性。云数据库弹性扩展的能力,至少是支持垂直扩展(scale-up),通常也支持水平扩展(scale-out)。灵活性则是第三维度的扩展,它可以支持一主多从,读写分离。数据库工程师能够在短期内聚焦业务,暂时不会有扩展性的烦恼。

5、自带运维能力。云数据库通常支持自动备份和手动备份两种模式,提供一键回档的功能找回数据。并提供详细的监控数据,也可配置异常自动告警。可以说,数据库工程师对云数据库基本没有运维工作。

6、安全可靠。云数据库在数据存储、网络链路访问、鉴权认证、多租户隔离方面做了多重保障,以确保数据安全,除此之外,它可以支持数据库审计,后端自动漏洞扫描,定期安全加固等。

使用云数据库后,数据库工程师可以有更多时间关注其他技能的锻炼和培养,提升自己的综合竞争力。如果你想了解更多云计算技术,可以选择专业学习一下。

MYsql:数据库内容完整复制到另一数据库

数据库内容完整复制到另一数据库
1.        双击打开数据库1

2.        右击数据库1,在弹出的属性菜单内选择:转储SQL文件…

3.        在弹出页面内,选择保存到本地的位置,点击保存   会将数据库1内的所有信息保存到本地(类似备份功能)

4.        双击打开另一数据库2

5.        右击数据库2,在弹出的属性菜单内选择:运行SQL文件…

6.        打开运行sql文件页面

7.        在【文件】选择之前转储的 数据库1 文件

8.        点击【开始】可以将数据库1 完全的运行复制到数据库2

mysql数据库从一台服务器迁移到另一台服务器上

一、应用场景
由于要把测试服务器上的数据库迁移到正式服务器上,因此需要做数据库的迁移。这里记录一下。

二、数据库迁移
1、新建数据库test

create database test;
1
2、进入数据库,创建数据表test

create table test1(id int(10) primary key, name varchar(30), age int(10));
1
3、生成.sql文件

(1)这里生成.sql文件,需要用到mysqldump,如果找到该命令的话,建立一个软连接到/usr/bin 下。例如,你的mysql 路径为:/usr/local/mysql,则执行
ln -fs /usr/local/mysql /usr/bin (PS:这里不需要进入到mysql执行命令)

(2)执行mysqldump命令

1)为某个数据库生成.sql文件

mysqldump -u 用户名 -p 数据库>你想要生成.sql文件的路径

2)只要数据库的表结构

mysqldump -u 用户名 -p -d 数据库>你想要生成.sql文件的路径

3)生成某个数据库下面对应某个表的表结构

mysqldump -u 用户名 -p -d 数据库名 表名>你想要生成.sql文件的路径

4)生成某个数据库下面对应某个表的表结构+表数据

mysqldump -u 用户名 -p -d 数据库名>你想要生成.sql文件的路径

我这里执行的命令是:

mysqldump -u xx -p pzsh>/home/pzsh/test.sql
1
然后去/home/pzsh下面看看,就会发现已经生成.sql文件了

4、使用ftp工具,把生成的.sql文件放到新服务器上去

(1)使用FTP工具下载.sql文件
(2)使用FTP工具把.sql文件上传到指定路径
(3)我这边是把.sql文件上传到新服务器的/home/pzsh目录下

5、导入到服务器

(1)进入到新服务器的mysql中

mysql -u 用户名 -p

(2)先创建数据库,按照.sql文件中的数据库名字。

create database test;

//进入到创建的数据库中
use test;
//查看当下的数据表
show tables;
//此时数据库中是没有任何表的

(3)执行source命令,导入.sql文件

source /home/pzsh/test.sql

(4)查看test数据库中的表

show tables;

此时发现我们已经把表都转移过来了。

6、如果两台服务器的数据库版本不兼容,则在root用户下执行下面的命令

mysql_upgrade -u root -p

输入密码即可。

end

5T 的 MySQL 数据上云?如何做才能更好?

chinafengzhao · 135 天前 · 3616 次点击
这是一个创建于 135 天前的主题,其中的信息可能已经有所发展或是发生改变。
由于架构和历史原因,公司在本地机房部署 MySQL 做数据仓库,主要是 OLAP 的业务,跑存储过程和 ETL 做数据清洗。单实例建的 MySQL,里面各种中文表名和各种大宽表(建表和索引也没有完全符合 OLTP 的*佳实践),数据量日积月累,现在有 100 多个 schema,单实例数据量差不多有 5T 了,运维起来非常吃力。现在公司准备上云,估计还是这套架构。
MySQL 实例 表名 大宽表33 条回复 • 2020-12-10 11:25:18 +08:00
snail00 1
snail00 135 天前
有 5t 的数据量, 其他周边服务应该也要陆续上云, *简单的就是联系云厂商会有专人对接出方案的.
cccp2020 2
cccp2020 135 天前
买云服务器,然后买 rds 什么的,发工单就行,大客户他们有专人解决,你可以看看我的历史帖子,有优惠券的购买 rds
opengps 3
opengps 135 天前 via Android ❤️ 2
快递硬盘
mitsuhasanye 4
mitsuhasanye 135 天前 ❤️ 1
让乙方出方案更保险,肯定不止你一家有过这么多数据
iphoneXr 5
iphoneXr 135 天前 ❤️ 1
买阿里云 polardb 吧,兼容 mysql,不用去管存储空间用量了。
chinafengzhao 6
chinafengzhao 135 天前
@iphoneXr 完全兼容吗?这个主要是 OLAP 业务,跑各种存储过程。polardb 太贵了啊
mahone3297 7
mahone3297 135 天前
@iphoneXr 请教下, polardb,rds,oceanbase 的区别是什么?
buaacss 8
buaacss 135 天前
做一个点对点 * 连到本地机房,然后做一个 dts 把数据全量同步过去,并设置增量同步,*后切 dns 同时把老数据库上的账号都设置为只读
chinafengzhao 9
chinafengzhao 135 天前
@iphoneXr 我也想用 polardb,不想折腾那么多,但是我们本地资源就实在是太贵了
orclcast 10
orclcast 135 天前
走线下吧

iphoneXr 11
iphoneXr 134 天前 via iPhone
@chinafengzhao 先看好不好使,贵不贵的问题有办法解决,一次性买 3 到 5 年,再走个代理商回扣啥的,算下来很便宜。自己用 ecs 来搭建那种双节点也差不多价钱,不贵的。
第二个 配合 dms 做数据库管理,das 做数据库优化监控(自动限流、索引创建删除、扩容节点等),dts 做数据同步等
iphoneXr 12
iphoneXr 134 天前 via iPhone
@mahone3297 我觉得没啥区别,感觉更像迭代产品的关系
dynastysea 13
dynastysea 134 天前
@iphoneXr 区别大了啊,这几个形态完全不同。polardb 是基于共享存储方案的,可以快速扩容 ro 节点。rds 更接近原生 mysql 。这两者都是 100%兼容 mysql 。ob 是分布式数据库,完全自研,只能说兼容*大多数 mysql,主要场景争对金融级数据库,一般的应用不适合
ifuture 14
ifuture 134 天前
分而治之呗,100 个 schema,单个 schema 也就不大了,一个一个迁移,迁移以后,再把迁移期间原来系统的数据增量同步过去
iphoneXr 15
iphoneXr 134 天前 via iPhone
@dynastysea 哈哈哈 我承认我对第二个问题有点张口就来了。不过我当时想的是对于 java 程序来说,没区别。所以我还是坚持我的说法。
springz 16
springz 134 天前
为什么没人推荐 TiDB,推荐下。
springz 17
springz 134 天前
TiDB 还有 TiFlash 和 TiSpark,OLAP 场景多合适。
xuanbg 18
xuanbg 134 天前
阿里云有个数据迁移工具的,配好了让它跑就行了。5T 跑个 10 来天总能跑完的吧。
dynastysea 19
dynastysea 134 天前
@xuanbg 哈哈,你是看不起阿里云? 5T 这么点数据量都要跑 10 天?
threeEggs123 20
threeEggs123 134 天前 via Android
aws snowball?
brendanliu 21
brendanliu 134 天前
快递硬盘吧 TB 级别的自己上传费时费力 可能还会出错 快递硬盘期间的增量数据*后再使用官方的迁移工具搞一下
xuanbg 22
xuanbg 134 天前
@dynastysea 我是怕楼主本地机房是小水管啊
Weixiao0725 23
Weixiao0725 134 天前
买云服务器,搭建 TiDB 集群,自己写个程序慢慢往里面导呗
hongzai118 24
hongzai118 134 天前
需要采购阿里云 华为云 腾讯云 可以联系我 我这边给你全网*低额外返现优惠 vx:gome3000
stranger75 25
stranger75 134 天前
我们这边可以出架构方案和技术售后,老哥需要的话联系我
@chinafengzhao
janxin 26
janxin 134 天前
花钱买方案?
IDAEngine 27
IDAEngine 134 天前 via iPhone
用亚马逊 aurora 呀,国内版的还不错,而且都是企业用户
whx20202 28
whx20202 134 天前
阿里云有个 dts,可以看一下
freecloud 29
freecloud 134 天前
/t/729386
可以联系我,我帮出架构和方案。
way2explore2 30
way2explore2 134 天前
@IDAEngine 这个情况 Aurora 很可能或者不久之后也会吃力,*好是直接 redshift

aurora 不是很适合 data warehouse
way2explore2 31
way2explore2 134 天前
联系我出方案也行。 哈哈哈
lance6716 32
lance6716 133 天前 via Android
@Weixiao0725 有 tidb-lightning,配置合适的话 200G/h 吧,比自己写快
Svalues 33
Svalues 120 天前
@dynastysea 可能还不止,考虑一下磁盘的 IO

搭建Spring Boot项目 如何配置数据源

在上一章中,我们已经搭建好项目,现在来讲一下如何配置数据源。

由于在有的项目中,用的数据源可能会涉及多个,且是不同类型的,我们接下来就讲解多数据源的配置。

 

情景描述:

现有项目需要访问不同的数据库,有Mysql、Oracle、Sql server数据库

就以该情景为例,讲讲该如何配置。

 

步骤:

1、在resources文件夹下新建persistence-multiple-db.properties资源文件,如下图:

(备注:具体的值自己配置)

%title插图%num

 1 # Mysql数据库
 2 app.datasource.mysql.url=jdbc:mysql://192.168.1.100/XXX数据库名称
 3 app.datasource.mysql.username=username
 4 app.datasource.mysql.password=password
 5 app.datasource.mysql.driver-class-name=com.mysql.jdbc.Driver
 6 app.datasource.mysql.maximum-pool-size=10
 7 
 8 # Oracle数据库
 9 app.datasource.oracle.url=jdbc:oracle:thin:@192.168.1.100:1521/XXX数据库名称
10 app.datasource.oracle.username=username
11 app.datasource.oracle.password=password
12 app.datasource.oracle.driver-class-name=oracle.jdbc.driver.OracleDriver
13 app.datasource.oracle.maximum-pool-size=30
14 
15 # Sql server数据库
16 app.datasource.sqlserver.url=jdbc:sqlserver://192.168.1.100;databaseName=XXX数据库名称
17 app.datasource.sqlserver.username=username
18 app.datasource.sqlserver.password=password
19 app.datasource.sqlserver.driver-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver
20 app.datasource.sqlserver.maximum-pool-size=30

 

2、在config文件夹中新建MysqlDatabaseConfig.java、OracleDatabaseConfig.java、SqlserverDatabaseConfig.java

在domain文件夹中新建mysql、oracle、sqlserver文件夹

在repository文件夹中新建mysql、oracle、sqlserver文件夹

(备注:命名可以自定义,我这里是为了便于区分)

%title插图%num

接下来就依次配置这三个文件,以MysqlDatabaseConfig.java为例说明一下,另外两个同理,但是要注意@Primary(优先考虑,优先考虑被注解的对象注入)注解,另外两个不要添加该注解

 1 package com.hyl.springdemo.config;
 2 
 3 import com.ulisesbocchio.jasyptspringboot.annotation.EnableEncryptableProperties;
 4 import com.zaxxer.hikari.HikariDataSource;
 5 import org.springframework.beans.factory.annotation.Autowired;
 6 import org.springframework.boot.jdbc.DataSourceBuilder;
 7 import org.springframework.context.annotation.Bean;
 8 import org.springframework.context.annotation.Configuration;
 9 import org.springframework.context.annotation.Primary;
10 import org.springframework.context.annotation.PropertySource;
11 import org.springframework.core.env.Environment;
12 import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
13 import org.springframework.orm.jpa.JpaTransactionManager;
14 import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
15 import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
16 import org.springframework.transaction.PlatformTransactionManager;
17 
18 import javax.sql.DataSource;
19 import java.util.HashMap;
20 
21 @Configuration
22 @EnableEncryptableProperties
23 @PropertySource({ "classpath:persistence-multiple-db.properties" })
24 @EnableJpaRepositories(
25         basePackages = "com.hyl.springdemo.repository.mysql",
26         entityManagerFactoryRef = "mysqlEntityManager",
27         transactionManagerRef = "mysqlTransactionManager"
28 )
29 public class MysqlDatabaseConfig {
30 
31     @Autowired
32     private Environment env;
33 
34     @Bean
35     @Primary
36     public DataSource mysqlDataSource() {
37 
38         HikariDataSource dataSource = DataSourceBuilder.create().type(HikariDataSource.class).build();
39         dataSource.setDriverClassName(env.getProperty("app.datasource.mysql.driver-class-name"));
40         dataSource.setJdbcUrl(env.getProperty("app.datasource.mysql.url"));
41         dataSource.setUsername(env.getProperty("app.datasource.mysql.username"));
42         dataSource.setPassword(env.getProperty("app.datasource.mysql.password"));
43         dataSource.setMaximumPoolSize(Integer.parseInt(env.getProperty("app.datasource.mysql.maximum-pool-size")));
44 
45         return dataSource;
46     }
47 
48     @Bean
49     @Primary
50     public LocalContainerEntityManagerFactoryBean mysqlEntityManager() {
51         LocalContainerEntityManagerFactoryBean em
52                 = new LocalContainerEntityManagerFactoryBean();
53         em.setDataSource(mysqlDataSource());
54         em.setPackagesToScan(
55                 new String[] { "com.hyl.springdemo.domain.mysql" });
56 
57         HibernateJpaVendorAdapter vendorAdapter
58                 = new HibernateJpaVendorAdapter();
59         em.setJpaVendorAdapter(vendorAdapter);
60         em.setPersistenceUnitName("MysqlPersistenceUnit");
61         HashMap<String, Object> properties = new HashMap<>();
62         properties.put("hibernate.hbm2ddl.auto",
63                 env.getProperty("hibernate.hbm2ddl.auto"));
64         properties.put("hibernate.dialect",
65                 "org.hibernate.dialect.MySQL5Dialect");
66         em.setJpaPropertyMap(properties);
67 
68         return em;
69     }
70 
71     @Bean
72     @Primary
73     public PlatformTransactionManager mysqlTransactionManager() {
74 
75         JpaTransactionManager transactionManager
76                 = new JpaTransactionManager();
77         transactionManager.setEntityManagerFactory(
78                 mysqlEntityManager().getObject());
79         return transactionManager;
80     }
81 }

 

3、新建Repository,访问数据库(关于该部分,在后续的文章中再进行介绍)

%title插图%num

 

4、新建Service层,访问Repository

%title插图%num

 

5、在Controller层中进行调用

%title插图%num

 

6、运行项目,在网页中查看

%title插图%num

此篇博文主要是为了介绍配置多数据源,涉及到的其它内容在后续的博文中会逐一介绍

 

友情链接: SITEMAP | 旋风加速器官网 | 旋风软件中心 | textarea | 黑洞加速器 | jiaohess | 老王加速器 | 烧饼哥加速器 | 小蓝鸟 | tiktok加速器 | 旋风加速度器 | 旋风加速 | quickq加速器 | 飞驰加速器 | 飞鸟加速器 | 狗急加速器 | hammer加速器 | trafficace | 原子加速器 | 葫芦加速器 | 麦旋风 | 油管加速器 | anycastly | INS加速器 | INS加速器免费版 | 免费vqn加速外网 | 旋风加速器 | 快橙加速器 | 啊哈加速器 | 迷雾通 | 优途加速器 | 海外播 | 坚果加速器 | 海外vqn加速 | 蘑菇加速器 | 毛豆加速器 | 接码平台 | 接码S | 西柚加速器 | 快柠檬加速器 | 黑洞加速 | falemon | 快橙加速器 | anycast加速器 | ibaidu | moneytreeblog | 坚果加速器 | 派币加速器 | 飞鸟加速器 | 毛豆APP | PIKPAK | 安卓vqn免费 | 一元机场加速器 | 一元机场 | 老王加速器 | 黑洞加速器 | 白石山 | 小牛加速器 | 黑洞加速 | 迷雾通官网 | 迷雾通 | 迷雾通加速器 | 十大免费加速神器 | 猎豹加速器 | 蚂蚁加速器 | 坚果加速器 | 黑洞加速 | 银河加速器 | 猎豹加速器 | 海鸥加速器 | 芒果加速器 | 小牛加速器 | 极光加速器 | 黑洞加速 | movabletype中文网 | 猎豹加速器官网 | 烧饼哥加速器官网 | 旋风加速器度器 | 哔咔漫画 | PicACG | 雷霆加速