数据库学习-常用的SQL语句

这篇具有很好参考价值的文章主要介绍了数据库学习-常用的SQL语句。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

背景:

汇整一下自己学习数据库过程中常见的题目及语句。

一.实例分析题

数据库学习-常用的SQL语句

 数据库学习-常用的SQL语句

数据库学习-常用的SQL语句

 二.简单SQL查询:

1):统计每个部门员工的数目
	select dept,count(*) from employee group by dept;

2):统计每个部门员工的数目大于一个的记录
	select dept,count(*) from employee group by dept having count(*)>1;

3):统计工资超过1200的员工所在部门的名称
	select e.first_name,salary,d.name
	from s_emp e, s_dept d
	where e.dept_id = d.id
	and salary > 1200;

4):查询哪个部门没有员工
	select e.empno, d.deptno 
	from emp e, dept d
	where e.deptno(+) = d.deptno
	and e.deptno is null;

三.复杂SQL查询

有3个表(15分钟):(SQL)

Student 学生表 (学号,姓名,性别,年龄,组织部门)

Course 课程表 (编号,课程名称)

Sc 选课表 (学号,课程编号,成绩)

表结构如下:

 

1) 写一个SQL语句,查询选修了’JAVA’的学生学号和姓名(3分钟)

答:SQL语句如下:

select stu.sno, stu.sname

from student stu, course c, sc

where stu.sno = sc.sno and sc.cno = c.cno and c.cname=’JAVA’;

2) 写一个SQL语句,查询’a’同学选修了的课程名字(3分钟)

答:SQL语句如下:

select stu.sname, c.cname

from student stu, course c, sc

where stu.sno = sc.sno and sc.cno = c.cno and stu.sname = ’a’;

3) 写一个SQL语句,查询选修了5门课程的学生学号和姓名(9分钟)

答:SQL语句如下:

select stu.sno, stu.sname from student stu

where (select count(*) from sc where sno=stu.sno) = 5;

三. 在SQL中删除重复记录的方法:(用到rowid (oracle伪列))

    1)通过建立临时表来实现

        SQL>create table temp_emp as (select distinct * from employee) 

        SQL>truncate table employee; (清空employee表的数据)

        SQL>rename temp_emp to employee; (再将表重命名)

    2)通过使用rowid来实现。

        SQL>delete from employee where rowid not in (

        select max(t1.rowid) from employee t1 group by

        t1.emp_id,t1.emp_name,t1.salary);

        --这里用min(rowid)也可以。

四. TOP N问题:查出一张表的前2条数据(用到rownum (oracle伪列))

四. TOP N问题:查出一张表的前2条数据(用到rownum (oracle伪列))

    答:--rownum只能使用<=或<的关系比较运算符

    select * from s_emp where rownum <= 2;

    --查询公司工资最高的3个人

    /*select * from emp

    where rownum <= 3

    order by sal desc;*/ 错误的

    select * from (select * from emp order by sal desc) where rownum <= 3;

五.分页查询:

    --查询第1-5条记录

    select * from (select rownum num, s_emp.* from s_emp)

    where num >=1 and num <= 5;

    --按工资排序,五条一页,查找第二页

   select salary,first_name

         from( select s.*, rownum rm

        from (select *

                  from s_emp

                  order by salary d

          ) s

       )

    where rm between 6 and 10

四、简述题:

1.怎样创建一个视图,视图的好处, 视图可以控制权限吗?

答案:

Create view <視圖名> as <select 語句>

視圖名在數據庫中必須是唯一的,不能與其他表或視圖同名

指定創建視圖的語句,可以查詢多個基礎表或源視圖

1.增强保障數據安全性

2.組裝數據 數據整合

3.封裝複雜查詢 數據的透明性

4.提供建模模型

5.提高響應速度

視圖只是一個虛表 用戶有只讀權限 沒有控制權限

2.怎样创建一个一个索引,索引使用的原则,有什么优点和缺点?

Create index idx_表名_列名 on 表名(列名)

原則 1.小數據量的表不宜使用索引

2.頻繁使用插入,修改,刪除等DML操作的數據表不宜使用索引

優點:利用索引提供數據庫性能

缺點:添加刪除修改數據對索引的影響都是不可避免地形成了對存儲空間的浪費

3. 怎样将一个旧数据库数据移到一个新的数据库

創建一個臨時數據庫

先把舊的數據庫遷移過去,再SQL導入數據 insert into  select from 然後再把舊的數據庫刪除就好了

4. 怎样创建一个存储过程,有什么好处?

5. 说说你了解的oracle中的经常使用到得函数

字符函数:

Upper()函數

Lower()函數

Initcap()函數

Substr()函數

Length()函數

Concat()函數

Instr()函數

Trim()函數

Itrim()函數

Rtrim()函數

Translate()函數

轉換函數 TO_CHAR

数字函数:

Abs()函數

Round()函數

Ceil()函數

Floor()函數

Mod()函數

Sign()函數

Sqrt()函數

Power()函數

Trunc()函數

轉換函數 TO_NUMBER

 日期函数:

Sysdate()函數

Add_months()函數

Last_day()函數

