数据库面试

数据库知识点

是否了解内存数据库?

顾名思义就是将数据放在内存中直接操作的数据库。

相对于磁盘(传统的数据库管理系统把所有数据都放在磁盘上进行管理,所以称做磁盘数据库)

内存的数据读写速度要高出几个数量级,因此内存数据库的最大特点就是性能好,速度快。

由于内存在系统中是稀缺的资源,因此内存数据库的容量大小受物理内存的限制,而内存数据库也会被要求根据灵活的策略与磁盘数据库进行数据同步。安全性的问题可以说是内存数据库最大的硬伤。

因为内存本身有掉电丢失的天然缺陷。因此我们在使用内存数据库的时候,

通常需要,提前对内存上的数据采取一些保护机制,比如备份,记录日志,热备或集群,与磁盘数据库同步等方式。

内存数据库做为优秀内存数据库完全可以单独使用,并做好容灾以及扩展等。电信行业普遍在用。

1、触发器的作用?

答:触发器是一中特殊的存储过程,主要是通过事件来触发而被执行的。它可以强化约束,来维护数据的完整性和一致性,

可以跟踪数据库内的操作从而不允许未经许可的更新和变化。可以联级运算。如,某表上的触发器上包含对另一个表的数据操作,而该操作又会导致该表触发器被触发。

2、什么是存储过程?用什么来调用?

答:存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。

如果某次操作需要执行多次SQL,使用存储过程比单纯SQL语句执行要快。可以用一个命令对象来调用存储过程。

3、索引的作用?和它的优点缺点是什么?

答:索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据。

索引可以是唯一的,创建索引允许指定单个列或者是多个列。缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小。

4、什么是内存泄漏?

答:一般我们所说的内存泄漏指的是堆内存的泄漏。堆内存是程序从堆中为其分配的,大小任意的,使用完后要显示释放内存。

当应用程序用关键字new等创建对象时,就从堆中为它分配一块内存,使用完后程序调用free或者delete释放该内存,否则就说该内存就不能被使用,我们就说该内存被泄漏了。

5、维护数据库的完整性和一致性,你喜欢用触发器还是自写业务逻辑?为什么?

答:我是这样做的,尽可能使用约束,如check,主键,外键,非空字段等来约束,这样做效率最高,也最方便。其次是使用触发器,这种方法可以保证,无论什么业务系统访问数据库都可以保证数据的完整新和一致性。最后考虑的是自写业务逻辑,但这样做麻烦,编程复杂,效率低下。

6、什么是事务?什么是锁?

答:事务就是被绑定在一起作为一个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就被失败,以后操作就会回滚到操作前状态,或者是上有个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,

就需要通过ACID测试,即原子性,一致性,隔离性和持久性。锁:在DBMS中,锁是实现事务的关键,锁可以保证事务的完整性和并发性。与现实生活中锁一样,它可以使某些数据的拥有者,在某段时间内不能使用某些数据或数据结构。当然锁还分级别的。

7、什么叫视图?游标是什么?

答:视图是一种虚拟的表,具有和物理表相同的功能。可以对视图进行增,改,查,操作,视图通常是有一个表或者多个表的行或列的子集。

对视图的修改不影响基本表。它使得我们获取数据更容易,相比多表查询。

游标:是对查询出来的结果集作为一个单元来有效的处理。游标可以定在该单元中的特定行,从结果集的当前行检索一行或多行。

可以对结果集当前行做修改。一般不使用游标,但是需要逐条处理数据的时候,游标显得十分重要。

8.说说分库与分表设计

对于访问极为频繁且数据量巨大的单表来说,我们首先要做的就是减少单表的记录条数,以便减少数据查询所需要的时间,提高数据库的吞吐,这就是所谓的分表!

面对高并发的读写访问,对数据库进行拆分,从而提高数据库写入能力,这就是所谓的分库!

场景:有时数据库可能既面临着高并发访问的压力,又需要面对海量数据的存储问题,这时需要对数据库既采用分表策略,又采用分库策略,以便同时扩展系统的并发处理能力,以及提升单表的查询性能,这就是所谓的分库分表。

分库与分表带来的分布式困境与应对之策       

数据迁移与扩容,表关联,分页和排序,分布式事务,分布式全局唯一ID等问题。

9.说说 SQL 优化之道

