mysql的student是什么意思_复习mysql

一、复习详尽如下:

创建一个test库

create database test;

授权一个用户

grant all privileges on *.* to 'xiang'@'%' identified by '1qaz@WSX';

创建表

create table student(id int not null);

查询

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

增加

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

update table_name set id=10 where 条件判断

删除

delete from table_name where 条件判断

drop table table_name

联合查询

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

创建索引

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

查看sql是否走索引

explain select * from student where name='ling'

链接数据库

Python2 使用的是MySQLdb

python3 使用的pymysql pip安装

1. 创建链接和游标

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

conn = pymysql.connect(host='', port=, user='', passwd='', db='')

cus = conn.curse()

2. 实行sql

sql = "select * from Student;"

cus.execute(sql)

cus.fetchone() 获取单个 返回值 tuple

cus.fetchall() 获取多个 返回值 list(单个元素是tuple)

cus.fetchmany(size=n) 获取多个

3. 关闭游标和连接

cus.close()

conn.close()

注意结合try exception finally的使用

SQLAlchemy

1. 创建引擎

engine = create_engine('mysql+pymysql://username:password@hostname:port/db')

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')

select * from student where name like '%ling%';

模糊查询含有ling的关键字

模糊查询

session.query(Student).filter(Student.name like('%ling%'))

获取数据的时候有两个方法:

one() tuple

all() list(单个元素是tuple)

如果在查询中不写one(), 或者all() 出来的就是sql语句

6. 更新

1. 先查出来

2. 跟新一下类所对应的属性值就ok

3. 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()

统计有多少个

分组:group_by

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

二、课堂案例如下

from sqlalchemy import create_engine, Integer, String, Column

from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy.orm import sessionmaker

Base = declarative_base()

class Student(Base):

__tablename__ = 'student'

id = Column(Integer, primary_key=True)

name = Column(String(100))

age = Column(Integer)

address = Column(String(100))

def update(session):

student1 = session.query(Student).filter(Student.id == 1001).one()

student1.name='test123'

session.commit()

student2 = session.query(Student).filter(Student.id == 1001).one()

print(student2.name)

def delete(session):

session.query(Student).filter(Student.id == 1001).delete()

session.commit()

def insert(session):

student1 = Student(id=1004, name='ling', age=28, address='shanxi')

session.add(student1)

session.commit()

def count(session):

numnber = session.query(Student).filter().count()

print("total student is {0}".format(numnber))

def groupBy(session):

groupByAge = session.query(Student).group_by(Student.age).all()

print(groupByAge)

for i in groupByAge:

print(i.id, i.name, i.age, i.address)

def orderBy(session):

orderByAge = session.query(Student).order_by(Student.age.desc()).all()

for x in orderByAge:

print(x.id, x.name, x.age, x.address)

def main():

engine = create_engine('mysql+pymysql://xiang:xiang@192.168.48.136/sqlalchemy')

DBsession = sessionmaker(bind=engine)

session = DBsession()

# insert(session)

# update(session)

# delete(session)

# count(session)

# groupBy(session)

orderBy(session)

if __name__ == '__main__':

main()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/429386.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法复杂度的理解

算法复杂度的理解 from:http://blog.sina.com.cn/s/blog_4bab8e7f0102vmth.html算法复杂度分为时间复杂度和空间复杂度。 时间复杂度的计算 ​1.一个算法执行所耗费的时间&#xff0c;从理论上是不能算出来的&#xff0c;必须上机运行测试才能知道。但我们不可能也没有必要对每…

php如何将mysql数据库中的admin字段赋值给session_php实现将Session写入数据库

