mysql数据库和mongodb数据库的相关操作以及两个数据库的区别

 

在docs命令中执行数据操作

 

MySQL数据库

先启动MySQL服务器  net start mysql

进入MySQL服务器MySQL -uroot -p(这里写你的数据库密码) (-P是从哪个端口进)

我第一次操作是就是因为电脑上 有 MySQL  MySQL57 MySQLla 三个服务 引起端口冲突

导致 我 找不到相应的数据

数据库操作

create database   创建数据库

show databases   显示MySQL服务上的数据库

use  数据库          使用数据库

数据表操作

create table  表名()  创建数据表   

例如  create table  user(id int,name char,age int)  

desc   表名            获取表的结构

show tables          显示当前数据库中的 表

drop table  表名    删除数据表

rename  table 原表名 to 新表名   修改数据表的名称

表中数据操作

insert into userone (id,name) values (1,"bbb");   添加数据

select * from 表名;                                               查询数据表中的全部数据

select username from  userone;                         查询一列

select * from userone username="avc";              按条件查询  查询一条数据

update userone set password="qqq" where username="111";       更新某一条数据数据

delete from userone where username="111";      删除某一条数据

 

mongodb数据库

要使用mongodb数据库 首先要

安装 mongodb 数据库

npm install mongodb

启动mongodb服务

net start mongodb 

进入 mongodb数据库

mongo

 

show dbs          显示mongodb中的所有数据库

use 数据库名    创建数据库 

db.dropDatabase(数据库名字)    删除数据库 

db                     查看当前的数据库

 

db.createCollection("数据库名称")   创建集合

show tables/collections       显示集合

db.集合名称.drop()             删除集合

 

db.person.insert({"name":"gg","age":12});  插入数据】

db.person.save({"name":"aa","age":12})    插入数据    如果插入当前集合id值相同的  save  不会报错   而insert会报错

db.person.remove({内容})               删除数据

db.person.find()                              查询当前集合所有的数据

db.person.find({"age":{$lt:12}})       带符号的 查询      大于 $gt  小于 $lt   不等于$ne  

小于或等于$lte     大于或等于   $gte  

 

db.person.update({条件},{内容},true,false)     更新数据

 

带修改器的更新文档

   db.person.update({条件},{$set:{内容},true,true})

第三个true 如果没有查询条件的数据  执行插入的操作

第四个 true 批量修改  false反之

$inc 用于数字类型 可以为指定键对应的值进行加减操作 

 

mongodb与mysql相比的优缺点

与关系型数据库相比,MongoDB的优点:

①弱一致性(最终一致),更能保证用户的访问速度:

举例来说,在传统的关系型数据库中,一个COUNT类型的操作会锁定数据集,这样可以保证得到“当前”情况下的精确值。这在某些情况下,例 如通过ATM查看账户信息的时候很重要,但对于Wordnik来说,数据是不断更新和增长的,这种“精确”的保证几乎没有任何意义,反而会产生很大的延 迟。他们需要的是一个“大约”的数字以及更快的处理速度。

②文档结构的存储方式,能够更便捷的获取数据。

对于一个层级式的数据结构来说,如果要将这样的数据使用扁平式的,表状的结构来保存数据,这无论是在查询还是获取数据时都十分困难。

③内置GridFS,支持大容量的存储。

  GridFS是一个出色的分布式文件系统,可以支持海量的数据存储。  内置了GridFS了MongoDB,能够满足对大数据集的快速范围查询。④内置Sharding。提供基于Range的Auto Sharding机制:一个collection可按照记录的范围,分成若干个段,切分到不同的Shard上。

⑤第三方支持丰富。(这是与其他的NoSQL相比,MongoDB也具有的优势)

现在网络上的很多NoSQL开源数据库完全属于社区型的,没有官方支持,给使用者带来了很大的风险。而开源文档数据库MongoDB背后有商业公司10gen为其提供供商业培训和支持。
而且MongoDB社区非常活跃,很多开发框架都迅速提供了对MongDB的支持。不少知名大公司和网站也在生产环境中使用MongoDB,越来越多的创新型企业转而使用MongoDB作为和Django,RoR来搭配的技术方案。

⑥性能优越:

在使用场合下,千万级别的文档对象,近10G的数据,对有索引的ID的查询不会比mysql慢,而对非索引字段的查询,则是全面胜出。 mysql实际无法胜任大数据量下任意字段的查询,而mongodb的查询性能实在让我惊讶。写入性能同样很令人满意,同样写入百万级别的数 据,mongodb比我以前试用过的couchdb要快得多,基本10分钟以下可以解决。补上一句,观察过程中mongodb都远算不上是CPU杀手。

与关系型数据库相比,MongoDB的缺点:

①mongodb不支持事务操作。  

所以事务要求严格的系统(如果银行系统)肯定不能用它。(这点和优点①是对应的)

②mongodb占用空间过大。

  关于其原因,在官方的FAQ中,提到有如下几个方面:
1、空间的预分配:为避免形成过多的硬盘碎片,mongodb每次空间不足时都会申请生成一大块的硬盘空间,而且申请的量从64M、128M、256M那 样的指数递增,直到2G为单个文件的最大体积。随着数据量的增加,你可以在其数据目录里看到这些整块生成容量不断递增的文件。

