获取2天前的
DATE_SUB(NOW(),INTERVAL 2 DAY)
2天后
DATE_ADD(OrderDate,INTERVAL 2 DAY)
参考:http://www.w3school.com.cn/sql/func_date_sub.asp
注:只为个人参考用,详情请看W3school
获取2天前的
DATE_SUB(NOW(),INTERVAL 2 DAY)
2天后
DATE_ADD(OrderDate,INTERVAL 2 DAY)
参考:http://www.w3school.com.cn/sql/func_date_sub.asp
注:只为个人参考用,详情请看W3school
问题:想复制users表中的id到users表中的student_id,并在前面添加‘st00’
方法:update users set student_id=concat('st00',id) where id >0;
典型的NoSQL数据库通常包含键值数据库,列族数据库,文档数据库
键值数据库:redis
http://it.xiaomantu.com/web/mysql/redis/
列族数据库:HBase
http://it.xiaomantu.com/web/cloud/368.html
文档数据库:MangoDB
http://it.xiaomantu.com/web/cloud/371.html
问题:文档数据库MongoDB的基本操作(shell命令)
方法:
1、增加
db.student.insert({_id:1, sname: 'zhangsan', sage: 20}) #_id可选
db.student.save({_id:1, sname: 'zhangsan', sage: 22}) #_id可选
这两种方式,其插入的数据中_id字段均可不写,会自动生成一个唯一的_id来标识本条数据。而insert和save不同之处在于:在手动插入_id字段时,如果_id已经存在,insert不做操作,save做更新操作;如果不加_id字段,两者作用相同都是插入数据。
2、查询
db.student.find() #查询所有记录。相当于:select * from student
db.student.find({sname: 'lisi'}) #查询sname='lisi'的记录。相当于: select * from student where sname='lisi'
db.student.find({},{sname:1, sage:1}) #查询指定列sname、sage数据。相当于:select sname,sage from student。sname:1表示返回sname列,默认_id字段也是返回的,可以添加_id:0(意为不返回_id)写成{sname: 1, sage: 1,_id:0},就不会返回默认的_id字段了
db.student.find({sname: 'zhangsan', sage: 22}) #and 与条件查询。相当于:select * from student where sname = 'zhangsan' and sage = 22
db.student.find({$or: [{sage: 22}, {sage: 25}]}) #or 条件查询。相当于:select * from student where sage = 22 or sage = 25
3、修改
db.student.update({sname: 'lisi'}, {$set: {sage: 30}}, false, true) #相当于:update student set sage =30 where sname = 'lisi';
注:第三个参数false表示 如果不存在sname='list'的记录,则不插入sage=30这条记录,改为true时表示插入,默认是false。
4、删除
db.student.remove({sname: 'chenliu'}) #相当于:delete from student where sname='chenliu'
db.student.drop() # 删除集合
5、拓展
show dbs #显示数据库列表
show collections #显示当前数据库中的集合(类似关系数据库中的表table)
show users #显示所有用户
use School #切换到School数据库。MongoDB 无需预创建School数据库,在使用时会自动创建
db.createCollection('teacher') #创建一个聚集集合。MongoDB 其实在插入数据的时候,也会自动创建对应的集合,无需预定义集合
db.help():显示数据库操作命令
db.teacher.help():显示集合操作命令,teacher是集合名
问题:HBase数据库的基本shell操作:增、删、改、查
方法:
1、增加
put ‘student’,’95001’,’Sname’,’LiYing’时,即为student表添加了学号为95001,名字为LiYing的一行数据,其行键为95001。
put 'student','95001','course:math','80'
2、查询
get命令,用于查看表的某一行数据:
get 'student','95001'
scan命令用于查看某个表的全部数据:
scan 'student'
3、删除
delete用于删除一个数据,是put的反向操作:
delete 'student','95001','Ssex'
deleteall操作用于删除一行数据:
deleteall 'student','95001'
4、修改
HBase会自动为添加的数据添加一个时间戳,故在需要修改数据时,只需直接添加数据,HBase即会生成一个新的版本,从而完成“改”操作,旧的版本依旧保留,系统会定时回收垃圾数据,只留下最新的几个版本,保存的版本数可以在创建表的时候指定。
put 'student','95001','course:math','82'
5、查询数据库中的表有哪些
直接list命令就可以查看所建立的表
6、删除数据表
disable 'student'
drop 'student'