Python操作三大数据库

python MySQL数据库

//查看数据库列表
show databases;
//切换到其中一个
use baidu;
//查看表
show tables;

SQL语法基础

DDL(数据定义语句)

CREATE TABLE/DATABASE
ALTER TABLE/DATABASE
DROP TABLE/DATABASE

DML(数据管理语句)

INSERT 增
DELETE 删
UPDATE 改
SELECT 查

创建并使用数据库
CREATE DATABASE mydatabase;
USE mydatabase;
查看已有数据库
SHOW DATABASES;
建表语句

CREATE TABLE `students`(
    `id` INT NOT NUL AUTO_INCREMENT,
    `name` VARCHAR(200) NOT NULL
);

查询语句

SELECT select_expr,...
FROM table_references
[WHERE where_definition]
[GROUP BY {col_name|expr|position}]
[HAVING where_definition]
[ORDER BY {col_name|expr|position} [ASC|DESC], ...] --排序
[LIMIT {[offset,] row_count}]

修改语句

UPDATE tables_references SET col_name1=expr1[,col_name2=expr2...]
[WHERE where_definition]

删除

DELETE FROM tbl_name
[WHERE where_definition]

例子

CREATE DATABASE `school`;
USE `school`;
CREATE TABLE `students`(
    `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
    `name` VARCHAR(20) NOT NULL,
    `nickname` VARCHAR(20) NULL,
    `sex` CHAR(1) NULL,
    `in_time` DATETIME NULL
) DEFAULT CHARSET 'UTF8';

INSERT INTO `students`(`name`, `nickname` , `sex`) VALUES
    ('张三','三哥','男'),
    ('张三X','三哥X','男'),
    ('张三X1','三哥X1','男'); 
SELECT `id`,`name`,`nickname` FROM `students` WHERE `sex`='男' ORDER BY `id` DESC LIMIT 0,2;
SELECT `id`,`name`,`nickname` FROM `students` WHERE `sex`='男' ORDER BY `id`;
UPDATE `students` SET `sex`='女',`nickname`='没有昵称' WHERE `sex`='男';
UPDATE `students` SET `sex`='男',`nickname`='没有昵称' WHERE `id`>6;
DELETE FROM `students` WHERE `sex`='男';

安装mysql

MySQL ORM --SQLAlchemy

pip install SQLAlchemy --安装
import sqlalchemy --测试
sqlalchemy.version

Python MongoDB

  • 安装
    https://www.mongodb.com/download-center/
    msi版如果安装不成功可以下载zip版直接解压

  • 启动
    Windows: mongod.exe --dbpath D:\MongoDB\DB
    Mac: mongod --config /usr/local/etc/mongod.conf
    Linux: sudo service mongod start

  • 连接数据库
    mongo

  • 查看数据库列表
    show dbs

  • 切换到某个数据库(不需要创建)
    use databasename

  • 插入数据

stu = {
    name:'Jhon',
    age:21
}
db.databasename.insert(stu)
  • 查询数据
    db.students.find()
  • 修改数据
    stu.name = "Amy"
    db.students.update({name:"Jhon",stu})
  • 删除数据
    db.students.update({name:"Amy"})

pymongo

//安装
pip install pymongo
文档:http://api.mongodb.com/python/current/
pypi:https://pypi.python.org/pypi/pymongo
github:https://github.com/mongodb/mongo-python-driver/
//连接数据库
client = MongoClient()
client = MongoClient('localhost',27017)
client = MongoClient('mongodb://localhost:27017/')

MongoDB ODM MongoEngine

pip install mongoengine

flask-mongoengine

pip install flask-mongoengine
文档:http://flask-mongoengine.readthedocs.io/en/latest/

在ubantu服务器上安装mongoDB

https://docs.mongodb.com/manual/tutorial/install-mongodb-on-ubuntu/

sudo vi /etc/apt/sources.list.d/mongodb-org-3.4.list //设置下载镜像
http://mirrors.aliyun.com/mongodb/apt/ubuntu

cat /var/log/mongodb/mongod.log //检查服务是否开启
sudo service mongod start //开启服务
sudo service mongod stop //停止服务
sudo service mongod restart //重启

sudo vi /etc/mongod.conf //打开配置文件,修改默认端口
sudo vi /etc/iptables.up.rules //更改防火墙配置文件中的端口号

//配置远程连接
sudo vi /etc/mongod.conf //配置文件,把 bind_ip=127.0.0.1 修改为 0.0.0.0

Redis数据库

//官网
http://redis.io/
//中文网站
http://www.redis.cn/
//windows
http://github.com/MSOpenTech/redis/releases

String操作

set --设置值
get --获取值
mset --设置多个键对
mget --获取多个键对
append --添加字符串
del --删除
incr/decr --增加/减少1

List列表相关操作

lpush/rpush --从左/右插入数据
lrange --获取指定长度的数据
ltrim --截取一定长度的数据
lpop/rpop --移除最左/最右的元素并返回
lpushx/rpushx --key存在的时候才插入数据,不存在时不做任何处理

Set集合相关操作

sadd/srem --添加/删除元素
sismember --判断是否为set的一个元素
smembers --返回该集合的所有成员
sdiff --返回一个集合与其他集合的差异
sinter --返回几个集合的交集
sunion --返回几个集合的并集

Hash散列相关操作

hset/hget --设置/获取散列值
hmset/hmget --设置/获取多对散列值
hsetnx --如果散列已经存在,则不设置
hkeys/hvals --返回所有Keys/Values
hlen --返回散列包含域(field)的数量
hdel --删除散列指定的域(field)
hexists --判断是否存在

Redis Desktop Manager

官网:https://redisdesttop.com/
Github: https://github.com/uglide

python操作redis

pip install redis
import redis

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • 一、MongoDB简介 概述MongoDB是一个基于分布式文件存储的数据库,由C++语言编写。旨在为WEB应用提供...
    EndEvent阅读 1,163评论 1 4
  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,920评论 2 89
  • 一、MongoDB简介 概述MongoDB是一个基于分布式文件存储的数据库,由C++语言编写。旨在为WEB应用提供...
    未央_m阅读 712评论 0 1
  • 一、MongoDB简介 概述MongoDB是一个基于分布式文件存储的数据库,由C++语言编写。旨在为WEB应用提供...
    王梓懿_1fbc阅读 493评论 0 3
  • 一、数据库系统 数据库DataBase【DB】,指的是长期保存到计算机上的数据,按照一定顺序组织,可以被各种用户或...
    王梓懿_1fbc阅读 508评论 0 0