第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

时间:2022-03-11 04:51:23

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

链表操作

链表,就是一张表的外键字段,连接另外一张表的主键字段

一对多

models.ForeignKey()外键字段一对多,值是要外键的表类

from __future__ import unicode_literals

from django.db import models        #导入models对象

class yong_hu_shen_fen(models.Model):                        #创建用户是否表类
id = models.AutoField('id',primary_key=True) #自增id
shen_fen = models.CharField('身份',max_length=16) #字符串类型字段,记录用户身份 class Meta:
verbose_name = '用户身份表'
verbose_name_plural = verbose_name class yong_hu_biao(models.Model):
yong_hu = models.CharField('用户',max_length=32)
you_xiang = models.EmailField('邮箱',max_length=32)
mi_ma = models.CharField('密码',max_length=64)
wai_jian_yong_hu_shen_fen = models.ForeignKey(yong_hu_shen_fen) #外键链表 class Meta:
verbose_name = '用户表'
verbose_name_plural = verbose_name

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

正向查找,也就是通过表的外键,查找到外键连接的表里的数据

链表查询之了不起的__双下划线

也就是一般普通查询外键字段时,得到的是另外一张表的主键值,

__双下划线,表示跨表查询的意思,注意,__双下划线跨表查询必须是外键连接的表

查询一张表的外键字段时可以通过,外键字段名称__连接表的字段名称,查询到外键连接表里的指定字段值

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 #逻辑处理模块
def special(request):
a = yong_hu_biao.objects.all().values('yong_hu','wai_jian_yong_hu_shen_fen_id') #获取用户名字段,和外键字段
print(a)
b = yong_hu_biao.objects.all().values('yong_hu','wai_jian_yong_hu_shen_fen_id__shen_fen') #获取用户名字段,和外键字段连接的表里的指定字段
print(b) return render(request,'index.html',locals()) #打开页面 #返回
# <QuerySet [{'yong_hu': '林贵秀', 'wai_jian_yong_hu_shen_fen_id': 1}, {'yong_hu': '马云', 'wai_jian_yong_hu_shen_fen_id': 2}, {'yong_hu': '张三', 'wai_jian_yong_hu_shen_fen_id': 3}]>
# <QuerySet [{'wai_jian_yong_hu_shen_fen_id__shen_fen': '普通用户', 'yong_hu': '林贵秀'}, {'wai_jian_yong_hu_shen_fen_id__shen_fen': 'vip用户', 'yong_hu': '马云'}, {'wai_jian_yong_hu_shen_fen_id__shen_fen': '超级用户', 'yong_hu': '张三'}]>

 注意:__双下划线跨表查询,都是用过外键关系跨表的

举例:如果a表外键连接b表,b表又外键连接c表,这就有了三张表,也就是多层一对多的关系

如果我们要从a表跨表查询到c表的字段,那么就是:a表外键字段__b表外键字段__c表字段    ,无论多少层继续__

filter()条件,加__双下划线,跨表查询

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 #逻辑处理模块
def special(request):
a = yong_hu_biao.objects.filter(wai_jian_yong_hu_shen_fen_id__shen_fen='普通用户').values() #获取当前表里外键字段跨表的shen_fen字段等于普通用户的数据
print(a) return render(request,'index.html',locals()) #打开页面 #返回
# <QuerySet [{'you_xiang': '729088188@qq.com', 'id': 1, 'wai_jian_yong_hu_shen_fen_id': 1, 'mi_ma': '279819', 'yong_hu': '林贵秀'}]>

反向查找,从一张表查到它,被那张表外键连接,然后查出外键连接表里的信息

外键表类名称_set ,链表反向查找

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 #逻辑处理模块
def special(request):
obj = yong_hu_shen_fen.objects.filter(shen_fen='超级用户').first() #通过条件查找到符合条件的对象,获取到第一个对象
print(obj)
a = obj.yong_hu_biao_set.all().values() #通过查找到的对象,找外键表里符合这个对象的数据,反向查找
print(a) return render(request,'index.html',locals()) #打开页面 #返回
# <QuerySet [{'yong_hu': '张三', 'wai_jian_yong_hu_shen_fen_id': 3, 'mi_ma': '279819', 'id': 3, 'you_xiang': '123456@qq.com'}]>

 __双下划线反向查找

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 #逻辑处理模块
def special(request):
a = yong_hu_shen_fen.objects.all().values('id','shen_fen','yong_hu_biao__yong_hu') #反向查找
# a = yong_hu_shen_fen.objects.all().values('id', 'shen_fen', '外键表类名称__外键表字段')
print(a) return render(request,'index.html',locals()) #打开页面 #返回
#<QuerySet [{'yong_hu_biao__yong_hu': '林贵秀', 'shen_fen': '普通用户', 'id': 1}, {'yong_hu_biao__yong_hu': '马云', 'shen_fen': 'vip用户', 'id': 2}, {'yong_hu_biao__yong_hu': '张三', 'shen_fen': '超级用户', 'id': 3}]>

