python学习第三十九天:mysql表相关操作

表的完整性约束

约束条件与数据类型的宽度一样,都是可选参数

作用:用于保证数据的完整性和一致性

主要分为:

not null  标识该字段不能为空

default   为该字段设置默认值

unsigned  无符号

zerofill   使用0填充

auto_increment  标识该字段的自动增长(整数类型,而且为主键)

primary key   标识该字段为该表的主键,可以唯一的标识记录

foreign key   标识该字段为该表的外键

unique key    标识该字段的值是唯一的

一、not null与default

create table t1(

id int primary key auto_increment,

name varchar(16) not null,

sex enum(‘nale’,’female’) not null default ‘male’

);

Insert into t1(name) values(‘egon’),(‘lxx’),(‘alex’);

二、unique key

create table t2(x int unique);

create table t3(

x int,

y varchar(5),

unique key(x)

);

create table t4(

x int,

y varchar(5),

constraint uni_x unique key(X)

);  # 给键取名

create table service(

ip varchar(15),

port int,

unique key(ip,port)

);  # 联合唯一

三、primary key

站在约束角度看primary key = not null unique

以后但凡建表,必须注意:

1、必须有且只有一个主键

2、通常是id字段被设置为主键

create table t5(

id int primary key auto_increment

);

# 补充存储引擎:

create table t12(x int)engine=‘myisam‘;  #会创建三个文件

create table t13(x int)engine=‘innodb‘;   #一般都用这个,创建两个,主键与数据在一个表中

create table t14(x int)engine=‘memory‘;       #内存中,服务端关机消失

create table t15(x int)engine=‘blackhole‘;   #不会有任何数据信息

四、foreign key:限制关联表某一个字段的值必是来自于被关联表的一个字段的

注意:

1.被关联的字段必须是一个key,通常是id字段

2.创建表时:必须先建立被关联的表,才能建立关联表

3.插入记录时:必须先往被关联的表中插入记录,才能往关联表中插入记录

4.删除时:应该先删除关联表emp中的记录,再删除被关联表对应的记录

create table dep(

id int primary key auto_increment,

dname varchar(20),

info varchar(50)

);

create table emp(

id int primary key auto_increment,

name varchar(15),

age int,

dep_id int,

foreign key(dep_id) references dep(id)

on update cascade

on delete cascade

);

insert into dep(dname,info) values

(‘IT’,’技术能力有限部门’),

(‘sale’,’文化程度不高部门’),

(‘HR’,’招不到人部门’);

insert into emp(name,age,dep_id) values

(‘egon‘,18,1),

(‘alex‘,28,2),

(‘wsj‘,38,2),

(‘lxx‘,30,1),

(‘xiaohou‘,18,3);

# 找两张表的关系的窍门

emp        dep

#1、先站在左表的角度:去找左表emp的多条记录能否对应右表dep的一条记录

翻译:多个员工能否属于一个部门

#2、然后站在右表的角度:去找右表dep的多条记录能否对应左表emp的一条记录

翻译:多个部门能否拥有同一名员工

# 多对一:结果的判断

#1、如果只有单向的多对一成立,那么最终的关系就是多对一

#2、在emp表新增一个字段dep_id, 该字段外键关联dep(id)

# 多对多:结果的判断

#1、双向的多对一就是多对多

#2、需要建立第三张表,有一个字段值fk左表,一个字段的值fk右表

create table author(

id int primary key auto_increment,

name varchar(16),

age int

);

create table book(

id int primary key auto_increment,

bname varchar(20),

price int

);

create table author2book(

id int primary key auto_increment,

author_id int,

book_id int,

foreign key(author_id) references author(id) on update cascade on delete cascade,

foreign key(book_id) references book(id) on update cascade on delete cascade

);

# 一对一:无需参考窍门,左表的一条数据唯一对应右表的一条记录

fk+unique

原文地址:https://www.cnblogs.com/luck-L/p/9343469.html

时间: 2024-09-28 07:21:36

python学习第三十九天:mysql表相关操作的相关文章

Python学习日记(三十四) Mysql数据库篇 二

