周结七

  • 线程理论

进程:进程其实是资源单位 表示一块内存空间

线程:线程才是执行单位 表示真正的代码指令

  1. 一个进程可以开设多个进程
  2. 同一个进程下的多个进程数据是共享的
  3. 创建进程的与线程的区别:创建进程的消耗要远远大于线程
  • 创建线程的两种方式

from threading import Thread
import time
方式一:
# def task(name):
#     time.sleep(1)
#     print(f'我的名字是{name}')
#
# t = Thread(target=task, args=('jason',))
# t.start()
# print('主线程')

方式二:
class MyTread(Thread):
    def __init__(self,name):
        super().__init__()
        self.name = name
    def run(self):
        time.sleep(1)
        print(f'你的名字叫{self.name}')


t1 = MyTread('tony')
t1.start()
print('主子')
  • GIL全局解释器锁

  1. 在python中解释器中存在全局解释器锁简称GIL

    python解释器有很多类型:CPython JPython PPython 常用的是CPython

  2. GIL本质也是一把互斥锁 用来阻止同一个进程内多个进程同时执行

  3. GIL的存在是因为CPython解释器中内存管理不是线程安全的(垃圾回收机制)

from threading import Thread

num_name = 100

def task():
    global num_name
    num_name -= 1

t_list = []
for i in range(100):
    t = Thread(target=task)
    t.start()
    t_list.append(t)
for t in t_list:
    t.join()

print(num_name)
  • 进程池与线程池

进程与线程不能无限制的一直创建 因为硬件的发展赶不上软件的 有物理极限 如果一直无限制的创建进程或线程会可能会导致计算机奔溃

池:降低程序的执行效率 但是保证了计算机硬件的安全

进程池:提前创建好固定的进程功后续程序的调用 超出就等待

线程池:提前创建好固定数量的线程供后续程序的调用 超出就等待

import time
from concurrent.futures import ThreadPoolExecutor

pool = ThreadPoolExecutor(5)  # 产生固定数量线程的线程池


def task():
    print('哈哈')
    time.sleep(0.1)


for i in range(100):  # 将任务提交给线程池 5个线程处理100个任务 谁有空谁来
    pool.submit(task)
  • 协程

进程资源单位 线程执行单位

协程:单线程下实现并大(效率极高) 在代码层面欺骗CPU 让CPU觉得我们代码没有IO操作 实际上被我们自己写的代码检测 一旦有 立刻让代码执行别的 核心:自己写的代码完成切换+保存状态

  • 存取数据的演变史

  1. 文本文件:文件路径不固定 数据格式不统一

  2. 软件开发目录规范 规定了数据应该保存到db目录下 路径偏向统一 数据格式还是没有得到统一

  3. 数据库服务 统一了路径的操作方式 降低了学习的的成本提高了开发效率

  • 数据库的分类

关系型数据库:

特征1:拥有固定的表结构(字段名、字段类型)

特征2:数据与数据之间可以建立数据层面关系

有:MySQL Oracle MariaDB PostgreSQL sql server SQLite access

非关系型数据库

特征1:没有固定的表结构 数据采用K:V键值对的形式

特征2:数据之间无法建立数据层面关系 可以编写代码建立逻辑层面的关系

有:redis mongoDB memcache

  • MySQL简介及基本使用、系统服务的制作

bin目录:存放启动文件 mysql.exe(服务端) mysql.exe(客户端)

data目录:存在核心数据

my-default.ini:默认的配置文件

readme:软件说明

基本使用:

cmd建议你使用管理员身份打开

1.切换到mysql的bin目录下先启动服务端 mysqld

2.保持窗口不关闭 重新打开一个新的cmd窗口

3.切换到mysql的bin目录下启动客户端 mysql

基本使用每次都要打开服务端 设置成开机自动启动

1.先把bin目录添加到环境变量

2.将mysql添加到系统服务端中

3.首次添加不会自动启动 需要人为操作一下

4.卸载操作:先关闭服务端 net stop mysql 移除系统服务 mysql –remove

  • SQL与NOSQL

数据库服务端是可以服务多种类型的客户端 客户端可以自己开发 也可以是python代码编写 也可以是java编写

SQL:操作关系型数据库的语言

NOSQL:操作非关系型数据库的语言

  • 数据重要概念

库 就相当于 文件夹
表 就相当于 文件夹里面的文件
记录 就相当于 文件夹里面的文件中的一行行数据

验证
1.查看所有的库名称
show databases;
2.查看所有的表的名称
show table;
3.查看所有的记录
select * from mysql.user;

  • 基本SQL语句

\c: 中断当前输入的语句

\G:垂直显示结果

\h:显示此帮助 等于hlep

\u:切换数据库 等于use

\s:查看Mysql相关信息用户、版本、编码、端口

创建库
create database 库名;

查看库
show databases; 查看所有的库名
show create database 库名; 查看指定库的信息

编辑库
alter database 库名 条件;

删除库
drop database 库名

创建表
create table 表名(字段类 字段类型, 字段名 字段类型);

查看表
show tables; 查看库下所有的表名称
show create table 表名; 查看指定表的信息
describe 表名; 查看表结构 简写>>>desc 表名;
ps: 如果想跨库操作其他表 只需要再表名前加库名即可
desc 库名.表名;

编辑表
alter table 表名 rename 新表名;

删除表
drop table 表名;

插入数据
insert into 表名 values(数据值1, 数据值2);

查询数据
select * from 表名; 查询表中所有的数据

编辑数据
update 表名 set 字段名=新数据 where 筛选条件;

删除数据
delete from 表名;
delete from 表名 where 条件;
  • 数据库存储引擎

存储引擎:数据库针对数据采取的多种存取方式

show engines; 查看引擎

常见的存储引擎有:

MyISAM:MySQL5.5之前默认的储存引擎、存取数据的速度快 但是功能较少 安全性低

InnoDB:MySQL5.5之后默认的储存引擎、支持事物 行锁 外键等操作 存取速度没有MyISAM快 但是安全性更高

Memory:基于内存存起数据 仅用于临时表数据存取

BlackHole:任何写入进去的数据都会立刻丢失

  • 字段类型之整型、严格模式、浮点型、字符串类型、枚举与集合、日期

整型:tinyint smallint int bigint

严格模式:当我们在使用数据库存储数据的时候 如果数据不符合规范 应该直接报错而不是擅自修改数据 这样会导致数据的失真

show variables like ‘%mode%’; 模糊查询 找出所有带mode的配置信息

sql_mode NO_ENGINE_SUBSTITUTION

浮点型:float double decimal 精度不同

字符串类型:char 定长 varchar 变长

枚举与集合:多选一 enum(‘小二’,’小三’,’小四’) 多选多(包含多选一) set(‘小二’,’小三’,’小四’)

日期类型:datetime date time year

  • 字段约束条件

unsigned 无符号

zerofill 0填充

非空: not null 所有的字段类型不加约束条件的情况默认下都可以为空

默认值:default

位置值:unique分单列唯一 unique()联合唯一

主键:primary key auto_increment(主键自增) InnoDB储存引擎规定所有的表都必须只有一个主键(主键是组织数据的重要条件 并且可以加快数据的查询速度)

  • SQL语句关键字查询

select:指定需要查询的字段信息

from:指定需要查询的表信息

查询关键字之where筛选、之group by分组、之having过滤、distinct去重、order by排序、limit分页、regexp正则表达式

原文地址:http://www.cnblogs.com/xiao-fu-zi/p/16930167.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性