链表操作一对一

OneToOneField()外键链表,一对一类型,也就是相当于,在外键字段加了一个唯一索引,在添加数据时不能有重复类容,只能一对一

from __future__ import unicode_literals

from django.db import models        #导入models对象

class yong_hu_shen_fen(models.Model):                        #创建用户是否表类
id = models.AutoField('id',primary_key=True) #自增id
shen_fen = models.CharField('身份',max_length=16) #字符串类型字段,记录用户身份 class Meta:
verbose_name = '用户身份表'
verbose_name_plural = verbose_name class yong_hu_biao(models.Model):
yong_hu = models.CharField('用户',max_length=32)
you_xiang = models.EmailField('邮箱',max_length=32)
mi_ma = models.CharField('密码',max_length=64)
wai_jian_yong_hu_shen_fen = models.OneToOneField(yong_hu_shen_fen) #外键链表一对一 class Meta:
verbose_name = '用户表'
verbose_name_plural = verbose_name

其他链表操作与上面相同


链表操作多对多

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

ManyToManyField()多对多字段类型

创建一对多结构有3中方式

方式一,传统方式【不推荐】

from __future__ import unicode_literals

from django.db import models        #导入models对象

class yu_wen_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) class Meta:
verbose_name = '语文老师表'
verbose_name_plural = verbose_name class shu_xue_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) class Meta:
verbose_name = '数学老师表'
verbose_name_plural = verbose_name class tong_xue_biao(models.Model):                 #关系表
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16)
wj_yu_wen_lao_shi = models.ForeignKey(yu_wen_lao_shi) #外键语文老师表
WJ_shu_xue_lao_shi = models.ForeignKey(shu_xue_lao_shi) #外键数学老师表 class Meta:
verbose_name = '同学表'
verbose_name_plural = verbose_name

 方式二ManyToManyField()多对多字段类型,自动生成关系表【不推荐】

ManyToManyField(另外一张表的名称)写在,要建立关系的任意一张表里,参数是另外的要建立关系的表类名称

from __future__ import unicode_literals

from django.db import models        #导入models对象

class yu_wen_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) class Meta:
verbose_name = '语文老师表'
verbose_name_plural = verbose_name class shu_xue_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) guan_xi = models.ManyToManyField(yu_wen_lao_shi) #注意不会生成guan_xi这个字段,只会自动生成一张多对多关系表 class Meta:
verbose_name = '数学老师表'
verbose_name_plural = verbose_name

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

 可以看到,这个方式虽然简单,但是自动生成的关系表,只有外键关系的字段,如果我们需要有其他字段,无法满足

方式三,上面两种方式的结合【推荐】

ManyToManyField(另外一张表的名称,through='关系表名称')写在,要建立关系的任意一张表里,参数是另外的要建立关系的表类名称

同时也在关系表设置外键字段

from __future__ import unicode_literals

from django.db import models        #导入models对象

class yu_wen_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) class Meta:
verbose_name = '语文老师表'
verbose_name_plural = verbose_name class shu_xue_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) guan_xi = models.ManyToManyField('yu_wen_lao_shi', through='tong_xue_biao')
# guan_xi = models.ManyToManyField('另外一张表的名称', through='关系表名称') class Meta:
verbose_name = '数学老师表'
verbose_name_plural = verbose_name class tong_xue_biao(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16)
wj_yu_wen_lao_shi = models.ForeignKey(yu_wen_lao_shi) #外键表
wj_shu_xue_lao_shi = models.ForeignKey(shu_xue_lao_shi) #外键表 class Meta:
verbose_name = '同学表'
verbose_name_plural = verbose_name

 这样关系表就可以设置其他字段了,注意:此时看起来既然关系表已经外键链表了,干嘛还要用ManyToManyField(),感觉是多余的,放心以后查询等操作的时候它能帮到你的

多对对添加数据

