Mysql总结

1、数据库的概念

"""
数据库:库(文件夹)、表(表结构文件、表数据文件(索引结构))、字段(数据的描述)、记录(数据的本体)
分类:效率问题(内存大于硬盘、非关系大于关系、key-value大于sql)
数据库连接:主机、端口、账号、密码、数据库
"""

2、用户

"""
创建对指定数据库权限的用户:grant 权限们 on 数据库名.表名 to 用户名@主机名 identified by '密码';
"""

3、基本操作

"""
库:创建、删除
表:完整创建表的语法、删除
字段:增alter add、删alter drop、改alter modify
数据:增删改查*****
insert into values|select
delete from
update set
select from
"""

4、单表查询

# sql中几乎所有的操作都是单表操作,多表也会连成单表,临时表也会创建视图

select distinct 字段 from 表 where group by having order by limit

""" distinct
两条几以上所查所有字段形成的记录全部相同,才认为相同
""" """ where和having可以对字段进行的筛选规则
比较:> < = >= <= !=
区间:between and | in | not in
逻辑: and or not
相似:like _%
正则:regexp
自定义区间:id in (2,3) | id not in (2,3) | id < all(2,3) | id < any(2,3)
""" """ group by
尽量对重复率较高的字段进行分组,分组的字段可以直接被查询
分组后只有聚合结果可以参与查询
如果分组情况下,一个字段值全相同,可以直接用max(字段)处理进行查询
联合分组,两个字段组合的综合结果作为分组依据
""" """ order by
升序:order by salary asc
降序:order by salary desc
多个排序条件:order by salary desc, name asc
""" """ limit
limit row
limit offset,row
"""

5、连表

"""
from 左表 inner|left|right join 右表 on 两个表之间的关联条件
inner:都是有用的
left:左边全有
right:右边全有 全连:left union right
"""

6、表关系

"""
外键:外键本身字段不一定唯一,关联字段一定唯一 一对一:外键随意
一对多:外键多一方
多对多:外键关系表中 foreign key(外键字段) references 被关联表(被关联字段)
on update cascade
on delete cascade
"""

7、子查询

"""
查询结果辅助另一条sql的增删改查 子查询一个字段,用一个字段进行筛选
where salary = (select salary from 表) # 结果一条
where salary in (select salary from 表) # 结果多条
where salary > all(select salary from 表) # 结果多条
where salary > any(select salary from 表) # 结果多条
where (dep,salary) in (select dep_name,max_salary from 表)
"""

视图

create view 视图名[(别名1,...,别名n)] as select 字段1,...,字段n from 表

# 视图与真实表共享数据,视图和真实表的数据会相互映射
# 视图的表结构只要存在,真实表的数据只要存在,该视图就可以使用

事务

""" 事务的四大特性
1.原子性:事务是一组不可分割的单位,要么同时成功,要么同时不成功
2.一致性:事物前后的数据完整性应该保持一致(数据库的完整性:如果数据库在某一时间点下,所有的数据都符合所有的约束,则称数据库为完整性的状态)
3.隔离性:事物的隔离性是指多个用户并发访问数据时,一个用户的事物不能被其它用户的事务所干扰,多个并发事务之间数据要相互隔离
4.持久性:持久性是指一个事物一旦被提交,它对数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响
"""

pymysql

"""
# 1)建立数据库连接对象 conn
# 2)通过 conn 创建操作sql的 游标对象
# 3)编写sql交给 cursor 执行
# 4)如果是查询,通过 cursor对象 获取结果
# 5)操作完毕,端口操作与连接
"""
import pymysql
conn = pymysql.connect(user='root', passwd='root', database='oldboy')
cursor = conn.cursor(pymysql.cursors.DictCursor)
sql = '%s %s'
cursor.execute(sql, (参数1,参数2))
cursor.executemany(sql, [(参数1,参数2),(参数1,参数2)]) # 增删改
conn.commit()
conn.rollback() # 查
cursor.fetchone()
cursor.fetchmany(n)
cursor.fetchall() cursor.scroll(num, 'relative|absolute')

索引

# 优化的是查询 不是增删改