Next_day()函數

Months_between()函數

Extract()函數

轉換函數 TO_DATE

其它函数:

Decode()函數

Nvl()函數

Cast()函數

 聚合函數/組函數:

AVG()函數

SUM()函數

MAX()函數

MIN()函數

COUNT()函數

6. Oracle中字符串用什么符号链接?

Oracle 字符串連接使用“||”進行字符串拼接

單引號表示日期或字符串

雙引號表示別名

7.简要说一下什么是内连接、左连接、右连接,并写出连接的sql。

答案:

(1)文章来源地址https://www.toymoban.com/news/detail-420209.html

到了这里,关于数据库学习-常用的SQL语句的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据库基础——数据库、数据表和SQL语句

    数据库是用来存储、管理数据的仓库 数据表是数据的存储结构 Structured Query Language,结构化查询语言,用来操作数据库 安装MySQL,自行百度 进入cmd使用命令 mysql -hAddress -uUser -p(Password) 登录数据库 -p后直接回车可进入密文登录 如果出现以下报错,则打开任务管理器-服务-开启

    2024年02月09日
    浏览(72)
  • 数据库SQL语句使用

    -- 查询所有数据库 -- 创建数据库,数据库名为mydatabase   -- 如果没有名为 mydatabase的数据库则创建,有就不创建   -- 如果没有名为 mydatabase的数据库则创建,有就不创建,数据库字符编码设置为utf8mb4 -- 使用数据库 -- 删除名为mydatabase的数据库 -- 如果有名为 mydatabase的数据库则

    2024年02月12日
    浏览(45)
  • SQL语句创建数据库

    SQL语句如下: (1) name: 数据文件名称一般为 ( name ) _Data ,日志文件名称一般为( name )_Log 。 (2) filename: 数据文件名后缀为 .mdf ,日志文件名后缀为 .ldf 。 (3) maxsize: 设置为 unlimited 时,表示文件最大大小无限制。 (4) filegrowth: 可以设置为具体值(—M)或者百分比

    2024年02月13日
    浏览(60)
  • MySQL常用数据库语句

    ==数据库== 1、创建数据库 create database [IF NOT EXISTS] 数据库名; 2、删除数据库 drop database [IF EXISTS] 数据库名; 3、切换数据库 select database(); 4、查询数据库 show databases; ———————————————————————————— ==数据表== 1、创建数据表 create table 表名( 字段名

    2024年02月01日
    浏览(49)
  • 数据库作业-sql语句查询

    建表的插入数据的表 数据库作业-sql建表和插入数据_快乐的xiao何的博客-CSDN博客 create table supplier( supplierno char(6) primary key, suppliername nvarchar(10), address nvarchar(20), number char(11) )create table category( categoryno char(5) primary key, categoryname varchar(20), descriptions text... https://blog.csdn.net/m0_539670

    2023年04月23日
    浏览(54)
  • SQL语句创建数据库详解

    在SQL中,创建数据库的语句通常是使用 CREATE DATABASE 语句。让我们来详细解释一下这个语句,并通过一个示例来说明如何创建数据库。 CREATE DATABASE语句详解 CREATE DATABASE 语句用于在数据库管理系统中创建一个新的数据库。它的基本语法如下: 其中, database_name 是要创建的数据

    2024年02月19日
    浏览(55)
  • 数据库应用:MySQL数据库SQL高级语句与操作

    目录 一、理论 1.克隆表与清空表 2.SQL高级语句 3.SQL函数 4.SQL高级操作 5.MySQL中6种常见的约束 二、实验  1.克隆表与清空表 2.SQL高级语句 3.SQL函数 4.SQL高级操作 5.主键表和外键表  三、总结 克隆表:将数据表的数据记录生成到新的表中。 (1)克隆表 ① 先创建再导入 ② 创建

    2024年02月13日
    浏览(75)
  • SQL 选择数据库 USE语句

    当SQL Schema中有多个数据库时,在开始操作之前,需要选择一个执行所有操作的数据库。 SQL USE语句用于选择SQL架构中的任何现有数据库。 句法 USE语句的基本语法如下所示 : 数据库名称在RDBMS中必须是唯一的。 您可以查看可用的数据库,如下所示: 现在,如果您想使用AMROOD数

    2024年02月08日
    浏览(55)
  • 数据库sql语句(视图的创建)

    例题:  建表:要注意各表之间的索引联系,建表先后顺序很重要,不然建不了,例如先建dept,在建其他表,先在dept插入数据,再在其他表插入数据 (1) (2)  (3)  (4) (5)    插入数据如下图 sql语句: 在 Student 表中加入属性 SAGE(INT 型 )  将 Student 表中的属性 SA

    2024年02月04日
    浏览(63)
  • 用SQL语句操作Oracle数据库——数据更新

    数据库中的数据更新操作有3种:1)向表中添加若干行数据(增);2)删除表中的若干行数据(删);3)修改表中的数据(改)。对于这3种操作,SQL语言中有3种相应的语句与之对应。接下来让我们逐一详细地了解一下。 本文我们依然使用以下三个表来进行数据更新操作:

    2024年01月19日
    浏览(63)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包