自动创建关系表添加数据,关系表类不存在

方式二ManyToManyField()多对多字段类型,自动生成关系表,因为关系表是自动生成的,而数据库表类,里没有这个关系表的类,所以无法实现向关系表添加数据,这样我们就需要用ManyToManyField()变量通道来添加数据了

数据库表类里没有关系表类

from __future__ import unicode_literals

from django.db import models        #导入models对象

class yu_wen_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) class Meta:
verbose_name = '语文老师表'
verbose_name_plural = verbose_name class shu_xue_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) guan_xi = models.ManyToManyField(yu_wen_lao_shi) #注意不会生成guan_xi这个字段,只会自动生成一张多对多关系表 class Meta:
verbose_name = '数学老师表'
verbose_name_plural = verbose_name

ManyToManyField()变量添加数据到关系表

ManyToManyField()变量.add()正向添加关系表数据

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 #逻辑处理模块
def special(request):
#向yu_wen_lao_shi表插入数据
# yu_wen_lao_shi.objects.create(xing_ming='张三', you_xiang='123')
# yu_wen_lao_shi.objects.create(xing_ming='李四', you_xiang='456')
# yu_wen_lao_shi.objects.create(xing_ming='王五', you_xiang='789')
# yu_wen_lao_shi.objects.create(xing_ming='马六', you_xiang='101112') #向shu_xue_lao_shi表插入数据
# shu_xue_lao_shi.objects.create(xing_ming='赵好', you_xiang='101112')
# shu_xue_lao_shi.objects.create(xing_ming='钱的', you_xiang='101112')
# shu_xue_lao_shi.objects.create(xing_ming='孙客', you_xiang='101112')
# shu_xue_lao_shi.objects.create(xing_ming='李是', you_xiang='101112') #向关系表插入数据
a = shu_xue_lao_shi.objects.get(id=1) #获取表类里有ManyToManyField那张表,返回的一条数据对象
print(a.guan_xi.all()) #通过数据对象,找到ManyToManyField的变量,得到另外一张表的对象 b = yu_wen_lao_shi.objects.get(id=1) #获取第二张表里的数据
a.guan_xi.add(b) #将第二张表里的数据对象通过ManyToManyField的变量通道添加到关系表 #a.guan_xi 将第一张表对应的数据添加到关系表
#a.guan_xi.add(b) 将第二张表对应的数据添加到关系表 return render(request,'index.html',locals()) #打开页面

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

 如果是要添加多条用*接收

#向关系表插入数据
a = shu_xue_lao_shi.objects.get(id=1) #获取表类里有ManyToManyField那张表,返回的一条数据对象
print(a.guan_xi.all()) #通过数据对象,找到ManyToManyField的变量,得到另外一张表的对象 b = yu_wen_lao_shi.objects.filter(id__gt=1) #获取第二张表里的数据
a.guan_xi.add(*b) #将第二张表里的数据对象通过ManyToManyField的变量通道添加到关系表

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

 反向添加数据

通过另外一张表名称_set.add()方法添加数据

    #向关系表插入数据
a = yu_wen_lao_shi.objects.get(id=3) #获取没有ManyToManyField变量的那张表
print(a.shu_xue_lao_shi_set) #对象里有一个,另外一张表名称_set属性 b = shu_xue_lao_shi.objects.filter(id__gt=1) #获取有ManyToManyField变量的那张表
a.shu_xue_lao_shi_set.add(*b) #通过另外一张表名称_set属性的add()方法添加数据

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

 删除数据

remove()删除数据,不删除其他表里相关数据
delete()删除数据,删除其他表里相关数据

    #正向删除数据
# a = shu_xue_lao_shi.objects.get(id=1)
# b = yu_wen_lao_shi.objects.filter(id__gt=1)
# a.guan_xi.remove(*b) #删除关系表里shu_xue_lao_shi等于1,yu_wen_lao_shi字段大于1的数据 #反向删除
a = yu_wen_lao_shi.objects.get(id=2)
a.shu_xue_lao_shi_set.all().delete() #删除关系表yu_wen_lao_shi字段为1的数据,shu_xue_lao_shi表相关的数据也会被删除

手动创建关系表添加数据,关系表类存在

数据表类

from __future__ import unicode_literals

from django.db import models        #导入models对象

