#外键  表与表相连 列名 MUL 外键 参照完整性 不能添加另一个表没有的字段
create table study_record(
id int auto_increment primary key,
day int not null,
status char(32) not null,
stu_id int not null,
#创建外键
key 'fk_student_key' ('stu_id'), #起个名字
constraint 'fk_student_key' foreign key ("stu_id") references 'student' ('id')
)
#若表1是参照的 表2是跟随的 如果删除2 是可以的! 但是如果删除1 是不可以的 #NULL 值处理
#IS NULL 如当前值为空 则返回true
#IS NOT NULL 不为空
#不能用 = NULL 或者!= NULL 永远记住 NULL值与任何比较都返回false #mysql连接多表查询
# left join
#right join
#inner join 内连接 获取两个表匹配记录
#full join create table A (a int not null )
create table B (b int not null)
insert into A (a) values(1);
insert into A (a) values(2);
insert into A (a) values(3); insert into B (b) values(4);
insert into B (b) values(5);
insert into B (b) values(6);
求交集 内连接 inner join
select * from A inner join B on A.A = B.b;
select a.*, b.* from A,B where A.a=B.b; 求差集 left join
select * from A left join B on A.a = B.b; 求差集 反向的left join
select * from A right join B on A.a = B.b; 求并集 full join mysql是不支持full join 一般并集无用
select * from a full join B on A.a = B.b; 并集 MySQL
select * from A left join B on A.a = B.b union select * from A right join B on A.a = B.b; 事务必须满足四个条件
原子性(atomicity) 要么成功要么撤回
稳定性(consistency) 有非法数据时 事务撤回
隔离性Isolation 事务独立运行 一个事务处理后的结果影响事务 name其他事务会撤回
可靠性durability 硬件奔溃的时 InnoDB数据会利用日志文件重构修改 可靠和高速度不可兼容
#数据库 成批的 要么都成功 要么都失败
修改 删除 插入 才需要事务
默认为 Innodb 只有innodb才支持事务 mysql sum不支持事务 开启一个事务 begin;
select * from student;
insert into student (name , register_date, gender ) values('ljc', '2014', 'M');
insert into student (name , register_date, gender ) values('ljc', '2014', 'M');
已经插入表里
如果出现问题 可回滚 输入rollback; 或者会自动回滚 (id会自增 但不影响) begin;
insert into student (name , register_date, gender ) values('ljc', '2014', 'M');
insert into student (name , register_date, gender ) values('ljc', '2014', 'M');
commit 确认提交 索引 #使表查询更快 索引可以有很多个!! mysql索引是通过二叉树(B tree)实现 和hash差不多
单列索引 和 组合索引(两个列)就是想两个列加起来唯一!!!
创建索引时 记住查询时用索引查询!!
索引也为表 一个排序好了的数字表
但是 过多索引也会有缺陷 更新表时,也需要更新数字表,需要重新排数据表!! 所以更新时速度会变慢
增加磁盘空间!!
主键就是索引!!! 查看索引 show index from 表名
show index from 表名;
create index index_name on 表名(列名()) #index_name 是key_name 与原表无关系 随意定
create index index_name on student(name(32)) 修改表结构添加
alter student add index index_name on (列名()) 创建表添加
create table student(id int not null, index index_name (列名(长度)))
create table student (id int not null, index index_name (name(32))); ************ 删除索引
drop index index_name on 表名; show index from student
drop index index_name on student; 唯一索引 索引列值必须唯一 可以有空值 主键就是 区别就是添加unique
alter student add unique index_name on (username(32))
create table student(unique index_name (username(32)))
create unique index index_name on student(username(32)) 使用alter添加和删除主键
alter table student modify id int not null;
alter table student add primary key(id); alter删除主键
alter table student drop primary key;不知道索引名时删除
alter table student drop primary key(id); ??????????? show index from student\G 不需要添加; 将数值列表名都列表显示