mysql小结(了解)的更多相关文章

  1. mysql小结

    1.使用密码登录mysql mysql -u root -p 2.查看所有的数据库 show databases; 3.创建数据库 create database <数据库名>; 4.创建 ...

  2. mysql 小结

    Mariadb proxy maxscale01.test.com maxscale02.test.com Mariadb Galera Cluster db01.test.com db02.test ...

  3. JavaOO小结二,及MySQL小结

    流按照传输内容分有几种?各自的父类是什么? 流按照传输内容有 字节流.字符流.对象流.但其本质都是字节流.字符流和对象流是在字节流基础上作了一层封装,以便更好对字符和对象进行操作. 字节流的父类:In ...

  4. mysql通过mysql_install_db初始化数据目录时使用--user选项的作用是什么?

    需求描述: mysql数据库通过mysql_install_db初始化数据目录时,使用了--user选项,这里记录下该参数的作用 参数解释: 1.--user的作用:就是以哪个操作系统用户来执行mys ...

  5. PHP,mysql,Linux,CI框架学习总结

    PHP,mysql,CI框架学习总结 PHP标记 1.Xml风格<?php ?> 2.简短风格 <? ?> 需在php.ini中开启short_open_tag 3.asp风格 ...

  6. 【MySQL】使用MySQL(连接、选择数据库、显示数据库和表信息)

    第3章 使用MySQL 文章目录 第3章 使用MySQL 连接 选择数据库 了解数据库和表 小结 简单记录 - MySQL必知必会 - [英]Ben Forta 将学习如何连接和登录到MySQL,如何 ...

  7. xtrabackup之Innobackupex增量备份及恢复

    演示增量备份 #启动一个全备 innobackupex \ > --defaults-/my.cnf \ > --host=127.0.0.1 \ > --user=xtrabk \ ...

  8. pymongo学习第1篇——增删改查

    参考文档: 1.https://docs.mongodb.org/getting-started/python/ 2.http://api.mongodb.org/python/current/api ...

  9. 转:攻击JavaWeb应用[3]-SQL注入

    转:http://static.hx99.net/static/drops/tips-236.html 攻击JavaWeb应用[3]-SQL注入 园长 · 2013/07/16 18:28 注:本节重 ...

随机推荐

  1. 第09组 Beta冲刺(3/5)

    队名:观光队 链接 组长博客 作业博客 组员实践情况 王耀鑫 过去两天完成了哪些任务 文字/口头描述 学习 展示GitHub当日代码/文档签入记录 接下来的计划 完成短租车,页面美化 还剩下哪些任务 ...

  2. mnist数据集探究

    一.mnist的属性和方法 为了方便我只检查了后20个属性和方法 from tensorflow.examples.tutorials.mnist import input_data mnist = ...

  3. 【08月01日】A股滚动市净率PB历史新低排名

    2010年01月01日 到 2019年08月01日 之间,滚动市净率历史新低排名. 上市三年以上的公司,2019年08月01日市净率在30以下的公司. 来源:A股滚动市净率(PB)历史新低排名. 1 ...

  4. 书籍推荐-An introduction to Data Science

    为什么要读这本书? 该书是由我们老师推荐的,通过学习此数,可以了解R语言的使用,也可以知道基本的数据分析方法. 看到Creating a Data Set in R -- 24页面

  5. php 500报错解决方案

    php 500报错解决方案 1 先看nginx error.log 指定的错误日记文件路径 找到这个日记文件看 里面信息 2 再看 php-fpm.conf 里面指定的PHP错误日记的路径 具体如下& ...

  6. ShellScript之变量

    Shell脚本之变量学习 ##########################ShellScript初学者,文章摘自菜鸟教程################################ 1.She ...

  7. 订单1:n支付单 设计讨论

    方法一:订单1:1支付单,下单时生成1订单,并生成1支付单(这个支付单是微信需要的相关信息),设置超时时间2小时,如果订单超时,则提示用户,订单已超时,重新下单即可: 方法二:订单1:N支付单,下单时 ...

  8. docker安装mysql8

    docker run --restart=always -d -v /opt/data/conf.d/:/etc/mysql/conf.d/ -v /opt/data/mysql/:/var/lib/ ...

  9. [转] JavaScript数组去重(12种方法)

    数组去重,一般都是在面试的时候才会碰到,一般是要求手写数组去重方法的代码.如果是被提问到,数组去重的方法有哪些?你能答出其中的10种,面试官很有可能对你刮目相看.在真实的项目中碰到的数组去重,一般都是 ...

  10. 易百教程人工智能python补充-NLTK包

    自然语言处理(NLP)是指使用诸如英语之类的自然语言与智能系统进行通信的AI方法. 如果您希望智能系统(如机器人)按照您的指示执行操作,希望听取基于对话的临床专家系统的决策时,则需要处理自然语言. N ...