数据库(mysql)
一、left join right join inner join
left join(左连接),在两张表进行连接查询时,会返回左表所有的行,即使在右表中没有匹配的记录。
right join(右连接),在两张表进行连接查询时,会返回右表所有的行,即使在左表中没有匹配的记录。
full join(全连接),在两张表进行连接查询时,返回左表和右表中所有没有匹配的行。(full join,在两张表进行连接查询时,返回左表和右表中所有没有匹配的行。)
inner join(内连接),在两张表进行连接查询时,只保留两张表中完全匹配的结果集。
二、myisam innodb(存储引擎)
myisam 锁是表级、支持全文索引、不支持事物处理、占用空间小
innodb 锁是行级、不支持全文索引、支持事物处理、占用空间大(2倍)
三、数据库优化查询方法
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在where及order by涉及的列上建立索引
2.应尽量避免在where子句中使用!=或<>操作符,否则引擎将放弃使用索引而进行全表扫描
3.任何地方都不要使用select * from t,用具体的字段列表代替“ * ”,不要返回用不到的任何字段
4.尽量避免大事务操作,提高系统并发能力
5.尽量避免向客户端返回大数据量,若数据量过大,应该考虑相应需求是否合理
四、索引、视图、事务
索引:是一个数据结构,用来查询数据库表的数据
主键索引:
primary key
作用:确认表中一条特定数据记录的位置,不能为空,一个表只有一个主键
外键索引:表中的一个字段(非主键)指向另一张表中的主键,称该字段为主键。
foreign key(外键名) references 主表(主键) ;
作用:多表查询时方便联系两表数据。限制:表类型必须是innodb(有约束效果)
唯一索引:确定某一列不能出现重复的值
unique
普通索引:
create index 索引名 on 表名(列名)
索引操作:
创建:create index 索引名 on 表名(列名)
查看:show index from 表名
删除:drop index 索引名 on 表名
视图:是一个虚拟的表,不占用物理内存、不存放数据,数据只存在基表中,相互影响
优点:简单、方便,查看数据更清楚;安全性:保护数据;不占物理内存
缺点:性能差;查询效率偏低,需要转换;修改限制:对于复杂视图(多表查询)修改是麻烦的
创建:create view 视图名 as select语句
查询:show creaw view 视图名
删除:drop view 视图名
事务:将多个SQL语句要完成的任务看出一个任务,只要有一个环节出错,所有的语句都不执行
限制:表类型必须是innodb、先关闭数据库的自动提交(set autocommit=0/1(开启))
回滚:返回前面的操作 rollback
提交:开启自动提交:set autocommit=1
关闭自动提交:set autocommit=0
数据库(mysql)的更多相关文章
- MYSQL添加新用户 MYSQL为用户创建数据库 MYSQL为新用户分配权限
1.新建用户 //登录MYSQL @>mysql -u root -p @>密码 //创建用户 mysql> insert into mysql.user(Host,User,Pas ...
- Robot Framework-DatabaseLibrary数据库(MySql)
Robot Framework-Mac版本安装 Robot Framework-Windows版本安装 Robot Framework-工具简介及入门使用 Robot Framework-Databa ...
- paip.导入数据英文音标到数据库mysql为空的问题之道解决原理
paip.导入数据英文音标到数据库mysql为空的问题之道解决原理 #---原因:mysql 导入工具的bug #---解决:使用双引号不个音标括起来. 作者 老哇的爪子 Attilax 艾龙, E ...
- paip.解决 数据库mysql增加列 字段很慢添加字段很慢
paip.解决 数据库mysql增加列 字段很慢添加字段很慢 #环境如下: mysql5.6 数据仅仅3w alter table xxx add column yyy int default ...
- Sqoop是一款开源的工具,主要用于在HADOOP(Hive)与传统的数据库(mysql、oracle...)间进行数据的传递
http://niuzhenxin.iteye.com/blog/1706203 Sqoop是一款开源的工具,主要用于在HADOOP(Hive)与传统的数据库(mysql.postgresql.. ...
- 数据库MySQL多个数据库服务冲突
一.目标名称 MySQL 二.目标版本 mysql-5.6.24-win32.1432006610.zip 三.环境信息 系统:windows 7 旗舰版 防火墙:关闭 —— 注意:如果防火墙不关闭 ...
- paip.将数据导入到在英语语音数据库mysql道路解决空原则问题
paip.将数据导入到在英语语音数据库mysql道路解决空原则问题 #---原因:mysql 导入工具bug #---解决:不要使用双引号括注音. 笔者 老哇爪 Attilax 艾龙. EMAIL: ...
- Yii Framework2.0开发教程(5)数据库mysql性能
继续<Yii Framework2.0开发教程(3)数据库mysql入门> 首先给予一定的尊重yii2数据库支持引进 Yii 基于 PHP's PDO一个成熟的数据库访问层的建立.它提供了 ...
- cpanel导入大数据库(mysql)的方法
phpmyadmin是一件很方便的在线管理MySQL数据库的工具,但对于较大的数据库的导出和导入却很容易出错.特别是导入工作,通常5M已经是它的极限了.这里,主要介绍一下如何通过cPanel导入大型的 ...
- 前端学习数据库MYSQL
这篇文章主要写了 1.数据库MYSQL 2.基本上会遇到的所有SQL语句 数据库可视化软件------Navicat 数据库里边存放的是表,表与表之间是有关联的,而且可以对表进行相关操作(增,删,改, ...
随机推荐
- AS2在FLASH中调用EXE文件方法详细说明 已测试可行
熟悉FLASH功能的朋友都知道fscommand在FLASH中是一个经常用来控制窗口全屏或退出的命令,同时它也是FLASH调用外部可执行程序的一种方法,使用fscommand命令格式如下: fscom ...
- Centos6与Centos7防火墙设置与端口开放的方法
Centos升级到7之后,内置的防火墙已经从iptables变成了firewalld.所以,端口的开启还是要从两种情况来说明的,即iptables和firewalld.更多关于CentOs防火墙的最新 ...
- C#实现联合体
[StructLayout(LayoutKind.Explicit, Size = )] public struct TypeTransform { [FieldOffset()] public fl ...
- Servlet开发
源地址:http://www.cnblogs.com/xdp-gacl/p/3760336.html 一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun ...
- Eclipse编译Android项目时出现的问题:Android requires compiler compliance level 5.0 or 6.0. Found '1.8' instead.
Consle: Android requires compiler compliance level 5.0 or 6.0. Found '1.8' instead. Please use Andro ...
- mysql分表实战
本文主要讲述如何使用存储过程完成本表.并不讨论其他问题.首先我们得看看手册上关于meger引擎的说明: MERGE存储引擎,也被认识为MRG_MyISAM引擎,是一个相同的可以被当作一个来用的MyIS ...
- 29.Spring-基础.md
目录 1.目的和作用 [toc] 2.概念 2.1框架的设计 2.2控制反转 2.3AOP [toc] 3. 3.1Spring六大模块 [toc] 1.目的和作用 解决对象的创建和以及对象依赖关系的 ...
- Ajax 学习 第三篇
1.什么是json 第一种方法 第二种方法 比较evar and jsondata 任何时候使用EVAR要特别小心,他不会管输入对象的类型 JSONLint可以在线校验代码的正确性 改写代码
- 利用monkeyrunner、python脚本来做多设备多apk适配ui界面截屏的自动化测试
http://www.cnblogs.com/youxilua/archive/2011/11/25/2262715.html
- centos7.x修改网卡名字
1.编辑/etc/default/grub 加入如下代码 net.ifnames=0 biosdevname=0 2. 在执行以下 grub2-mkconfig -o /boot/grub2/gru ...