Mysql基础第二部分,针对以后python使用的更多相关文章

  1. Mysql基础部分,针对以后python使用

    #redis 非关系型数据库#mysql 关系型数据库 表与表之间有数据关系 Oracle Mysql SqlServer DB2#多张表组合在一起就是数据库#冗余 存储两倍数据 可以使系统速度更快 ...

  2. python【第十二篇】Mysql基础

    内容: 1.数据库介绍及MySQL简介 2.MySQL基本操作 1 数据库介绍 1.1什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数据库都有一个或多个不同 ...

  3. python操作mysql基础一

    python操作mysql基础一 使用Python操作MySQL的一些基本方法 前奏 为了能操作数据库, 首先我们要有一个数据库, 所以要首先安装Mysql, 然后创建一个测试数据库python_te ...

  4. MySQL基础语句与其在Python中的使用

    一.MySQL基础语句 $ mysql -u root -p (有密码时) $ mysql -u root     (无密码时) QUIT (or \q)  退出 查看当前所有数据库 show dat ...

  5. python进阶08 MySQL基础补充

    python进阶08 MySQL基础补充 本次课程都是基于三张表格的使用 一.子查询 #如何找到‘张三’的成绩 #思路:先找到张三的学号,在拿这个张三的学号到成绩表里面去匹配,得出成绩 #如何用一条查 ...

  6. Mysql基础学习第二天

    Mysql基础学习第二天 函数 函数:是指一段可以直接被另一段程序调用的程序或代码. 字符串函数 数值函数 日期函数 流程函数 字符串函数 MySQL内置很多字符串函数,常用的几个如下: 函数 功能 ...

  7. python学习之-- Mysql 基础知识

    数据库介绍及MYSQL基础操作了解 关系型数据库(RDBMS)是按照数据结构来组织,存储和管理数据的仓库.特点:1:数据以表格的形式出现2:每行为各种记录名称3:每列为记录名称所对应的数据域4:许多的 ...

  8. MySQL基础和习题强化(完结)

    Mysql 1.     Mysql基础知识 1.1.     Index and table searching of Mysql 1.1.1.     Basic concepts of Mysq ...

  9. MYSQL基础操作

    MYSQL基础操作 [TOC] 1.基本定义 1.1.关系型数据库系统 关系型数据库系统是建立在关系模型上的数据库系统 什么是关系模型呢? 1.数据结构可以规定,同类数据结构一致,就是一个二维的表格 ...

随机推荐

  1. go语言简单的执行shell命令

    package main import(     "fmt"     "os/exec"     "os"     "string ...

  2. [洛谷P3939]数颜色

    题目大意:有n个物品,每个物品有一个颜色.现在有两种操作:1.查询l-r内有多少颜色为c的物品并输出.2.将第x个物品和第x+1个交换.现在让你实现这些操作. 解题思路:首先一共有300000种颜色, ...

  3. Java基础学习总结(43)——Java8 Lambda揭秘

    再了解了Java 8 Lambda的一些基本概念和应用后, 我们会有这样的一个问题: Lambda表达式被编译成了什么?. 这是一个有趣的问题,涉及到JDK的具体的实现. 本文将介绍OpenJDK对L ...

  4. 你必须了解的RecyclerView的五大开源项目-解决上拉加载、下拉刷新和添加Header、Footer等问题

    前段时间做项目由于采用的MD设计,所以必须要使用RecyclerView全面代替ListView.但是开发中遇到了需要实现RecyclerView上拉加载.下拉刷新和添加Header以及Footer等 ...

  5. [android] 百度地图开发 (一).申请AK显示地图及解决显示空白网格问题

        近期做android百度地图,可是使用baidumapapi_v2_3_1.jar和libBaiduMapSDK_v2_3_1.so显示百度地图时总是遇到问题--仅仅显示网格而没有显示地图,网 ...

  6. glm编译错误问题解决 formal parameter with __declspec(align('16')) won't be aligned

    參考:http://stackoverflow.com/questions/25300116/directxxmmatrix-error-c2719-declspecalign16-wont-be-a ...

  7. 更改linux文件的拥有者及用户组(chown和chgrp)

    .使用chown命令更改文件拥有者 在 shell 中,能够使用chown命令来改变文件全部者.chown命令是change owner(改变拥有者)的缩写.须要要注意的是,用户必须是已经存在系统中的 ...

  8. 计算机系统之汇编---IA32处理器数据格式及数据操作

    计算机系统之汇编---IA32处理器数据格式及数据操作 IA32数据格式: Intel用术语"字"表示16位数据类型,因此.称32位数为"双字",称64位数为& ...

  9. windows电脑空间清理

    最近电脑空间又快满了,想下载一些好电影音频资源都要先临时清理一些文件才行,今天有时间就彻底整理一下,将整理过程及用到的好工具都记录一下,方面下次再遇到问题时可以很方面的参考执行. 1.分析磁盘空间占用 ...

  10. Method Swizzing中一般替换方法都写在Category类别里吗?有没有别的实现方式

    Method Swizzing中一般替换方法都写在Category类别里吗?有没有别的实现方式 Method Swizzing中一般替换方法都写在Category类别里吗?有没有别的实现方式 > ...