class yu_wen_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) class Meta:
verbose_name = '语文老师表'
verbose_name_plural = verbose_name class shu_xue_lao_shi(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16) guan_xi = models.ManyToManyField('yu_wen_lao_shi', through='tong_xue_biao')
# guan_xi = models.ManyToManyField('另外一张表的名称', through='关系表名称') class Meta:
verbose_name = '数学老师表'
verbose_name_plural = verbose_name class tong_xue_biao(models.Model):
id = models.AutoField('id',primary_key=True)
xing_ming = models.CharField('姓名',max_length=16)
you_xiang = models.CharField('邮箱',max_length=16)
wj_yu_wen_lao_shi = models.ForeignKey(yu_wen_lao_shi) #外键表
wj_shu_xue_lao_shi = models.ForeignKey(shu_xue_lao_shi) #外键表 class Meta:
verbose_name = '同学表'
verbose_name_plural = verbose_name

操作数据

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 #逻辑处理模块
def special(request):
#向yu_wen_lao_shi表插入数据
# yu_wen_lao_shi.objects.create(xing_ming='张三', you_xiang='123')
# yu_wen_lao_shi.objects.create(xing_ming='李四', you_xiang='456')
# yu_wen_lao_shi.objects.create(xing_ming='王五', you_xiang='789')
# yu_wen_lao_shi.objects.create(xing_ming='马六', you_xiang='101112') #向shu_xue_lao_shi表插入数据
# shu_xue_lao_shi.objects.create(xing_ming='赵好', you_xiang='101112')
# shu_xue_lao_shi.objects.create(xing_ming='钱的', you_xiang='101112')
# shu_xue_lao_shi.objects.create(xing_ming='孙客', you_xiang='101112')
# shu_xue_lao_shi.objects.create(xing_ming='李是', you_xiang='101112') #向关系表添加数据
# tong_xue_biao.objects.create(xing_ming='丰收1',you_xiang='123',wj_yu_wen_lao_shi_id=1,wj_shu_xue_lao_shi_id=2) #获取数据
#获取全部数据
a = tong_xue_biao.objects.all().values()
print(a)
#通过外键跨表获取数据
b = tong_xue_biao.objects.all().values('wj_yu_wen_lao_shi_id__xing_ming')
print(b)
for i in b:
print(i) return render(request,'index.html',locals()) #打开页面 #返回
# <QuerySet [{'you_xiang': '123', 'wj_shu_xue_lao_shi_id': 2, 'id': 1, 'xing_ming': '丰收1', 'wj_yu_wen_lao_shi_id': 1}, {'you_xiang': '123', 'wj_shu_xue_lao_shi_id': 2, 'id': 2, 'xing_ming': '丰收2', 'wj_yu_wen_lao_shi_id': 1}, {'you_xiang': '123', 'wj_shu_xue_lao_shi_id': 1, 'id': 3, 'xing_ming': '丰收3', 'wj_yu_wen_lao_shi_id': 1}, {'you_xiang': '123', 'wj_shu_xue_lao_shi_id': 2, 'id': 4, 'xing_ming': '丰收4', 'wj_yu_wen_lao_shi_id': 3}, {'you_xiang': '123', 'wj_shu_xue_lao_shi_id': 2, 'id': 5, 'xing_ming': '丰收5', 'wj_yu_wen_lao_shi_id': 4}]>
# <QuerySet [{'wj_yu_wen_lao_shi_id__xing_ming': '张三'}, {'wj_yu_wen_lao_shi_id__xing_ming': '张三'}, {'wj_yu_wen_lao_shi_id__xing_ming': '张三'}, {'wj_yu_wen_lao_shi_id__xing_ming': '王五'}, {'wj_yu_wen_lao_shi_id__xing_ming': '马六'}]>
# {'wj_yu_wen_lao_shi_id__xing_ming': '张三'}
# {'wj_yu_wen_lao_shi_id__xing_ming': '张三'}
# {'wj_yu_wen_lao_shi_id__xing_ming': '张三'}
# {'wj_yu_wen_lao_shi_id__xing_ming': '王五'}
# {'wj_yu_wen_lao_shi_id__xing_ming': '马六'}

总结;重点

一对多
外键字段__连接表字段:正向跨表查找
连接表类名称_set: 反向跨表查找

一对一
与一对多相同

多对多
ManyToManyField()自动创建关系表,数据库表类没有关系表类
ManyToManyField()变量.xx():从ManyToManyField表正向操作关系表
另外一张表名称_set.xx():从非ManyToManyField表反向操作关系表
注意:以上操作他们之间,必须有文外键关系

