热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python基础——mysql数据库、SQLAlchemy

python,基础,mysql,数据库,

一、MySQL常用操作

1、创建库

create database test;

2、创建表

create table student(id int not null);

3、授权一个用户

grant all privileges on *.* to 'username'@'%' identified by 'passwd'; 其中%通配所有地址

4、查询

select * from tabel_name where 条件1 and 条件2;

5、增加数据

insert into table_name (id, name, age, sex, grander) values (1, 'jsh', 25, 'M', 99), (2, 'Tom', 45, 'F', 88);

6、删除数据

delete from table_name where 条件判断; drop table table_name; 删除表

7、改数据(更新数据)

update table_name set id=10 where 条件判断;

8、联合查询

select a.id, b.name from A a join B b on a.id=b.tid;

9、创建索引

create index idx_库名_表名_列名1_列名2 或 (列名1, 列名2)

10、查看SQL是否走索引

explain select * from student where name='JSH'

二、MySQL 数据库连接

1、Python2  使用mysqldb                      python3 使用 pymysql

2、创建链接  和 游标

     在mysql连接中,尽量使用一个连接,确保mysql的并发数

cOnn= pymysql.connect(host='', port=, user='', passwd='', db='') # cus = conn.curse()

3、执行MySQL语句

sql = "select * from Student;" # cus.execute(sql) # cus.fetchone() 获取单个 返回值 tuple # cus.fetchall() 获取多个 返回值 list(单个元素是tuple) # cus.fetchmany(size=n) 获取多个

4、关闭游标  和  链接

     注意结合try exception finally的使用

cus.close() conn.close()

三、SQLAlchemy (对象关系映射)

1、创建引擎

engine = create_engine('mysql+pymysql://root:123456@192.168.6.137/sqlalchemy',echo=True)

2、创建session

DBsession = sessionmaker(bind=engine) session = DBsession()

3、创建表

a. 获得engine b. metadata = MetaData(engine) c. student = Table('表名', metadata, Colume('id', Integer, primary_key=True), Colume('name', String(50)) d. metadata.create_all()

4、增加数据

a. 先要有一个模型 Base = declarative_base(0 class Student(Base): __tablename__ = 'student' id = Column(Integer, primary_key=True) name = Column(String(100), primary_key=True) b. 导入模型类,实例化该类, sutdent1 = Student(1, 'ling') c. session.add(单实例) session.add_all([实例1, 实例2])

5、查询

# filter和filter_by的区别 # filter:可以使用> <等,但是列必须是: 表.列, filter的等于号是== session.query(Student).filter(Student.id>100) # filter 不支持组合查询 session.query(Student).filter(Studnet.id>100).filter(name='ling') # filter_by: 可以直接写列,不支持<> filter_by 等于是== session.query(Student).filter_by(id==10) # filter_by 可以支持组合查询 session.query(Student).filter_by(name='ling' and id='342') # 模糊查询含有ling的关键字 select * from student where name like '%JSH%'; # 模糊查询 # session.query(Student).filter(Student.name.like('%JSH%')) # 获取数据的时候有两个方法: # one() 获取到的数据为 tuple # all() 获取到的数据为 list(单个元素是tuple) # 如果在查询中不写one(), 或者all() 得到的就是sql语句

6、更新

1. 先查出来 2. 跟新一下类所对应的属性值就ok session.commit() student1 = session.query(Student).filter(Student.id=1001) student1.name = "test" session.commit()

7、删除

# 1. 先查出来 # 2. 直接调用delete()方法就可以 # 3. 提交一下

8、统计count() 分组

# 只需要在查出来以后, 把one或者all替换成count()

9、分组 group_by

    查出来以后,把one或者all替换成group_by(属性)


推荐阅读
  • 三周学会小程序第七讲:提交问题
    截止到上一讲可以支持数据库存储了,所以这一讲开始讲解怎么从小程序发布一个问题并存储到服务器端。下面简单罗列一下本讲的知识点。对了老规矩,文末附源码。对小 ... [详细]
  • 我想从message_id(int类型)取最大值,用这条语句selectmax(message_id)asmaxidfrommessage出现一下错误[Microsoft][SQLS ... [详细]
  • 本文目录一览:1、基于jsp的图书管理系统的设计与实现的源代码 ... [详细]
  • 在MySQL中,LOAD_FILE()函数读取一个文件并将其内容作为字符串返回。语法LOAD_FILE(file_name)其中file_name是文件的完整路径。下面是我从一个文件中选择内容的示例:SELECTLOAD_FILE( ... [详细]
  • 图基本概念及操作
    图基本概念及操作一、思维导图二、重要概念笔记1.图的定义图(Graph)G由顶点集合V(G)和边集合E(G)构成。图可分为有向图和无向图。2.图的存储结构一、邻接矩阵:二、邻接表; ... [详细]
  • <selectnameBigClassName><optionvalue>请选择一级分类& ... [详细]
  • SpringMvc组件初始化
    SpringMVC9大组件初始化由上面的断点流程,可以看出来其实是在spring容器初始化完成的最后一步,通过发送event事件@Overridepublicvoidpublish ... [详细]
  • 一、数据库并发测试的必要性1、与数据库连接的服务程序采用多线程同时开启多个数据库连接;2、与数据库连接的服务程序单线程,但是同时开启多套服务程序 ... [详细]
  • 首先:新建一个sequence,定义好起始值,增值大小,最大值即可。一般自增用到从1开始自增为1的居多。假定新建的sequence名字为:MY_SEQ其次: ... [详细]
  • Hibernate的入门:
    1下载Hibernate5http:sourceforge.netprojectshibernatefileshibernate-orm5.0.7.Finalhibernate-r ... [详细]
  • (1)选择最有效率的表名顺序(只在基于规则的优化器中有效):ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名, ... [详细]
  • 如何处理为ListView显示空视图的问题,因为当我从Firebase数据库读取数据并将其显示在ListView中时,我不知道要放入哪些数据.我正在使用CustomListAdapter更改字体 ... [详细]
  • 前面:链表的排序参考:链表的排序-冒泡,简单选择,插入排序,归并,快排——以leetcode14 ... [详细]
  • 设计模式:闲谈单例模式
    大家可能都看过单例模式的几种写法,其中饿汉式最简单,懒汉式中双重check最为复杂。双重che ... [详细]
  • 很多时候,在项目中需要打单子,生成pdf格式,还需要盖章。这个时候,就需要对pdf文件进行再次处理。处理的方式就是:1、获取要处理的位置2、将要盖章的图片添加上去代码如下:publ ... [详细]
author-avatar
V陈冬梅_717
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有