python之路-----MySql操作二
CREATE TABLE NAME (
id INT auto_increment,
NAME CHAR (20),
sid int,
PRIMARY KEY (id, sid)
);
插入数据(1,'a',1),主键值为:(1,1) ,插入(1,'b',2),主键为(1,2),两个主键值不完全相等即可
主键示例
CREATE TABLE name1 (
id INT auto_increment,
NAME CHAR (20),
UNIQUE qu_name (NAME),
INDEX (id)
)
唯一索引示例
三.自增
CREATE TABLE `more2` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`pc_name` char(20) DEFAULT NULL,
`owner_id` int(11) DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `uq_more2` (`owner_id`),
CONSTRAINT `one2_more2` FOREIGN KEY (`owner_id`) REFERENCES `one2` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | 1 | #步长
| auto_increment_offset | 1 | #数量默认起始值
+--------------------------+-------+
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | 3 |
| auto_increment_offset | 5 |
+--------------------------+-------+
新建连接,查看自增起始值和步长
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | 1 |
| auto_increment_offset | 1 |
+--------------------------+-------+
我们发送,通过修改session变量,仅本次连接有效,如果要使修改的值永久有效,需要修改global变量
2.4查看global自增相关变量值
show global variables like '%auto_inc%';
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | 1 |
| auto_increment_offset | 1 |
+--------------------------+-------+
2.5 修改global变量
set global auto_increment_increment=2; #修改自增步长
set global auto_increment_offset=2; #修改自增列起始值
2.6 新建连接查看,配置依旧生效 。但是不建议使用该方法进行修改
create table morekey(
id int auto_increment,
sid int,
name char(20),
PRIMARY KEY(id,sid)
);
CREATE table morekey1(
id1 INT,
sid1 INT,
name1 CHAR(20),
CONSTRAINT fk_moremore FOREIGN KEY(id1,sid1) REFERENCES morekey(id,sid)
)
关联多个外键
create table morekey(
id int auto_increment,
sid int,
name char(20),
PRIMARY KEY(id,sid)
);
CREATE table morekey1(
id1 INT,
sid1 INT,
name1 CHAR(20),
CONSTRAINT fk_moremore FOREIGN KEY(id1,sid1) REFERENCES morekey(id,sid)
)
一对多示例
-- pc编号
CREATE TABLE hostinfo(
id int auto_increment PRIMARY KEY,
host_name CHAR(20)
);
-- 用户资产信息
CREATE TABLE employ(
id int auto_increment PRIMARY KEY,
name char(20),
pc_id int,
UNIQUE uq_hostinfo_employ (pc_id),
CONSTRAINT fk_hostinfo_employ FOREIGN KEY (pc_id) REFERENCES hostinfo(id)
);
一对一示例
-- 主机信息表
CREATE TABLE pcinfo(
id int auto_increment PRIMARY KEY,
host_name char(20)
);
-- 管理员信息表
CREATE TABLE admininfo(
id int auto_increment PRIMARY KEY,
name char(20)
);
-- 管理员主机对应表
CREATE TABLE admin_pc(
id int auto_increment PRIMARY KEY,
pc_id int ,
user_id int,
UNIQUE uq_user_pc (pc_id,user_id),
CONSTRAINT fk_admin_pc FOREIGN KEY(pc_id) REFERENCES pcinfo(id),
CONSTRAINT fk_admin_user FOREIGN KEY(user_id) REFERENCES admininfo(id)
);
多对多示例
五.操作表内容高级运用补充
1.笛卡尔积
笛卡尔积是关系代数里的一个概念,表示两个表中的每一行数据任意组合。例如A表中有三条数据,B表中有三条数据,则使用命令:
select * from A,B,则会产生九条结果。A表的每个值都会和B表的每个值产生一条对应的值。关系图如下:

