1、MySQLhtml
一、mysql如何作分页mysql
mysql数据库作分页用limit关键字,它后面跟两个参数startIndex和pageSize面试
二、mysql引擎有哪些,各自的特色是什么?redis
http://www.cnblogs.com/ctztake/p/8453990.htmlsql
三、数据库怎么创建索引数据库
create index account_index on `table name `(`字段名`(length)django
四、一张表多个字段,怎么建立组合索引编程
create index account_index on `table name `(`字段名`,'字段名')windows
五、如何应对数据的高并发,大量的数据计算缓存
1.建立索引
2.数据库读写分离,两个数据库,一个做为写,一个做为读
3. 外键去掉
4.django中orm表性能相关的
select_related:
对于一对一字段(OneToOneField)和外键字段(ForeignKey),可使用select_related 来对QuerySet进行优化。
select_related主要针一对一和多对一关系进行优化。 select_related使用SQL的JOIN语句进行优化,经过减小SQL查询的次数来进行优化、提升性能。 能够经过可变长参数指定须要select_related的字段名。也能够经过使用双下划线“__”链接字段名来实现指定的递归查询。 没有指定的字段不会缓存,没有指定的深度不会缓存,若是要访问的话Django会再次进行SQL查询。 也能够经过depth参数指定递归的深度,Django会自动缓存指定深度内全部的字段。若是要访问指定深度外的字段,Django会再次进行SQL查询。 也接受无参数的调用,Django会尽量深的递归查询全部的字段。但注意有Django递归的限制和性能的浪费。 Django >= 1.7,链式调用的select_related至关于使用可变长参数。Django < 1.7,链式调用会致使前边的select_related失效,只保留最后一个。
prefetch_related:
对于多对多字段(ManyToManyField)和一对多字段,可使用prefetch_related()来进行优化。
prefetch_related()和select_related()的设计目的很类似,都是为了减小SQL查询的数量,可是实现的方式不同。后者是经过JOIN语句,在SQL查询内解决问题。
可是对于多对多关系,使用SQL语句解决就显得有些不太明智,由于JOIN获得的表将会很长,会致使SQL语句运行时间的增长和内存占用的增长。如有n个对象,每一个对象的多对多字段对应Mi条
,就会生成Σ(n)Mi 行的结果表。 prefetch_related()的解决方法是,分别查询每一个表,而后用Python处理他们之间的关系。
由于select_related()老是在单次SQL查询中解决问题,而prefetch_related()会对每一个相关表进行SQL查询,所以select_related()的效率一般比后者高。 鉴于第一条,尽量的用select_related()解决问题。只有在select_related()不能解决问题的时候再去想prefetch_related()。 你能够在一个QuerySet中同时使用select_related()和prefetch_related(),从而减小SQL查询的次数。 只有prefetch_related()以前的select_related()是有效的,以后的将会被无视掉
六、数据库内连表、左连表、右连表
内链接是根据某个条件链接两个表共有的数据
左链接是根据某个条件以及左边的表链接数据,右边的表没有数据的话则为null
右链接是根据某个条件以及右边的表链接数据,左边的表没有数据的话则为null
七、视图和表的区别
视图是已经编译好的sql语句,是基于sql语句的结果集的可视化的表,而表不是
视图是窗口,表示内容
视图没有实际的物理记录,而表有
视图是虚表,表是实表
视图的创建和删除只影响视图自己,不影响对应的表
八、关系型数据库的特色
数据集中控制
数据独立性高
数据共享性好
数据冗余度小
数据结构化
统一的数据保护能力
九、mysql数据库都有哪些索引
普通索引:普通索引仅有一个功能:加速查找
惟一索引:惟一索引两个功能:加速查找和惟一约束(可含null)
外键索引:外键索引两个功能:加速查找和惟一约束(不可为null)
联合索引:联合索引是将n个列组合成一个索引,应用场景:同时使用n列来进行查询
触发器
使用触发器能够定制用户对表进行【增、删、改】操做时先后的行为,注意:没有查询


# 插入前 CREATE TRIGGER tri_before_insert_tb1 BEFORE INSERT ON tb1 FOR EACH ROW BEGIN ... END # 插入后 CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROW BEGIN ... END # 删除前 CREATE TRIGGER tri_before_delete_tb1 BEFORE DELETE ON tb1 FOR EACH ROW BEGIN ... END # 删除后 CREATE TRIGGER tri_after_delete_tb1 AFTER DELETE ON tb1 FOR EACH ROW BEGIN ... END # 更新前 CREATE TRIGGER tri_before_update_tb1 BEFORE UPDATE ON tb1 FOR EACH ROW BEGIN ... END # 更新后 CREATE TRIGGER tri_after_update_tb1 AFTER UPDATE ON tb1 FOR EACH ROW BEGIN ... END


#准备表 CREATE TABLE cmd ( id INT PRIMARY KEY auto_increment, USER CHAR (32), priv CHAR (10), cmd CHAR (64), sub_time datetime, #提交时间 success enum ('yes', 'no') #0表明执行失败 ); CREATE TABLE errlog ( id INT PRIMARY KEY auto_increment, err_cmd CHAR (64), err_time datetime ); #建立触发器 delimiter // CREATE TRIGGER tri_after_insert_cmd AFTER INSERT ON cmd FOR EACH ROW BEGIN IF NEW.success = 'no' THEN #等值判断只有一个等号 INSERT INTO errlog(err_cmd, err_time) VALUES(NEW.cmd, NEW.sub_time) ; #必须加分号 END IF ; #必须加分号 END// delimiter ; #往表cmd中插入记录,触发触发器,根据IF的条件决定是否插入错误日志 INSERT INTO cmd ( USER, priv, cmd, sub_time, success ) VALUES ('egon','0755','ls -l /etc',NOW(),'yes'), ('egon','0755','cat /etc/passwd',NOW(),'no'), ('egon','0755','useradd xxx',NOW(),'no'), ('egon','0755','ps aux',NOW(),'yes'); #查询错误日志,发现有两条 mysql> select * from errlog; +----+-----------------+---------------------+ | id | err_cmd | err_time | +----+-----------------+---------------------+ | 1 | cat /etc/passwd | 2017-09-14 22:18:48 | | 2 | useradd xxx | 2017-09-14 22:18:48 | +----+-----------------+---------------------+ rows in set (0.00 sec) 插入后触发触发器
特别的:NEW表示即将插入的数据行,OLD表示即将删除的数据行。
二 使用触发器
触发器没法由用户直接调用,而知因为对表的【增/删/改】操做被动引起的。
三 删除触发器
drop trigger tri_after_insert_cmd;
十、存储过程
http://www.cnblogs.com/ctztake/p/7544559.html
存储过程不容许执行return语句,可是能够经过out参数返回多个值,存储过程通常是做为一个独立的部分来执行,存储过程是一个预编译的SQL语句。
十一、sql优化:
选取最适用的字段属性
使用链接(JOIN)来代替子查询(Sub-Queries)
select句中避免使用 '*'
减小访问数据库的次数
删除重复记录
用where子句替代having子句
减小对表的查询
explain
十二、char和vachar区别:
char是固定长度,存储须要空间12个字节,处理速度比vachar快,费内存空间,当存储的值没有达到指定的范围时,会用空格替代
vachar是不固定长度,须要存储空间13个字节,节约存储空间,存储的是真实的值,会在存储的值前面加上1-2个字节,用来表示真实数据的大小
1三、Mechached与redis
mechached:只支持字符串,不能持久化,数据仅存在内存中,宕机或重启数据将所有失效
不能进行分布式扩展,文件没法异步法。
优势:mechached进程运行以后,会预申请一块较大的内存空间,本身进行管理。
redis:支持服务器端的数据类型,redis与memcached相比来讲,拥有更多的数据结构和并发支持更丰富的数据操做,可持久化。
五大类型数据:string、hash、list、set和有序集合,redis是单进程单线程的。
缺点:数据库的容量受到物理内存的限制。
1四、sql注入
sql注入是比较常见的攻击方式之一,针对编程员编程的疏忽,经过sql语句,实现帐号没法登录,甚至篡改数据库。
防止:凡涉及到执行sql中有变量时,切记不要用拼接字符串的方法
1六、游标是什么?
是对查询出来的结果集做为一个单元来有效的处理,游标能够定在该单元中的特定行,从结果集的当前行检索一行或多行,能够对结果集当前行作修改,
通常不使用游标,可是须要逐条处理数据的时候,游标显得十分重要
1七、 数据库支持多有标准的SQL数据类型,重要分为三类
数值类型(tinyint,int,bigint,浮点数,bit)
字符串类型(char和vachar,enum,text,set)
日期类型(date,datetime,timestamp)
枚举类型与集合类型
1八、mysql慢查询
慢查询对于跟踪有问题的查询颇有用,能够分析出当前程序里哪些sql语句比较耗费资源
慢查询定义:
指mysql记录全部执行超过long_query_time参数设定的时间值的sql语句,慢查询日志就是记录这些sql的日志。
mysql在windows系统中的配置文件通常是my.ini找到mysqld
log-slow-queries = F:\MySQL\log\mysqlslowquery.log 为慢查询日志存放的位置,通常要有可写权限
long_query_time = 2 2表示查询超过两秒才记录
1九、memcached命中率
命中:能够直接经过缓存获取到须要的数据
不命中:没法直接经过缓存获取到想要的数据,须要再次查询数据库或者执行其余的操做,缘由多是因为缓存中根本不存在,或者缓存已通过期
缓存的命中率越高则表示使用缓存的收益越高,应额用的性能越好,抗病发能力越强
运行state命令能够查看memcached服务的状态信息,其中cmd—get表示总的get次数,get—hits表示命中次数,命中率=get—hits / cmd—get
20、Oracle和MySQL该如何选择,为何?
他们都有各自的优势和缺点。考虑到时间因素,我倾向于MySQL
选择MySQL而不选Oracle的缘由
MySQL开源
MySQL轻便快捷
MySQL对命令行和图形界面的支持都很好
MySQL支持经过Query Browser进行管理
2一、什么状况下适合创建索引?
1.为常常出如今关键字order by、group by、distinct后面的字段,创建索引
2.在union等集合操做的结果集字段上,创建索引,其创建索引的目的同上
3.为常常用做查询选择的字段,创建索引
4.在常常用做表链接的属性上,创建索引
2二、数据库底层是用什么结构实现的,你大体画一下:
底层用B+数实现,结构图参考:
http://blog.csdn.net/cjfeii/article/details/10858721
http://blog.csdn.net/tonyxf121/article/details/8393545
2三、sql语句应该考虑哪些安全性?
1.防止sql注入,对特殊字符进行转义,过滤或者使用预编译的sql语句绑定变量
2.最小权限原则,特别是不要用root帐户,为不一样的类型的动做或者组建使用不一样的帐户
3.当sql运行出错时,不要把数据库返回的错误信息所有显示给用户,以防止泄漏服务器和数据库相关信息
2四、数据库事物有哪几种?
隔离性、持续性、一致性、原子性
2五、MySQ数据表在什么状况下容易损坏?
服务器忽然断电致使数据文件损坏
强制关机,没有先关闭mysq服务器等
2六、drop、delete与truncate的区别
当表被TRUNCATE 后,这个表和索引所占用的空间会恢复到初始大小,
DELETE操做不会减小表或索引所占用的空间。
drop语句将表所占用的空间全释放掉。
1、delete 1、delete是DML,执行delete操做时,每次从表中删除一行,而且同时将该行的的删除操做记录在redo和undo表空间中以便进行回滚(rollback)和重作操做,但要注意表空间要足够大,
须要手动提交(commit)操做才能生效,能够经过rollback撤消操做。 2、delete可根据条件删除表中知足条件的数据,若是不指定where子句,那么删除表中全部记录。 3、delete语句不影响表所占用的extent,高水线(high watermark)保持原位置不变。 2、truncate 1、truncate是DDL,会隐式提交,因此,不能回滚,不会触发触发器。 2、truncate会删除表中全部记录,而且将从新设置高水线和全部的索引,缺省状况下将空间释放到minextents个extent,除非使用reuse storage,。不会记录日志,因此执行速度很快,
但不能经过rollback撤消操做(若是一不当心把一个表truncate掉,也是能够恢复的,只是不能经过rollback来恢复)。 3、对于外键(foreignkey )约束引用的表,不能使用 truncate table,而应使用不带 where 子句的 delete 语句。 4、truncatetable不能用于参与了索引视图的表。 3、drop 1、drop是DDL,会隐式提交,因此,不能回滚,不会触发触发器。 2、drop语句删除表结构及全部数据,并将表所占用的空间所有释放。 三、drop语句将删除表的结构所依赖的约束,触发器,索引,依赖于该表的存储过程/函数将保留,可是变为invalid状态。
2七、数据库范式
1.第一范式:就是无重复的列
2.第二范式:就是非主属性非部分依赖于主关键字
3.第三范式:就是属性不依赖于其余非主属性(消除冗余)
2八、MySQL锁类型
根据锁的类型分:能够分为共享锁、排他锁、意向共享锁和意向排他锁
根据锁的粒度分:能够分为行锁、表锁
对于mysql而言,事务机制更可能是靠底层的存储引擎来实现的,所以,mysql层面只有表锁,
而支持事物的innodb存储引发则实现了行锁(在行相应的索引记录上的锁)
说明:对于更新操做(读不上锁),只有走索引才可能上行锁
MVCC(多版本并发控制)并发控制机制下,任何操做都不会阻塞读取操做,
读取操做也不会阻塞任何操做,只由于读不上锁
共享锁:由读表操做加上的锁,加锁后其余用户只能获取该表或行的共享锁,不能获取排他锁,
也就是说只能读不能写
排他锁:由写表操做加上的锁,加锁后其余用户不能获取该表或该行的任何锁,典型mysql事物中的更新操做
意向共享锁(IS):事物打算给数据行加行共享锁,事物在给一个数据行加共享锁前必须先取得该表的IS锁
意向排他锁(IX):事物打算给数据行加行排他锁,事物在给一个数据行家排他锁前必须先取得该表的IX锁
2九、如何解决MYSQL数据库中文乱码问题?
1.在数据库安装的时候指定字符集
2.若是在按完了之后能够更改配置文件
3.创建数据库时候:指定字符集类型
4.建表的时候也指定字符集
30、数据库应用系统设计
1.规划 2.需求分析 3.概念模型设计 4.逻辑设计 5.物理设计 6. 程序编制及调试 7.运行及维护 ps:数据库常见面试问题总结 https://yq.aliyun.com/wenji/