2、字段名所占用的空间:为了保持每个记录内的结构信息用于查询,mongodb需要把每个字段的key-value都以BSON的形式存储,如果 value域相对于key域并不大,比如存放数值型的数据,则数据的overhead是最大的。一种减少空间占用的方法是把字段名尽量取短一些,这样占用 空间就小了,但这就要求在易读性与空间占用上作为权衡了。我曾建议作者把字段名作个index,每个字段名用一个字节表示,这样就不用担心字段名取多长 了。但作者的担忧也不无道理,这种索引方式需要每次查询得到结果后把索引值跟原值作一个替换,再发送到客户端,这个替换也是挺耗费时间的。现在的实现算是 拿空间来换取时间吧。

3、删除记录不释放空间:这很容易理解,为避免记录删除后的数据的大规模挪动,原记录空间不删除,只标记“已删除”即可,以后还可以重复利用。

4、可以定期运行db.repairDatabase()来整理记录,但这个过程会比较缓慢

③MongoDB没有如MySQL那样成熟的维护工具,这对于开发和IT运营都是个值得注意的地方。

 

 

 

转载于:https://www.cnblogs.com/calledspeed001/p/7100614.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是使用MongoDBMySQL实现数据库双写的示例: 1. 使用MongoDB进行写操作: ``` // 导入MongoDB驱动程序 const MongoClient = require('mongodb').MongoClient; // 定义MongoDB连接字符串和数据库名称 const url = 'mongodb://localhost:27017/'; const dbName = 'mydb'; // 连接MongoDB数据库 MongoClient.connect(url, function(err, client) { if (err) throw err; // 获取MongoDB数据库对象 const db = client.db(dbName); // 向MongoDB数据库写入数据 const collection = db.collection('mycollection'); collection.insertOne({name: 'John', age: 30}, function(err, result) { if (err) throw err; console.log('MongoDB write success'); }); // 关闭MongoDB数据库连接 client.close(); }); ``` 2. 使用MySQL进行写操作: ``` // 导入MySQL驱动程序 const mysql = require('mysql'); // 定义MySQL连接参数 const connection = mysql.createConnection({ host: 'localhost', user: 'root', password: 'password', database: 'mydb' }); // 连接MySQL数据库 connection.connect(function(err) { if (err) throw err; // 向MySQL数据库写入数据 const sql = "INSERT INTO mytable (name, age) VALUES ('John', 30)"; connection.query(sql, function (err, result) { if (err) throw err; console.log("MySQL write success"); }); // 关闭MySQL数据库连接 connection.end(); }); ``` 以上代码示例演示了如何在MongoDBMySQL进行写操作,这两个数据库都支持数据双写。但需要注意的是,双写操作需要保证数据一致性,即当一种数据库写入失败时,另一种数据库也应该将其相应的写操作回滚。 ### 回答2: MongoDBMySQL数据库双写示例是指在使用这两种数据库时,同时对两个数据库进行写操作。 假设有一个电商平台,用户在平台上下单购买商品。在这种场景,我们可以使用MySQL作为主要数据库,其包含商品信息、用户信息、订单信息等。而MongoDB则可以用作辅助数据库,用于存储一些非结构化的数据,如用户的评论、浏览历史等。 当用户下单购买商品时,首先会在MySQL创建一个新的订单,并更新相关的库存信息。同时,在MongoDB也会插入一条记录,记录用户的订单信息,以方便后续的数据分析和用户画像。 当订单信息发生变化时,如订单状态更新、发货等操作,同样需要在MySQL进行相应的更新,以确保订单信息的准确性和一致性。同时,也需要在MongoDB进行相应的更新,保持MongoDB的数据与MySQL同步。 这样做的好处在于,MySQL适用于更稳定和结构化的数据存储,而MongoDB则更适合存储一些非结构化或动态变化的数据。通过对两个数据库的双写操作,可以在满足业务需求的同时,保持数据的一致性和完整性。 需要注意的是,双写操作需要花费更多的资源和时间,因为需要同时写入两个数据库。因此,在设计数据库架构时,需要权衡业务的实时性和数据的一致性,选择合适的策略来实现数据库的双写。 ### 回答3: MongoDBMySQL是两种不同类型的数据库系统。MongoDB是一种基于文档的NoSQL数据库,而MySQL是一种关系型数据库。 当需要在MongoDBMySQL之间进行数据库双写时,需要考虑以下几个方面: 1. 数据同步:在双写过程,需要确保MongoDBMySQL的数据是同步的。可以使用数据同步工具来实现这一点,例如使用Mongo Connector来实时同步MongoDBMySQL之间的数据。 2. 数据转换:由于MongoDBMySQL采用不同的数据模型,需要进行数据转换。可以使用ETL工具(例如Apache Nifi或Talend)将MongoDB的文档转换为适合MySQL的结构,并进行适当的数据类型转换。 3. 冲突解决:在双写过程,可能会发生数据冲突的情况,即在MongoDBMySQL同时对同一数据进行修改。解决冲突可以采取如下策略之一:在每次写入时使用乐观锁进行检查和更新,使用时间戳来判断最新数据并进行处理,或者采用分布式锁机制。 4. 故障恢复:在双写过程,如果其一个数据库发生故障,需要能够进行故障恢复,以确保数据的一致性和可用性。可以配置监控和自动故障转移机制,例如使用MongoDB的副本集或MySQL的主从复制。 总的来说,MongoDBMySQL之间的数据库双写需要进行数据同步、数据转换、冲突解决和故障恢复等方面的处理。这些措施可以保证数据的一致性和可用性,使得在MongoDBMySQL之间实现双写变得可行和可靠。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值