2.临时表,将过滤出来的数据临时当成一张表使用
命令格式:(SELECT 列名 FROM 表) as B 应用
连表操作:
SELECT * FROM (SELECT sid FROM score) as B LEFT JOIN student on student.sid=B.sid;
把score表中过滤出来的数据和student表进行连表操作
3.insert插入过滤后的表内容
INSERT INTO class(caption) SELECT name FROM class2;
ps:需要注意的是,插入的列要跟表的列一致
4.条件语句
句型:case when 条件 then 条件为正返回 esle 条件为假返回 end
case when id<10 then 1 else 0 end; #如果id小于10,则返回1,否则返回0
5.利用常量来统计
select count(1) from tablename groub by id;
6.插入动态值
SELECT
student_id,
(select num from score as s2 where s2.student_id=s1.student_id and course_id = 1) as 语文,
(select num from score as s2 where s2.student_id=s1.student_id and course_id = 2) as 数学,
(select num from score as s2 where s2.student_id=s1.student_id and course_id = 3) as 英语
from score as s1;
s1表的值可以再内循环中使用。类似于:
for student_id in s1:
for id in s2:
s2=s1
7.三元运算
if(条件,为真返回,为假返回)
e.g:if (isnull(xx),0,1) 如果为null,则返回0,否则返回1
python之路-----MySql操作二的更多相关文章
- python之路-----MySql操作
一.概述 1.什么是数据库 数据库就是按照数据结构来组织.存储和管理数据的仓库.如我们创建的文件夹,就是一个数据库. 2.什么是mysql,oracle,access,sqlit等? 他们都是一款软件 ...
- python之路-----MySql操作三
mysql 概述 一.主要内容: 视图 create view name (select * from user where id>5); 触发器 函数 存储过程 索引 二.各模块详细说明 1. ...
- 百万年薪python之路 -- MySQL数据库之 MySQL行(记录)的操作(二) -- 多表查询
MySQL行(记录)的操作(二) -- 多表查询 数据的准备 #建表 create table department( id int, name varchar(20) ); create table ...
- python中的mysql操作
一. 数据库在自动化测试中的应用 存测试数据 有的时候大批量的数据,我们需要存到数据库中,在测试的时候才能用到,测试的时候就从数据库中读取出来.这点是非常重要的! 存测试结果 二. python中的数 ...
- python之路--MySQL 库,表的详细操作
一 库操作 数据库命名规则 可以由数字,字母,下划线,@, #, $ 区分大小写 唯一性 不能使用关键字如 create select 不能单独使用数字 最长128位 # 这些是对上次的补充. 二 ...
- 百万年薪python之路 -- MySQL数据库之 MySQL行(记录)的操作(一)
MySQL的行(记录)的操作(一) 1. 增(insert) insert into 表名 value((字段1,字段2...); # 只能增加一行记录 insert into 表名 values(字 ...
- python之数据库(mysql)操作
前言: 最近开始学django了,学了下web框架,顿时感觉又会了好多知识.happy~~ 这篇博客整理写下数据库基本操作,内容挺少.明天写SQLAlchemy. 一.数据库基本操作 1. 想允许在数 ...
- 百万年薪python之路 -- MySQL数据库之 Navicat工具和pymysql模块
一. IDE工具介绍(Navicat) 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具,我们使用Navicat工具,这个工具本质上就是一个socket客户端,可视化的连接 ...
- python之路-Mysql&&ORM
1. 数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库, 每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据. 我们也可以 ...
随机推荐
- Hibernate一级缓存和二级缓存详解
(1)一级缓存 是Session级别的缓存,一个Session做了一个查询操作,它会把这个操作的结果放在一级缓存中,如果短时间内这个session(一定要同一个session)又做了同一个操作,那么h ...
- php 随机红包算法
<?php /** * 红包分配算法 * * example * $coupon = new Coupon(200, 5); * $res = $coupon->handle(); * p ...
- C语言解析WAV音频文件
C语言解析WAV音频文件 代码地址: Github : https://github.com/CasterWx/c-wave-master 目录 前言 了解WAV音频文件 什么是二进制文件 WAV的二 ...
- 【做题】SRM701 Div1 Hard - FibonacciStringSum——数学和式&矩阵快速幂
原文链接 https://www.cnblogs.com/cly-none/p/SRM701Div1C.html 题意:定义"Fibonacci string"为没有连续1的01串 ...
- [luaj]在安卓用使用luaj
luaj与安卓 什么是luaj luaj是一个Java的一个lua语言引擎,他可以让你在java上运行Lua代码. 在安卓中使用lua干嘛 lua代码可以用来书写布局,或者一些业务逻辑. 为什么要在安 ...
- scss、sass、less的对比与区别
什么是Sass和Less? sass和less都属于CSS预处理器. css预处理定义了一种新的语言,其基本思想是,用一种专门的编程语言,为css增加了一些编程的特性,将CSS作为目标生成文件,然后开 ...
- vs2013编译obs源码
obs源码下载 一种是在GitHub上下载最新的代码 git clone --recursive https://github.com/jp9000/obs-studio.git --recursiv ...
- 用Python实现简单通讯录
一个简单的通讯录例子 #!/usr/bin/python __author__ = 'fierce' #coding:utf-8 import os #引用os模块 import pickle #应用 ...
- 浮点型/小数/栅格图层转为整数型arcgis操作
有时候会遇到将32位栅格数据提取属性表的操作,但是一般此类数据都是浮点型,是无法计算得到属性表的.因此我们可以利用数据管理工具下的: 复制栅格工具,在最下面选择16位即可,看自己数据情况选择signe ...
- C#中得到程序当前工作目录和执行目录的五种方法
string str="";str += "\r\n" + System.Diagnostics.Process.GetCurrentProcess().Mai ...