/**author Fahy*数据库为mysql&#xff0c;*数据库名为session&#xff0c;表名为session&#xff0c;*表中字段包括PHPSESSID,update_time,client_ip,data*/class Session{private static $handler null;private static $ip null;private static $lifetime null;private st…

linux 脚本 java_Linux 通过脚本执行Java程序

由于要统计不同的IP&#xff0c;代码中应用了HashSet来存放IP地址。上述Java程序是在Windows下编写的&#xff0c;如果在Linux服务器上运行&#xff0c;只需要把上面文件的路径和文件更换了就可以了。2.编写好java程序后&#xff0c;将java程序打成jar文件(环境Linux)我将上述测…

Java开启/关闭tomcat服务器

© 版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请注明出处 通过java代码实现Tomcat的开启与关闭 1.项目结构 2.CallTomcat.java package com.calltomcat.test;import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader;…

python命令行调试django代码_Django shell调试models输出的SQL语句方法

在settings.py里&#xff0c;配置如下logging&#xff1a;LOGGING {version: 1,disable_existing_loggers: False,handlers: {console:{level:DEBUG,class:logging.StreamHandler,},},loggers: {django.db.backends: {handlers: [console],propagate: True,level:DEBUG,},}}使…

5、如何快速找到多个字典中的公共键(key) 6 如何让字典保持有序 7 如何实现用户的历史记录功能(最多n条)...

5、如何快速找到多个字典中的公共键(key) from random import randint,sample #随机取数 # a sample("ABCDEF",randint(5,6)) # print(a) # b1 {x:randint(1,4) for x in sample("ABCDEF",randint(3,6))} # b2 {x:randint(1,4) for x in sample("A…

Bresenham画椭圆算法

这里不仔细讲原理&#xff0c;只是把我写的算法发出来&#xff0c;跟大家分享下&#xff0c;如果有错误的话&#xff0c;还请大家告诉我&#xff0c;如果写的不好&#xff0c;也请指出来&#xff0c;一起讨论进步。 算法步骤: (1) 输入椭圆的长半轴a和短半轴b。 (2) 计算初始值…

iOS MD5 (消息摘要算法5)

一、MD5定义 MD5即Message-Digest Algorithm 5&#xff08;消息-摘要算法5&#xff09;&#xff0c;为计算机安全领域广泛使用的一种散列函数&#xff0c;用以提供消息的完整性保护&#xff08;又译摘要算法、哈希算法&#xff09;&#xff0c;主流编程语言普遍已有MD5实现。…

“每日一道面试题”.Net中所有类的基类是以及包含的方法

闲来无事&#xff0c;每日一贴。水平有限&#xff0c;大牛勿喷。 .Net中所有内建类型的基类是System.Object毋庸置疑 Puclic Class A{}和 Public Class A&#xff1a;System.Object{}是等效的 System.Object包含了Finalize在内的8个方法。 公共实例方法&#xff1a; Virtual b…

JAVA怎么将整数反转_【leetcode刷题】[简单]7.反转整数(reverse integer)-java

反转整数 reverse integer题目给定一个 32 位有符号整数&#xff0c;将整数中的数字进行反转。示例 1:输入: 123输出: 321示例 2:输入: -123输出: -321示例 3:输入: 120输出: 21注意:假设我们的环境只能存储 32 位有符号整数&#xff0c;其数值范围是 [− 2^31, 2^31 − 1]。根…

Linux实战案例(2)实例讲解使用软连接的场景和过程

使用场景&#xff1a;使用软连接简化版本切换动作 进入操作目录&#xff0c; cd /opt/modules/ 1、创建软连接ln -s jdk1.8.0_131 jdk1.8ln -s spark-2.1.0-bin-hadoop2.7 sparkln -s hadoop-2.7.3 hadoop 2、删除软连接rm -rf hadooprm -rf sparkrm -rf jdk1.8 3、验证结果 …

java单车吧_暑假一个月,撸个共享单车后台

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼加解密差不多了&#xff0c;下一步开始写登录了。//先对称加密 key 和数据String key "j783420jfjyqalgr";String data "周"; // FBI通缉人 周String encrypt AESUtil.encrypt(data, key); // 向服务器传输…

KVM虚拟化技术之使用Qemu-kvm创建和管理虚拟机

一 .KVM 简介 KVM &#xff08;名称来自英语&#xff1a; Kernel-basedVirtual Machine 的缩写&#xff0c;即基于内核的虚拟机&#xff09; &#xff0c; 是一种用于Linux内核中的虚拟化基础设施&#xff0c;可以将Linux内核转化为一个hypervisor。KVM在2007年2月被导入Li…

java序列化写法_java-spark的各种常用算子的写法

通常写spark的程序用scala比较方便&#xff0c;毕竟spark的源码就是用scala写的。然而&#xff0c;目前java开发者特别多&#xff0c;尤其进行数据对接、上线服务的时候&#xff0c;这时候&#xff0c;就需要掌握一些spark在java中的使用方法了一、mapmap在进行数据处理、转换的…

python 如何在一个for循环中遍历两个列表

是我在看《笨方法学python》过程中发现有一行代码看不懂——“ for sentence in snippet, phrase:”&#xff0c;所以研究了半天&#xff0c;感觉挺有收获的。所以就放在博客上分享给大家了。 直入主题&#xff1a; 为了不耽误大家时间&#xff0c;如果知道以下为两段代码为什么…

画王八java代码参数_java画乌龟源代码-郭遥航.doc

java画乌龟源代码-郭遥航.doc /*JAVA基本功小练习用java语言描述小王八用鼠标可以拖动小乌龟进行移动选中乌龟时可以显示小乌龟的腹面*/importjava.awt.*;importjavax.swing.*;importjava.awt.event.MouseMotionListener;importjava.awt.event.MouseListener;importjava.awt.ev…

Longest Substring With At Most K Distinct Characters

Given a string, find the length of the longest substring T that contains at most k distinct characters. For example, Given s “eceba” and k 2, T is "ece" which its length is 3. Analyses: Map each character in the string into a index in an arra…

java不同环境_Spring Boot系列 – 5. 不同的环境使用不同的配置

SpringBoot系列-5.不同的环境使用不同的配置数据库spring boot中&#xff0c;可以通过在application.yml配置文件中&#xff0c;配置多个不同的profile&#xff0c;实现在不同的环境(比如开发、测试和生产环境)使用不同的配置变量。具体配置如下(application.yml中的内容)&…

SQL Server的WAITFOR DELAY注入

SQL Server的WAITFOR DELAY注入WAITFOR是SQL Server中Transact-SQL提供的一个流程控制语句。它的作用就是等待特定时间&#xff0c;然后继续执行后续的语句。它包含一个参数DELAY&#xff0c;用来指定等待的时间。如果将该语句成功注入后&#xff0c;会造成数据库返回记录和Web…

java服务注册中心有哪些_Spring Cloud服务注册中心简述

概念当一个大型系统拥有很多服务时&#xff0c;往往需要一个服务注册中心来管理这些服务&#xff0c;它可以提供如下功能&#xff1a;登记每个服务提供的功能检测每个服务是否可用&#xff0c;不可用的服务剔除服务间互相调用时&#xff0c;通过服务注册中心很容易找到目标服务…