对查询进行优化,要尽量避免全表扫描,首先应考虑在where order by 涉及的列上建立索引。exists代替 in ,具体的字段列表代替*,避免使用游标,因为游标的效率较差,尽量避免大事务操作,提高系统并发能力,Update语句,如果只更改12字段,不要Update全部字段。

10.数据库常用的函数有哪些?

----统计函数----

AVG  --求平均值

COUNT  --统计数目

MAX  --求最大值

MIN  --求最小值

SUM  --求和

----日期函数----
DAY()  --函数返回date_expression 中的日期值
MONTH()  --函数返回date_expression 中的月份值
YEAR()  --函数返回date_expression 中的年份值
DATENAME( , ) --函数以字符串的形式返回日期的指定部分
DATEPART( , ) --函数以整数值的形式返回日期的指定部分

----字符串函数----
ASCII()     --函数返回字符表达式最左端字符的ASCII 码值
CHAR()  --函数用于将ASCII 码转换为字符
  --如果没有输入0 ~ 255 之间的ASCII 码值CHAR 函数会返回一个NULL 值
LOWER()  --函数把字符串全部转换为小写
UPPER()  --函数把字符串全部转换为大写
STR()  --函数把数值型数据转换为字符型数据
LTRIM()  --函数把字符串头部的空格去掉
RTRIM()  --函数把字符串尾部的空格去掉

sql命令大全

1、创建数据库 create database database-name

2、删除数据库 drop database dbname

3、备份sql server

--- 创建备份数据的 device

use master

exec sp_addumpdevice 'disk', 'testBack','c:\mssql7backup\MyNwind_1.dat'

--- 开始备份

BACKUP database pubs TO testBack

4、创建新表create table tabname(col1 type1 [not null][primary key],col2 type2 [not null],..)

根据已有的表创建新表:

Acreate table tab_new like tab_old (使用旧表创建新表)

Bcreate table tab_new as select col1,col2 fromtab_old definition only

5、删除新表 drop table tabname

6、增加一个列alter table tabname add column colType

注:列增加后将不能删除,唯一能改变的是增加varchar类型的长度。

7、添加(删除)主键: alter table tabname add (drop) primarykey(col)

8、创建索引:create [unique] index idxname on tablename(col.)

   删除索引:dropindex idxname

   注:索引是不可更改的,想更改必须删除重新建。

9、创建(删除)视图:create(drop)  view viewname as select statement

10、说明:几个简单的基本的sql语句

选择:select * from table1where 范围

插入:insert intotable1(field1,field2) values(value1,value2)

删除:delete from table1where 范围

更新:update table1 setfield1=value1 where 范围

查找:select * from table1where field1 like %value1%

排序:select * from table1order by field1,field2 [desc]

总数:select count astotalcount from table1

求和:select sum(field1) assumvalue from table1

平均:select avg(field1) asavgvalue from table1

最大:select max(field1) asmaxvalue from table1

最小:select min(field1) asminvalue from table1

行列转化(max casewhen else))

       select Student as'姓名',

       max(case Subjectwhen '语文' then Score else 0 end) as '语文' ,

       max(case Subjectwhen '英语' then Score else 0 end ) as '英语'

       from Scores groupby Student

11、说明:几个高级查询运算词

A UNION 运算符

UNION 运算符通过组合其他两个结果表(例如 TABLE1 TABLE2)并消去表中任何重复行而派生出一个结果表。

ALL UNION 一起使用时(即UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2

B EXCEPT 运算符

EXCEPT运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。

ALL EXCEPT一起使用时 (EXCEPT ALL),不消除重复行。

C INTERSECT 运算符

INTERSECT运算符通过只包括 TABLE1 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。

ALLINTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。

注:使用运算词的几个查询结果行必须是一致的。

12、说明:使用外连接

Aleft outer join

左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。

SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT JOIN bON a.a = b.c

Bright outer join:

右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。

Cfull/cross outer join

全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。

12、分组:Group by having:

   一张表,一旦分组完成后,查询后只能得到组相关的信息。

    组相关的信息:(统计信息) count,sum,max,min,avg 分组的标准)

13、对数据库进行操作:

   分离数据库:sp_detach_db;附加数据库:sp_attach_db 后接表明,附加需要完整的路径名

14.如何修改数据库的名称:

sp_renamedb 'old_name', 'new_name'

你可能感兴趣的:(数据库面试)