外键(Foreign Key) 如果今天有一张表上面有很多职务的信息 我们可以通过使用外键的方式去将两张表产生关联 这样的好处能够节省空间,比方说你今天的职务名称很长,在一张表中就要重复的去写这个职务的名字,很浪费空间;除此之外也能起到一个约束的作用. 像department就是外键. 执行代码: create table t1( uid bigint auto_increment primary key, name varchar(32), department_id int, gender

Python学习日记(三十五) Mysql数据库篇 三

使用Navicate 创建一个连接去使用Mysql的数据库,连接名可以取任意字符但是要有意义 新增一个数据库 填写新数据库名,设置它的字符集和排序规则 新建一个表 增加表中的信息 点击保存再去输入表名完成创建,再添加数据: 使用外键将两表产生联系 再创建一个department表 添加数据: 创建外键,右键userinfo设计表创建外键: 写入SQL语句 点击查询->新建查询 转储SQL文件 将SQL文件进行备份 保存数据和结构 保存结构 使用终端进行转储 保存数据和结构(备份) 保存结构(备份

python学习之第十九天

本节内容 算法定义 时间复杂度 空间复杂度 常用算法实例 1.算法定义 算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制.也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出.如果一个算法有缺陷,或不适合于某个问题,执行这个算法将不会解决这个问题.不同的算法可能用不同的时间.空间或效率来完成同样的任务.一个算法的优劣可以用空间复杂度与时间复杂度来衡量. 一个算法应该具有以下七个重要的特征: ①有穷性(Fin

Python学习(三十九)—— Django之Form组件

一.构建一个表单 假设你想在你的网站上创建一个简单的表单,以获得用户的名字.你需要类似这样的模板: <form action="/your-name/" method="post"> <label for="your_name">Your name: </label> <input id="your_name" type="text" name="your

python学习(三十)私有和继承

1.私有 私有方法和私有变量,出了类就不能用 格式就是在变量或者方法前加两个下划线 import redis class My(object): def __init__(self): self.__host='xxx' #私有变量,出了类就不能用了 self.___port=6379 self.__password='HK139bc&*' self.r=redis.Redis(host=self.host,port=self.port,password=self.password) def _

python学习(三十二)线程锁&amp;守护线程&amp;多进程

1.线程锁 如果多个线程同时要修改一个数据的时候,可能会把数据覆盖,这个时候就要在改数据的时候加锁,只同时有一个线程在改这个数据,改完后再解锁. 在Python2里面要加锁,在Python3里面不用,因为Python3里面会自动加锁和解锁. 在Python2里面加锁的代码如下: import threading,time num=1 lock=threading.Lock() #申请一把锁 def run(): time.sleep(1) global num lock.acquire() #加

python学习第四十九天:CSS3新增

1 CSS3 的选择器 1.1 基本选择器 tagName .className #idName * slector,selector,selector 1.2 层级选择器 selector1 selector2 后代 selectoer1>selectoer2 子元素 selector1+selector2 紧邻在后面的兄弟元素 selector1~selector 后面所有兄弟元素 1.3 属性选择器 selector[attr] 包含指定的属性 selector[attr=value] 指

javaweb学习总结(三十二)——JDBC学习入门【转】

原文地址:javaweb学习总结(三十二)——JDBC学习入门 一.JDBC相关概念介绍 1.1.数据库驱动 这里的驱动的概念和平时听到的那种驱动的概念是一样的,比如平时购买的声卡,网卡直接插到计算机上面是不能用的,必须要安装相应的驱动程序之后 才能够使用声卡和网卡,同样道理,我们安装好数据库之后,我们的应用程序也是不能直接使用数据库的,必须要通过相应的数据库驱动程序,通过驱动程序去和数 据库打交道,如下所示: 1.2.JDBC介绍 SUN公司为了简化.统一对数据库的操作,定义了一套Java操作

OpenCV for Python 学习笔记 三

给源图像增加边界 cv2.copyMakeBorder(src,top, bottom, left, right ,borderType,value) src:源图像 top,bottem,left,right: 分别表示四个方向上边界的长度 borderType: 边界的类型 有以下几种: BORDER_REFLICATE # 直接用边界的颜色填充, aaaaaa | abcdefg | gggg BORDER_REFLECT # 倒映,abcdefg | gfedcbamn | nmabcd