sql常见面试题
- 格式:doc
- 大小:78.50 KB
- 文档页数:21
sql常见的面试题1. 基本概念和语法a. 什么是SQL?它的作用是什么?b. SQL的分类有哪些?c. SQL中常见的数据类型有哪些?d. 什么是表?如何创建表?e. 如何插入数据到表中?f. 如何查询表中的数据?g. 如何更新和删除表中的数据?h. 什么是索引?如何创建和使用索引?2. 数据库查询a. 如何使用SELECT语句查询表中的数据?b. SELECT语句中常见的聚合函数有哪些?如何使用它们?c. 如何使用WHERE子句过滤查询结果?d. 如何使用ORDER BY子句对查询结果进行排序?e. 如何使用LIMIT子句限制查询结果的数量?f. 如何使用JOIN操作进行多表查询?3. 数据库修改和删除操作a. 如何使用INSERT语句插入新数据?b. 如何使用UPDATE语句更新数据?c. 如何使用DELETE语句删除数据?d. 如何使用ALTER TABLE语句修改表的结构?4. 数据库设计和优化a. 什么是数据库范式?常见的数据库范式有哪些?b. 什么是索引?如何选择合适的索引?c. 如何进行数据库性能优化?d. 什么是数据库事务?如何使用事务进行数据的一致性维护?5. 数据库安全和权限管理a. 如何创建用户并为其分配权限?b. 如何控制用户对数据库对象的访问权限?c. 如何保护数据库的安全性?6. 数据库备份和恢复a. 为什么需要数据库备份?b. 数据库备份的常见方法有哪些?c. 如何进行数据库的恢复操作?7. 高级SQL问题a. 如何使用子查询进行复杂的数据查询?b. 如何使用常用的SQL函数完成特定的数据操作?c. 如何使用触发器和存储过程实现自动化的数据处理任务?总结:在面试中,对SQL的基本概念、查询操作和修改操作的熟练掌握是很重要的。
此外,了解数据库设计、安全和性能优化等方面的知识也会给你在面试中加分。
希望本文给你提供了一些常见的SQL面试题及其解答,帮助你在面试中有所准备。
sql语句面试题及答案一、基本查询1. 简单查询请问如何查询一个表中的所有记录?答:可以使用SELECT * FROM table_name; 命令来查询表中的所有记录。
2. 条件查询如果我只想查询特定条件下的记录,例如查询年龄大于30的员工信息,应该怎么做?答:可以使用WHERE子句来进行条件查询,语句如下:SELECT * FROM employees WHERE age > 30;3. 限制查询结果在查询时,如果只想获取前5条记录,应该如何操作?答:可以使用LIMIT关键字来限制查询结果的数量,语句如下:SELECT * FROM table_name LIMIT 5;二、聚合查询1. 计数如何计算某个表中的记录数?答:可以使用COUNT()函数来计算表中的记录数,语句如下:SELECT COUNT(*) FROM table_name;2. 求和如果需要计算某列的总和,例如计算销售总额,应该怎么做?答:可以使用SUM()函数来计算某列的总和,语句如下:SELECT SUM(sales_amount) FROM sales_table;3. 平均值如何求某列的平均值,比如平均工资?答:可以使用AVG()函数来计算某列的平均值,语句如下:SELECT AVG(salary) FROM employees;三、分组查询1. 分组统计请问如何按照某个字段进行分组,并计算每个分组的记录数?答:可以使用GROUP BY子句来进行分组统计,语句如下:SELECT department, COUNT(*) FROM employees GROUP BY department;2. 多列分组如果需要按照多个字段进行分组,应该如何操作?答:可以在GROUP BY子句中列出所有需要分组的字段,语句如下:SELECT department, job_title, COUNT(*) FROM employees GROUP BY department, job_title;3. 分组聚合运算在分组查询中,如何对每个分组执行聚合运算,例如计算每个部门的最高工资?答:可以使用GROUP BY子句结合聚合函数来进行分组聚合运算,语句如下:SELECT department, MAX(salary) AS max_salary FROM employees GROUP BY department;四、连接查询1. 内连接如何查询两个表中有关联的记录?答:可以使用INNER JOIN来查询两个表中有关联的记录,语句如下:SELECT * FROM table1 INNER JOIN table2 ON mon_field = mon_field;2. 左连接如果需要查询左表的所有记录,以及右表中与之关联的记录,没有关联的则显示NULL,应该怎么做?答:可以使用LEFT JOIN来实现,语句如下:SELECT * FROM table1 LEFT JOIN table2 ON mon_field = mon_field;3. 右连接请问如何查询右表的所有记录,以及左表中与之关联的记录?答:可以使用RIGHT JOIN来实现,语句如下:SELECT * FROM table1 RIGHT JOIN table2 ON mon_field = mon_field;五、子查询1. 非相关子查询在查询时,如果需要在WHERE子句中使用一个SELECT语句作为条件,应该怎么做?答:可以使用非相关子查询来实现,语句如下:SELECT * FROM table1 WHERE column_name IN (SELECT column_name FROM table2);2. 相关子查询如果子查询需要引用外部查询的列,应该怎么做?答:可以使用相关子查询,在子查询中使用外部查询的列,语句如下:SELECT * FROM table1 WHERE column_name = (SELECT column_name FROM table2 WHERE related_column = table1.related_column);六、更新和删除操作1. 更新数据请问如何使用SQL语句来更新表中的记录?答:可以使用UPDATE语句来更新表中的记录,语句如下:UPDATE table_name SET column1 = value1, column2 = value2 WHERE condition;2. 删除数据如果需要删除表中的某些记录,应该如何操作?答:可以使用DELETE语句来删除记录,语句如下:DELETE FROM table_name WHERE condition;七、排序和索引1. 排序查询结果如何对查询结果进行排序?答:可以使用ORDER BY子句对查询结果进行排序,语句如下:SELECT * FROM table_name ORDER BY column_name ASC/DESC;2. 创建索引为了提高查询效率,如何为表中的列创建索引?答:可以使用CREATE INDEX语句来创建索引,语句如下:CREATE INDEX index_name ON table_name (column_name);通过以上问题的探讨,我们了解了SQL语句在面试中常见的问题及答案。
sql语句面试题及答案本文将为您提供一些常见的SQL语句面试题,并给出相应的答案。
通过阅读本文,您将对SQL语句有更深入的了解,从而在面试中更加自信。
一、查询相关的面试题1. 如何用SQL语句查询一张表的所有记录?答案:使用SELECT语句来查询表中的所有记录,语法为:SELECT * FROM 表名;2. 如何查询指定条件的记录?答案:使用SELECT语句的WHERE子句来查询指定条件的记录,语法为:SELECT * FROM 表名 WHERE 条件;3. 如何对查询结果进行排序?答案:使用SELECT语句的ORDER BY子句来对查询结果进行排序,语法为:SELECT * FROM 表名 ORDER BY 列名 ASC/DESC;4. 如何获取查询结果的前几条记录?答案:使用SELECT语句的TOP或LIMIT子句来获取查询结果的前几条记录,语法为:SELECT TOP 数量 * FROM 表名; 或 SELECT * FROM 表名 LIMIT 数量;5. 如何对查询结果进行分页?答案:使用SELECT语句的LIMIT子句来实现分页效果,语法为:SELECT * FROM 表名 LIMIT 起始位置, 每页数量;二、插入、更新和删除相关的面试题1. 如何插入一条新记录?答案:使用INSERT INTO语句来插入一条新记录,语法为:INSERT INTO 表名 (列1, 列2, 列3) VALUES (值1, 值2, 值3);2. 如何更新已有的记录?答案:使用UPDATE语句来更新已有的记录,语法为:UPDATE表名 SET 列名 = 新值 WHERE 条件;3. 如何删除指定的记录?答案:使用DELETE FROM语句来删除指定的记录,语法为:DELETE FROM 表名 WHERE 条件;三、聚合函数相关的面试题1. 如何计算表中记录的数量?答案:使用COUNT(*)函数来计算表中记录的数量,语法为:SELECT COUNT(*) FROM 表名;2. 如何计算某一列的总和?答案:使用SUM(列名)函数来计算某一列的总和,语法为:SELECT SUM(列名) FROM 表名;3. 如何计算某一列的平均值?答案:使用AVG(列名)函数来计算某一列的平均值,语法为:SELECT AVG(列名) FROM 表名;四、连接查询相关的面试题1. 如何在两个表之间进行连接查询?答案:使用JOIN语句来进行连接查询,语法为:SELECT * FROM 表1 JOIN 表2 ON 表1.列 = 表2.列;2. 如何实现左连接和右连接?答案:使用LEFT JOIN或RIGHT JOIN来实现左连接和右连接,语法为:SELECT * FROM 表1 LEFT JOIN 表2 ON 表1.列 = 表2.列; 或SELECT * FROM 表1 RIGHT JOIN 表2 ON 表1.列 = 表2.列;五、其他面试题1. 如何创建一个新表?答案:使用CREATE TABLE语句来创建一个新表,语法为:CREATE TABLE 表名 (列1 数据类型, 列2 数据类型, 列3 数据类型);2. 如何修改表的结构?答案:使用ALTER TABLE语句来修改表的结构,语法为:ALTER TABLE 表名 ADD 列名数据类型; 或 ALTER TABLE 表名DROP 列名;3. 如何在表中创建索引?答案:使用CREATE INDEX语句来在表中创建索引,语法为:CREATE INDEX 索引名 ON 表名 (列名);总结:本文介绍了一些常见的SQL语句面试题和对应的答案,涵盖了查询、插入、更新、删除、聚合函数、连接查询、表的创建和修改等方面。
常见sql面试题SQL(Structured Query Language)是一种用于管理关系型数据库的标准语言。
许多公司都使用SQL语言进行数据操作和管理。
以下是一些常见的SQL面试题:第一部分:基本概念和语法1. SQL是什么?它的作用是什么?2. SQL语句中有哪些基本的语句类型?3. 什么是SQL注释?如何使用注释?4. SQL语句中的通配符是什么?如何使用通配符?5. SQL中的保留字有哪些?第二部分:数据查询1. 什么是SQL查询?如何使用SELECT语句查询数据?2. 如何使用WHERE语句进行数据筛选?3. 如何进行多个条件的查询?4. 如何对数据进行排序?5. 如何使用LIMIT语句限制查询结果的数量?第三部分:数据操作1. 如何使用INSERT语句插入数据?2. 如何使用UPDATE语句修改数据?3. 如何使用DELETE语句删除数据?4. 如何使用TRUNCATE语句清空整张表?5. 如何使用DROP语句删除整张表?第四部分:数据关联和维护1. 什么是SQL关联查询?如何进行关联查询?2. 如何使用UNION语句合并查询结果?3. 如何使用JOIN语句进行表连接操作?4. 如何使用GROUP BY语句进行分组操作?5. 如何使用HAVING语句进行分组筛选?第五部分:数据约束和事务管理1. 什么是SQL数据约束?如何使用数据约束?2. SQL中有哪些常见的数据约束类型?3. 什么是SQL事务管理?如何进行事务的提交和回滚?4. 如何使用ACID规则确保数据的一致性和完整性?5. 什么是SQL索引?如何进行索引的创建和删除?以上是常见的SQL面试题,除此之外还会涉及到一些高级的SQL操作和优化技巧。
在面试前要充分准备,熟悉各种SQL语法和操作,并且要有实战经验。
sql面试必会6题经典面试题
1. SQL有哪些数据类型?
SQL数据类型包括:数值类型(整数、实数、位类型)、字符串类型(字符串、固定长度字符串、可变长度字符串)、日期/时间类型、二进制类型以及用户自定义的特殊类型。
2. 什么是 SQL 联合查询?
SQL联合查询是一种在单个查询中使用多个表进行信息检索的技术,可以将多个相关表中的数据检索出来并进行合并显示。
常用的联合查询有内连接(Inner Join)、左外连接(Left Join)、右外连接(Right Join)、全外连接(Full Join)等。
3. 什么是 SQL 索引?
SQL索引是数据库表中用于快速检索数据的数据结构,它可以加快数据库表中某一列或多列上的查询速度。
常见的索引类型有B树索引、哈希索引、空间索引等。
4. 什么是SQL视图?
SQL视图是一种虚拟表,用于从一个或多个表中检索数据,并提供一种抽象的方法来访问表中的数据。
它可以让用户只能看到所需要看到的列和行,而不需要查看整个表。
5. SQL语句有哪些?
SQL语句有以下几种:CREATE(创建)、SELECT(查询)、INSERT(插入)、UPDATE(更新)、DELETE(删除)、ALTER(修改)、DROP(删除)等。
6. 什么是子查询?
子查询是一种在SQL语句中嵌套另一个完整的SQL语句的查询,它可以从其它表中检索数据,也可以从当前表中检索数据。
它可以让你更有效地检索数据,并且可以让你在不使用连接的情况下实现类似于连接的结果。
sql面试题及答案数据库面试的技术员,对常见的面试题目了解会对面试结果有所帮助。
以下是为大家的sql面试题及答案,希望可以帮到大家。
1. 在一个查询中,使用哪一个关键字能够除去重复列值?答案:使用distinct关键字2. 什么是快照?它的作用是什么?答案:快照Snapshot是一个文件系统在特定时间里的镜像,对于在线实时数据备份非常有用。
快照对于拥有不能停顿的应用或具有常翻开文件的文件系统的备份非常重要。
对于只能提供一个非常短的备份时间而言,快照能保证系统的完整性。
3. 解释存储过程和触发器答案:存储过程是一组Transact-SQL语句,在一次编译后可以执行屡次。
因为不必重新编译Transact-SQL语句,所以执行存储过程可以提高性能。
触发器是一种特殊类型的存储过程,不由用户直接调用。
创立触发器时会对其进展定义,以便在对特定表或列作特定类型的数据修改时执行。
4. SQL Server是否支持行级锁,有什么好处?答案:支持动态行级锁定SQL Server 2000动态地将查询所引用的每一个表的锁定粒度调整到适宜的级别。
当查询所引用的少数几行分散在一个大型表中时,优化数据并行访问的最正确方法是使用粒度锁,如行锁。
但是,如果查询引用的是一个表中的大多数行或所有行,优化数据并行访问的最正确方法可以是锁定整个表,以尽量减少锁定开销并尽快完成查询。
SQL Serve 2000通过为每个查询中的每个表选择适当的锁定级别,在总体上优化了数据并发访问。
对于一个查询,如果只引用一个大型表中的几行,那么数据库引擎可以使用行级锁定;如果引用一个大型表的几页中的多行,那么使用页级锁定;如果引用一个小型表中的所有行,那么使用表级锁定。
5. 数据库日志干什么用,数据库日志满的时候再查询数据库时会出现什么情况。
答案:每个数据库都有事务日志,用以记录所有事务和每个事务对数据库所做的修改。
6. 存储过程和函数的区别?答案:存储过程是用户定义的一系列SQL语句的集合,涉及特定表或其它对象的任务,用户可以调用存储过程,而函数通常是数据库已定义的方法,它接收参数并返回某种类型的值并且不涉及特定用户表7. 事务是什么?答案:事务是作为一个逻辑单元执行的一系列操作,一个逻辑工作单元必须有四个属性,称为 ACID(原子性、一致性、隔离性和持久性)属性,只有这样才能成为一个事务:(1) 原子性事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。
Sql常见面试题受用了1.用一条SQL 语句查询出每门课都大于80 分的学生姓名name kecheng fenshu张三语文 81张三数学 75李四语文 76李四数学 90王五语文 81王五数学 100王五英语 90A: select distinct name from table where name not in (select distinct name from table where fenshu<=80)select name from table group by name having min(fenshu)>802.学生表如下:自动编号学号姓名课程编号课程名称分数1 2005001 张三 0001 数学 692 2005002 李四 0001 数学 893 2005001 张三 0001 数学 69删除除了自动编号不同, 其他都相同的学生冗余信息A: delete tablename where 自动编号 not in(select min( 自动编号) from tablename group by 学号, 姓名, 课程编号, 课程名称, 分数)3.一个叫team 的表,里面只有一个字段name, 一共有4 条纪录,分别是a,b,c,d, 对应四个球对,现在四个球对进行比赛,用一条sql 语句显示所有可能的比赛组合.你先按你自己的想法做一下,看结果有我的这个简单吗?答:select , from team a, team bwhere < 4.请用SQL 语句实现:从TestDB 数据表中查询出所有月份的发生额都比101 科目相应月份的发生额高的科目。
请注意:TestDB 中有很多科目,都有1 -12 月份的发生额。
AccID :科目代码,Occmonth :发生额月份,DebitOccur :发生额。
数据库名:JcyAudit ,数据集:Select * from TestDB答:select a.*from TestDB a,(select Occmonth,max(DebitOccur) Debit101ccur from TestDB where AccID='101' group by Occmonth) bwhere a.Occmonth=b.Occmonth and a.DebitOccur>b.Debit101ccur********************************************************************* ***************5.面试题:怎么把这样一个表儿year month amount1991 1 1.11991 2 1.21991 3 1.31991 4 1.41992 1 2.11992 2 2.21992 3 2.31992 4 2.4查成这样一个结果year m1 m2 m3 m41991 1.1 1.2 1.3 1.41992 2.1 2.2 2.3 2.4答案一、select year,(select amount from aaa m where month=1 and m.year=aaa.year) as m1, (select amount from aaa m where month=2 and m.year=aaa.year) as m2, (select amount from aaa m where month=3 and m.year=aaa.year) as m3, (select amount from aaa m where month=4 and m.year=aaa.year) as m4 from aaa group by year********************************************************************* **********6.说明:复制表( 只复制结构, 源表名:a 新表名:b)SQL: select * into b from a where 1<>1 (where1=1,拷贝表结构和数据内容)ORACLE:create table bAsSelect * from a where 1=2[<>(不等于)(SQL Server Compact)比较两个表达式。
sql面试题SQL(Structured Query Language)是用于管理和操作关系型数据库的标准语言。
在面试中,SQL面试题经常被用来评估应聘者对SQL的理解和使用能力。
以下是一些常见的SQL面试题及其答案,供参考。
1. 请解释什么是SQL?SQL是一种用于管理和操作关系型数据库的标准化语言。
它包含了一系列的命令和功能,用于创建、查询、修改和删除数据库中的数据和结构。
2. 请解释什么是关系型数据库?关系型数据库是一种基于表格的数据库管理系统,它使用了表、行和列的结构来组织和存储数据。
表由行和列组成,每行代表一个记录,每列代表一个属性。
3. 请解释什么是主键?主键是一列或一组列,用来唯一地标识表中的每个记录。
它的值必须是唯一且不为空。
主键对于确保数据完整性和表之间的引用非常重要。
4. 请解释什么是外键?外键是用来建立表与表之间的关联的列。
外键的值必须是另一张表中的主键值,用于确保数据的一致性和引用完整性。
5. 请解释什么是索引?索引是一种数据结构,用于快速查找表中的记录。
它可以提高查询的性能,但会增加写操作的开销。
常见的索引类型包括主键索引、唯一索引和普通索引。
6. 请解释什么是事务?事务是一组数据库操作,它们被视为一个不可分割的工作单位。
事务具有四个特性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability),以确保数据库的数据一致性和完整性。
7. 请解释什么是子查询?子查询是嵌套在主查询中的查询语句。
它可以作为主查询的条件或提供数据集合。
子查询通常用于限制查询结果或获取相关数据。
8. 请解释什么是联结?联结是将两个或多个表的行组合在一起,形成一个新的集合。
联结通常通过在相关列上进行比较来实现,它是查询多个表的常见操作。
9. 请解释什么是触发器?触发器是与表相关的特殊类型的存储过程。
它在插入、更新或删除数据时自动触发,用于执行特定的操作或应用业务规则。
以下是在SQL面试中常见的一些问题:
1.解释一下什么是SQL?
2.解释一下什么是索引?其作用是什么?
3.解释一下什么是视图?视图的作用是什么?
4.解释一下什么是存储过程?存储过程的作用是什么?
5.解释一下什么是触发器?触发器的作用是什么?
6.解释一下什么是事务?事务的作用是什么?
7.解释一下什么是锁?锁的作用是什么?
8.解释一下什么是游标?游标的作用是什么?
9.解释一下什么是数据完整性?如何保证数据完整性?
10.解释一下什么是主键?主键的作用是什么?
11.解释一下什么是排序查询?排序查询的作用是什么?
12.解释一下什么是分组查询?分组查询的作用是什么?
13.解释一下什么是聚合函数?常用的聚合函数有哪些?其作用是什么?
14.解释一下什么是窗口函数?窗口函数的作用是什么?
15.解释一下什么是数据库的完整性约束条件及其作用。
16.解释一下什么是SQL注入攻击以及如何防范。
17.请简述索引的原理及优缺点。
18.请简述数据库的ACID特性。
19.请简述SQL语句的优化方法。
20.请简述数据库的备份与恢复策略。
21.请简述数据库的优化策略。
22.请简述数据库的并发控制策略。
23.请简述数据库的故障排除方法。
24.请简述数据库的安全性控制方法。
25.请简述数据库的日志管理方法。
sql面试题大全SQL(Structured Query Language)是一种用于管理关系型数据库的标准化语言。
在数据库相关的职位面试中,SQL面试题是常见的一种考察方式。
本文将为您提供一份SQL面试题大全,帮助您更好地准备面试。
1. SELECT语句SELECT语句用于从数据库中检索数据。
以下是一些常见的SELECT语句相关的面试题:- 请解释SELECT语句中的DISTINCT关键字的作用。
- 如何使用WHERE子句来过滤结果?- 什么是表达式(Expression)和谓词(Predicate)?- 请解释SQL中的NULL值和未知值(UNKNOWN)的区别。
2. 数据库表操作数据库表操作是SQL中的核心操作之一。
以下是一些常见的数据库表操作相关的面试题:- 如何创建一个新的数据库表?- 如何添加列、删除列或修改列的定义?- 如何添加主键(Primary Key)和外键(Foreign Key)约束?- 请解释SQL中的合并(JOIN)操作和不同类型的合并操作的区别。
3. 数据查询与过滤数据查询与过滤是SQL中的重要方面,以下是一些相关的面试题:- 如何使用GROUP BY子句对数据进行分组?- 如何使用HAVING子句过滤分组数据?- 请解释SQL中的聚合函数(Aggregate Functions)的作用和常见的聚合函数有哪些?- 如何使用ORDER BY子句对结果进行排序?4. 数据更新与删除数据更新与删除是SQL中的常见操作之一。
以下是一些相关的面试题:- 如何使用INSERT语句向数据库表中插入新的数据?- 如何使用UPDATE语句更新已有的数据?- 如何使用DELETE语句从数据库中删除数据?- 请解释SQL中的事务(Transaction)和事务的四个特性(ACID)。
5. 数据库索引与优化数据库索引和优化是提高数据库性能的重要手段。
以下是一些相关的面试题:- 请解释数据库索引的作用和常见的索引类型有哪些?- 如何使用索引来优化SQL查询?- 什么是数据库的查询执行计划(Execution Plan)?- 请解释SQL中的表锁(Table Lock)和行锁(Row Lock)。
五. 数据库部分1、用两种方式根据部门号从高到低,工资从低到高列出每个员工的信息。
select * from employee order by deptid desc ,salary asc2、列出各个部门中工资高于本部门的平均工资的员工数和部门号,并按部门号排序创建表:mysql> create table employee921(id int primary key auto_increment,name varchar(5 0),salary bigint,deptid int);插入实验数据:mysql> insert into employee921 values(null,'zs',1000,1),(null,'ls',1100,1),(null,'ww',1100,1),(null,'zl',900,1) ,(null,'zl',1000,2), (null,'zl',900,2) ,(null,'zl',1000,2) , (null,'zl',1100,2);编写sql语句:()select avg(salary) from employee921 group by deptid;()mysql> selectemployee921.id,,employee921.salary,employee921.deptid tid from employee921 where salary > (select avg(salary) from employee921 where deptid = tid) order by salary效率低的一个语句,仅供学习参考使用(在group by之后不能使用where,只能使用having,在group by之前可以使用where,即表示对过滤后的结果分组):mysql> selectemployee921.id,,employee921.salary,employee921.deptid tid from employee921 where salary > (select avg(salary) from employee921 group by deptid having deptid = tid);()select count(*) ,tid from (select employee921.id,,employee921.salary,employee921.deptid tid from employee921where salary >(select avg(salary) from employee921 where deptid = tid)) as tgroup by tid ;另外一种方式:关联查询select a.ename,a.salary,a.deptidfrom emp a,(select deptd,avg(salary) avgsal from emp group by deptid ) bwhere a.deptid=b.deptid and a.salary>b.avgsal;3、存储过程与触发器必须讲,经常被面试到?create procedure insert_Student (_name varchar(50),_age int ,out _id int)begininsert into student value(null,_name,_age);select max(stuId) into _id from student;end;call insert_Student('wfz',23,@id);select @id;mysql> create trigger update_Student BEFORE update on student FOR EACH ROW -> select * from student;触发器不允许返回结果create trigger update_Student BEFORE update on student FOR EACH ROWinsert into student value(null,'zxx',28);mysql的触发器目前不能对当前表进行操作create trigger update_Student BEFORE update on student FOR EACH ROWdelete from articles where id=8;这个例子不是很好,最好是用删除一个用户时,顺带删除该用户的所有帖子这里要注意使用OLD.id触发器用处还是很多的,比如校内网、开心网、Facebook,你发一个日志,自动通知好友,其实就是在增加日志时做一个后触发,再向通知表中写入条目。
因为触发器效率高。
而UCH 没有用触发器,效率和数据处理能力都很低。
存储过程的实验步骤:mysql> delimiter |mysql> create procedure insertArticle_Procedure (pTitle varchar(50),pBid int,outpId int)-> begin-> insert into article1 value(null,pTitle,pBid);-> select max(id) into pId from article1;-> end;-> |Query OK, 0 rows affected (0.05 sec)mysql> call insertArticle_Procedure('传智播客',1,@pid);-> |Query OK, 0 rows affected (0.00 sec)mysql> delimiter ;mysql> select @pid;+------+| @pid |+------+| 3 |+------+1 row in set (0.00 sec)mysql> select * from article1;+----+--------------+------+| id | title | bid |+----+--------------+------+| 1 | test | 1 || 2 | chuanzhiboke | 1 || 3 | 传智播客| 1 |+----+--------------+------+3 rows in set (0.00 sec)触发器的实验步骤:create table board1(id int primary key auto_increment,name varchar(50),ar ticleCount int);create table article1(id int primary key auto_increment,title varchar(50),bid int references board1(id));delimiter |create trigger insertArticle_Trigger after insert on article1 for each row begin-> update board1 set articleCount=articleCount+1 where id= NEW.bid; -> end;-> |delimiter ;insert into board1 value (null,'test',0);insert into article1 value(null,'test',1);还有,每插入一个帖子,都希望将版面表中的最后发帖时间,帖子总数字段进行同步更新,用触发器做效率就很高。
下次课设计这样一个案例,写触发器时,对于最后发帖时间可能需要用declare方式声明一个变量,或者是用NEW.posttime来生成。
4、数据库三范式是什么?第一范式(1NF):字段具有原子性,不可再分。
所有关系型数据库系统都满足第一范式)数据库表中的字段都是单一属性的,不可再分。
例如,姓名字段,其中的姓和名必须作为一个整体,无法区分哪部分是姓,哪部分是名,如果要区分出姓和名,必须设计成两个独立的字段。
第二范式(2NF):第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。
要求数据库表中的每个实例或行必须可以被惟一地区分。
通常需要为表加上一个列,以存储各个实例的惟一标识。
这个惟一属性列被称为主关键字或主键。
第二范式(2NF)要求实体的属性完全依赖于主关键字。
所谓完全依赖是指不能存在仅依赖主关键字一部分的属性,如果存在,那么这个属性和主关键字的这一部分应该分离出来形成一个新的实体,新实体与原实体之间是一对多的关系。
为实现区分通常需要为表加上一个列,以存储各个实例的惟一标识。
简而言之,第二范式就是非主属性非部分依赖于主关键字。
第三范式的要求如下:满足第三范式(3NF)必须先满足第二范式(2NF)。
简而言之,第三范式(3NF)要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。
所以第三范式具有如下特征:1,每一列只有一个值2,每一行都能区分。
3,每一个表都不包含其他表已经包含的非主关键字信息。
例如,帖子表中只能出现发帖人的id,而不能出现发帖人的id,还同时出现发帖人姓名,否则,只要出现同一发帖人id的所有记录,它们中的姓名部分都必须严格保持一致,这就是数据冗余。
5、说出一些数据库优化方面的经验?用PreparedStatement 一般来说比Statement性能高:一个sql 发给服务器去执行,涉及步骤:语法检查、语义分析,编译,缓存二进制◊“inert into user values(1,1,1)”-二进制◊“inert into user values(2,2,2)”-二进制◊“inert into user values(?,?,?)”-有外键约束会影响插入和删除性能,如果程序能够保证数据的完整性,那在设计数据库时就去掉外键。
(比喻:就好比免检产品,就是为了提高效率,充分相信产品的制造商)(对于hibernate来说,就应该有一个变化:empleyee->deptid)◊Deptment对象,现在设计时就成了employee看mysql帮助文档子查询章节的最后部分,例如,根据扫描的原理,下面的子查询语句要比第二条关联查询的效率高:1. select ,e.salary where e.managerid=(select id from employee wherename='zxx');2. select ,e.salary,,m.salary from employees e,employees m wheree.managerid = m.id and ='zxx';表中允许适当冗余,譬如,主题帖的回复数量和最后回复时间等将姓名和密码单独从用户表中独立出来。