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. scss 入门基础

    在一个项目中,样式是必不可少的一部分,而对于一个完整的项目来说是有个基准色调的.在项目需求变化不大的情况下,可以直接在css中写这些颜色值之类的东西.但是如果遇到一个朝令夕改的领导或者甲方,那会变得相 ...

  2. 原创|强大!Nginx 配置在线一键生成“神器”

    Nginx作为一个轻量级的HTTP服务器,相比Apache优势也是比较明显的,在性能上它占用资源少,能支持更高更多的并发连接,从而达到提高访问效率;在功能上它是一款非常优秀的代理服务器与负载均衡服务器 ...

  3. 在 Vue 中使用 装饰器 Decorator

    Decorator 的语法还没有通过提案,所以项目中很少用.不过最近刚好有一个需求用到了. 装饰器的语法 http://es6.ruanyifeng.com/#docs/decorator 需求是,有 ...

  4. Java软件生产监控工具Btrace的使用

    Btrace BTrace是sun公司推出的一款Java 动态.安全追踪(监控)工具,可以在不用重启的情况下监控系统运行情况,方便的获取程序运行时的数据信息,如方法参数.返回值.全局变量和堆栈信息等, ...

  5. swagger Unable to render this definition

    Unable to render this definition The provided definition does not specify a valid version field. Ple ...

  6. java8 List集合的排序,求和,取最大值,按照条件过滤

    public class Java8Test {       public static void main(String[] args) {           Person p1 = new Pe ...

  7. 一个 Github 上使用 HttpClient 的 Sample

    地址:https://github.com/MikeWasson/HttpClientSample 截图: 直接贴代码了: 服务端: [RoutePrefix("api/products&q ...

  8. Wait… What Happens When my React Native Application Starts? — An In-depth Look Inside React Native

    Discover how React Native functions internally, and what it does for you without you knowing it. Dis ...

  9. 解密“CDO-首席数据官”的价值、挑战及发展

    数据,不论形态.格式和类型,已经迅速成为企业最有战略意义的资产:数据资产已经成为了可以形成业务洞察及优势的战略资源,数据的体量.多样性和复杂性也正以指数级增长.就像其他重要的企业资产,数据需要适当的管 ...

  10. c#实现串口通信

    参考文章:https://www.cnblogs.com/Zed-H/p/8651882.html 利用虚拟串口软件连接两个虚拟串口,如图连接6,7: 打开串口进行通信如下: