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. 第01组 Beta冲刺(3/5)

    队名:007 组长博客: https://www.cnblogs.com/Linrrui/p/12008397.html 作业博客: https://edu.cnblogs.com/campus/fz ...

  2. web版聊天功能简单实现

    一.问题 核心点:如何找到要发送的人? 要完成一个功能我觉得首先要分析该功能的逻辑及技术难点,而不是盲目的直接就撸代码,这样非常浪费时间.个人觉得web版聊天功能没什么实际应用场景,以前看过中国移动好 ...

  3. Unity Shader 屏幕后效果——景深

    景深效果的原理是,在摄像机的近裁剪平面和远裁剪平面之间可以设置一个焦距,在这个距离所在的平面上的物体最为清晰,而这个距离之前或之后的物体成像是一种模糊状态(根据距离逐渐模糊,最终达到最为模糊的状态). ...

  4. springmvc和mybatis面试题(含答案)

    Spring MVC Framework有这样一些特点: 1.它是基于组件技术的.全部的应用对象,无论控制器和视图,还是业务对象之类的都是java组件.并且和Spring提供的其他基础结构紧密集成. ...

  5. 如何在 ubuntu 下使用 Windows 里面的字体

    01. 02. 03. 04. 谢谢浏览!

  6. 【JVM】jmap命令详解----查看JVM内存使用详情

    linux获取java进程PID: https://www.cnblogs.com/sxdcgaq8080/p/10734752.html 如果命令使用过程中报错,可能解决你问题的方案: https: ...

  7. 2019-11-29-浅谈-Windows-桌面端触摸架构演进

    原文:2019-11-29-浅谈-Windows-桌面端触摸架构演进 title author date CreateTime categories 浅谈 Windows 桌面端触摸架构演进 lind ...

  8. NoSQL之redis用法

    什么是NoSQL? 泛指非关系型的数据库 不支持SQL语法 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是Key-Value(即键值对关系)形式 NoSQL的世界中没有一 ...

  9. Oracle数据库触发器

    第一次写触发器,浪费了一个小时,少了一个;编译不通过 当A表有更新或插入数据时,则触发器执行向B表插入对应条件的数据1 CREATE OR REPLACE TRIGGER Test -- 触发器名称 ...

  10. C# Socket服务器及多客户端连接示例

    服务端代码[控制台示例] static List<Socket> Sockets = new List<Socket>(); static void Main(string[] ...