第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多的更多相关文章

  1. 第三百零九节,Django框架&comma;models&period;py模块,数据库操作——F和Q&lpar;&rpar;运算符:&vert;或者、&amp&semi;并且——queryset对象序列化

    第三百零九节,Django框架,models.py模块,数据库操作——F()和Q()运算符:|或者.&并且 F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from dj ...

  2. 第三百零七节,Django框架&comma;models&period;py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  3. 第三百零六节,Django框架&comma;models&period;py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置

    Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...

  4. 五 Django框架&comma;models&period;py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  5. 四 Django框架&comma;models&period;py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置

    Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...

  6. 六 Django框架&comma;models&period;py模块,数据库操作——链表结构,一对多、一对一、多对多

    链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.ForeignKey()外键字段一对多,值是要外键的表类 from __future__ import unico ...

  7. 七 Django框架&comma;models&period;py模块,数据库操作——F和Q&lpar;&rpar;运算符:&vert;或者、&amp&semi;并且——queryset对象序列化

    F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from django.db.models import F from django.shortcuts import rende ...

  8. Django框架----models&period;py&lpar;数据库操作文件&rpar;

    利用一个中间模块 帮助我们连接数据库,写SQL语句,执行SQL语句,拿到结果 models.py 一.数据的对应关系 1. 类 ---> 表 2. 对象 ---> 数据行 3. 属性 -- ...

  9. 第三百九十八节,Django&plus;Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6&period;5系统环境设置

    第三百九十八节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6.5系统环境设置 1.Linux安装配置 注意事项: 虚拟机网卡桥接模式 不要拨VPN 如果,网络怎么都 ...

随机推荐

  1. 如何修复Outlook 2007源文件&period;PST及性能优化补丁

    kb961752 微软发布了改善 Outlook 2007 个人数据文件性能的补丁,该补丁未来将会集成于 SP2 中,但是现在对于SP1用户可以提前得到它.   获取地址: http://suppor ...

  2. Spring3&period;0 与 MyBatis框架 整合小实例

    本文将在Eclipse开发环境下,采用Spring MVC + Spring + MyBatis + Maven + Log4J 框架搭建一个Java web 项目. 1. 环境准备: 1.1 创建数 ...

  3. salt 批量部署与配置

    salt是啥? salt是一个大型分布式的配置管理系统(安装升级卸载软件,检测环境),也是一个远程命令执行系统. salt 分为 master和minion,master顾名思义就是老大,管理子节点: ...

  4. Linux例行工作crontab

    第一步编辑要定时执行的脚本: myScript.sh myScript.sh的内容为:touch /root/`date +%F' '%T`.txt 为myScript.sh增加可执行权限:chmod ...

  5. 【BZOJ5507】&lbrack;GXOI&sol;GZOI2019&rsqb;旧词(树链剖分,线段树)

    [BZOJ5507][GXOI/GZOI2019]旧词(树链剖分,线段树) 题面 BZOJ 洛谷 题解 如果\(k=1\)就是链并裸题了... 其实\(k>1\)发现还是可以用类似链并的思想,这 ...

  6. Redis自学笔记&colon;3&period;4入门-列表类型

    3.4列表类型 3.4.1介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者 获得列表的某一片段. 优点:内部使用的是双向链表,所以向列表两端添加元素的时间复杂度为O(1 ...

  7. 国外优秀C&sol;C&plus;&plus;网站

    1.https://en.cppreference.com/w/ 2.https://www.geeksforgeeks.org/ 3.https://www.tutorialspoint.com/c ...

  8. hbase源码系列(十一)Put、Delete在服务端是如何处理?

    在讲完之后HFile和HLog之后,今天我想分享是Put在Region Server经历些了什么?相信前面看了<HTable探秘>的朋友都会有印象,没看过的建议回去先看看,Put是通过Mu ...

  9. PHP使用FPDF pdf添加水印中文乱码问题 pdf合并版本问题

    ---恢复内容开始--- require_once('../fpdf/fpdf.php');require_once('../fpdi/fpdi.php'); 使用此插件 pdf 合并 并添加水印 期 ...

  10. vmvare安装系统提示vmci&period;sys 版本不正确解决方法

    无法获取vmci驱动程序版本:参数不正确解决 无法获取vmci驱动程序版本:参数不正确. 驱动程序vmci.sys版本不正确. 解决办法: 1,创建好虚拟机之后,别打开电源,然后到建好的虚拟机文件夹里 ...