MongoDB对MySQL常用的SQL语句对应的实现
——————————————
MySQL:
SELECT * FROM user
Mongo:
db.user.find()
——————————————
MySQl:
SELECT * FROM user WHERE name = 'foobar'
Mongo:
db.user.find({ 'name' : 'foobar' })
——————————————
MySql:
INSERT INTO user ('name','age') VALUES ('foobar',25)
Mongo:
db.user.insert({ 'name' : 'foobar' , 'age' : 25})
——————————————
如果想增加email这一列
MySql:
ALTER TABLE user ...
Mongo:
db.user.insert({ 'name' : 'foobar' , 'age' : 25 , 'email' : 'foo@bar.com' })
——————————————
MySql:
DELETE * FROM user
Mongo:
db.user.remove({})
——————————————
MySql:
DELETE FROM user WHERE age < 30
Mongo:
db.user.remove({ 'age' : {$lt : 30}})
$gt:> ; $gte:>= ; $lt:< ; $lte:<= ; $ne:!=
——————————————
MySql:
UPDATE user SET `age` = 36 WHERE `name` = 'foobar'
Mongo:
db.user.update({ 'name' : 'foobar'} , {$set : { 'age' : 36}})
——————————————
MySQL:
UPDATE user SET `age` = 'age' + 3 WHERE `name` = 'foobar'
Mongo:
db.user.update({ 'name' : 'foobar'} , {$inc : {'age' : 3}})
——————————————
MySQl:
SELECT COUNT(*) FROM user WHERE `name` = 'foobar'
Mongo:
db.user.find({ 'name' : 'foobar'}).count()
——————————————
MySql:
SELECT * FROM user limit 10,20
Mongo:
db.user.find().skip(10).limit(20)
——————————————
MySQl:
SELECT * FROM user WHERE `age` IN (25,35,45)
Mongo:
db.user.find({ 'age' : {$in : [25,35,45]}})
——————————————
MySql:
SELECT * FROM user ORDER BY age DESC
Mongo:
db.user.find().sort({ 'age' : -1})
——————————————
MySQL:
SELECT DISTINCT(name) FROM user WHERE age > 20
Mongo:
db.user.distinct( 'name',{'age' : {$lt : 20}})
——————————————
MySQL:
SELECT name, sum(marks) FROM user GROUP BY name
Mongo:
db.user.group({
key:{'name':true},
cond:{'name':'foo'},
reduce:function(obj,prev){prev.msum += obj.marks;},
initial:{msum : 0}
})
——————————————
MySQL:
SELECT name FROM user WHERE age < 20
Mongo:
db.user.find('this.age < 20' , {name : 1})
分享到:
相关推荐
一、MongoDB对MySQL常用的SQL语句对应的实现 代码如下: —————————————— MySQL: SELECT * FROM user Mongo: db.user.find() —————————————— MySQl: SELECT * FROM user WHERE ...
作为文档型数据库的代表,MongoDB使用的是BSON(一种类似JSON的二进制形式)格式存储数据,它与传统的关系型数据库如MySQL使用的SQL语言操作方式有所不同。 MongoDB的集合对应于SQL数据库中的表,文档则对应于表中...
本项目"springboot + mybatis +mysql+ sqlserver 双数据源"正是针对这种需求的一个解决方案,它利用SpringBoot框架、MyBatis持久层框架以及MySQL和SQLServer两种数据库,实现了数据源的自动切换,以满足不同业务场景...
1. **Java分页**: 在Java后端,实现分页主要是通过SQL查询语句来控制返回的数据量。例如,使用`LIMIT`和`OFFSET`在MySQL中实现分页,或者在MongoDB中使用`skip()`和`limit()`方法。在Java中,通常会有一个服务层方法...
MySQL是基于ACID(原子性、一致性、隔离性和持久性)原则的关系型数据库,支持标准的SQL查询语言,而MongoDB是非关系型数据库,属于NoSQL类别,以键值对或文档形式存储数据,它更注重灵活性和高扩展性。 1. 数据...
在函数计算中,我们可以使用类似于`pyodbc`这样的Python库,或者其他语言对应的驱动来实现与SQL Server的通信。需要注意的是,由于SQL Server通常运行在Windows环境下,可能需要处理跨平台兼容性问题,如证书验证、...
在MySQL中,查询通常使用SQL语句进行,例如,从user表中查询所有记录,可以使用SELECT * FROM user。在MongoDB中,查询是通过find方法进行的,例如db.user.find(),它返回user集合中所有的文档。对于带条件的查询,...
总结,Python将数据框数据写入MongoDB和MySQL数据库,关键在于将DataFrame转换为数据库能理解的格式(字典或元组),然后使用对应的数据库API进行数据操作。在实际应用中,还需要考虑错误处理、批量插入优化以及...
总之,从MongoDB到MySQL的数据迁移是一项涉及多种技术的任务,包括数据库连接、数据类型转换、SQL语句构造等。这个过程可以锻炼你的编程技能,同时也加深了对两种数据库特性的理解。在实际应用中,这种迁移可能在...
在Mycat 1.3版本中,已经实现了对MongoDB的支持。要配置Mycat以使用MongoDB,你需要进行以下几个步骤: 1. **配置dataHost**:在`conf/schema.xml`文件中,你需要在`<dataHost>`节点下添加一个新的MongoDB连接。...
3. **Laravel与MongoDB集成**:Laravel本身默认支持MySQL等关系型数据库,但通过第三方库可以轻松地与MongoDB集成。例如,Jenssegers/Laravel-MongoDB是一个广泛使用的Eloquent ORM扩展,它为Laravel提供了对MongoDB...
记得为每个数据库(MySQL和MongoDB)创建对应的Repository接口,Spring Data将自动为你生成实现。同时,不要忘记为MyBatis创建Mapper接口和XML映射文件,以便执行自定义的SQL语句。 总之,Spring Boot简化了开发...
然后,创建MySqlCommand对象,设置SQL插入语句,将C#对象中的数据转化为对应的SQL值。最后,调用ExecuteNonQuery方法执行插入操作。 如果在程序中没有MySQL数据库,可以暂时注释掉与数据库相关的代码,只保留JSON...
这个方法虽然多了一步通过MySQL的转换,但能够实现SQLServer数据向MongoDB的迁移。实际操作中,根据具体数据结构和需求,可能还需要进行其他调整,例如处理日期时间格式、自增ID等特殊字段。在迁移过程中,确保备份...
- MySQL的`LIKE`操作符在MongoDB中可以用正则表达式实现,如`db.users.find({name:/Joe/})`和`db.users.find({name:/^Joe/})`。 8. 记录计数: - MongoDB的`db.users.count()`用于获取记录总数,带条件的计数用`....
在IT行业中,数据库管理是至关重要的任务之一,而Navicat作为一款强大的...通过以上步骤,你可以在Navicat中顺利导入SQL文件,实现数据库的快速初始化或迁移。熟练掌握这一技能,对于日常的数据库管理工作将大有裨益。
SQL语句及对应代表性关键字: DDL(数据定义语言):包括create、alter、drop等关键字,用于定义数据库结构。 DML(数据操作语言):包括insert、delete、update等关键字,用于操作数据库中的数据。 DCL(数据控制...
在"Sql Driver java 驱动程序压缩包"中,可能包含了不同版本或类型的Sql Driver实现,比如知名的MySQL Connector/J、Oracle JDBC驱动、Microsoft SQL Server的JDBC驱动等。这些驱动通常以jar文件的形式提供,开发者...
1. 数据库连接的核心:数据库连接驱动包是Kettle与各种数据库进行通信的桥梁,它负责解析和执行SQL语句,实现数据的读取、写入和更新。如果没有匹配的驱动包,Kettle将无法识别和连接到特定的数据库系统,导致操作...