SQL数据库常用命令及语法举例

SQL数据库常用命令及语法举例
2024-11-25 01:55:40
推荐回答(3个)
回答1:

下面是一些常用的SQL语句,虽然很基础,可是却很值得收藏,对于初学者非常实用

SQL常用命令使用方法:

  • (1) 数据记录筛选:

    sql="select * from 数据表 where 字段名=字段值 order by 字段名 [desc]"

    sql="select * from 数据表 where 字段名 like '%字段值%' order by 字段名 [desc]"

    sql="select top 10 * from 数据表 where 字段名 order by 字段名 [desc]"

    sql="select * from 数据表 where 字段名 in ('值1','值2','值3')"

    sql="select * from 数据表 where 字段名 between 值1 and 值2"

  • (2) 更新数据记录:

    sql="update 数据表 set 字段名=字段值 where 条件表达式"

    sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式"

  • (3) 删除数据记录:

    sql="delete from 数据表 where 条件表达式"

    sql="delete from 数据表"  (将数据表所有记录删除)

  • (4) 添加数据记录:

    sql="insert into 数据表 (字段1,字段2,字段3 …) values (值1,值2,值3 …)"

    sql="insert into 目标数据表 select * from 源数据表"  (把源数据表的记录添加到目标数据表)

  • (5) 数据记录统计函数:

    AVG(字段名) 得出一个表格栏平均值

    COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计

    MAX(字段名) 取得一个表格栏最大的值

    MIN(字段名) 取得一个表格栏最小的值

    SUM(字段名) 把数据栏的值相加

    引用以上函数的方法:

    sql="select sum(字段名) as 别名 from 数据表 where 条件表达式"

    set rs=conn.excute(sql)

    用 rs("别名") 获取统的计值,其它函数运用同上。

  • (5) 数据表的建立和删除:

    CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )

    例:CREATE TABLE tab01(name varchar(50),datetime default now())

    DROP TABLE 数据表名称 (永久性删除一个数据表)

  • 4. 记录集对象的方法:

    rs.movenext              将记录指针从当前的位置向下移一行

    rs.moveprevious          将记录指针从当前的位置向上移一行

    rs.movefirst             将记录指针移到数据表第一行

    rs.movelast              将记录指针移到数据表最后一行

    rs.absoluteposition=N    将记录指针移到数据表第N行

    rs.absolutepage=N        将记录指针移到第N页的第一行

    rs.pagesize=N            设置每页为N条记录

    rs.pagecount             根据 pagesize 的设置返回总页数

    rs.recordcount           返回记录总数

    rs.bof                   返回记录指针是否超出数据表首端,true表示是,false为否

    rs.eof                   返回记录指针是否超出数据表末端,true表示是,false为否

    rs.delete                删除当前记录,但记录指针不会向下移动

    rs.addnew                添加记录到数据表末端

    rs.update                更新数据表记录

参考资料

SQL常用命令.csdn[引用时间2017-12-30]

回答2:

SQL Server数据库中的AS使用

回答3:

创建表:
create table 表名
(
id char(5) NOT NULL,
name VARCHAR(20) NOT NULL,
dept_name VARCHAR(20) NOT NULL,
salary NUMERIC(8,2),
PRIMARY KEY(id)
);
/* primary key == 主键 等价于 唯一 (UNIQUE) 且 非空 (NOT NULL) 因为 Mysql 里面的自增列, 必须要依赖一个 主键 或者 唯一的键。
*/
插入元组:
insert into 表名 values(每个属性对应的值);
例如:
insert into xinbiao values(001,'niuniu',math,2345.1);
如果无法添加出现1366错误,则可能是MySQL配置问题
只要找到my.ini文件并查找sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"这句话,将双引号前面{STRICT_TRANS_TABLES,}删除,改成sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",重启一下mysql后即可。前者很严格,不允许向数据库插入空值,所以就会有Value后面那个单引号。
删除所有元组:
delete from 表名;
删除表:
drop table 表名;
删除了表,进行select查询时会出现表名无效的错误。
属性操作
添加属性:
alter table 表名 add 新属性 数据类型,新属性 数据类型,...;

例:alter table xinbiao add shuxing1 varchar(20),shuxing2 varchar(20);
删除属性:
alter table 表名 drop 属性,...;

例:alter table xinbiao drop shuxing1 ,shuxing2 ;
查询语句基础结构
select对应投影
from对应笛卡尔积
where对应选择σ
含义:
(1).为from子句列出的关系产生笛卡尔积。
(2).在(1)的结果上应用where子句中指定的谓词(条件)。
(3).对于(2)中的元组,输出select子句中指定的属性。
select *(属性1,属性2,...)【字段名】
from 关系名1,关系名2,...【表名】
where 条件1 and 条件2 and ...;【条件】
例如:
Select id,name,salary
From xinbiao
Where salary>1000;

去重操作(distinct)
· 对于一些属性来说,在某些元组中存在相同的值,有时我们需要对结果去重,得到正确答案。
Select distinct 属性名【就是字段名】
From 关系名【就是表名】
Where 条件

例如:当我们想要查看系名时,多个老师可能位于同一个系,不去重将产生下列结果:
显然这不是我们想要的答案。我们只需要知道存在哪些系,而无需知道个数:

更名操作(as)
· 优点
方便:长名字变短名字,便于书写语句。
同一关系笛卡尔积:区分属性。
对属性:
Select 字段 as 字段别名,...
From 表名
Where 条件
例:
Select name as instructor_name,salary
From xinbiao
Where salary>3500
结果如下 :

对关系:
Select 字段,...
From 表名 as 表名别名,...
Where 条件
例:
Select i1.id,i2.name
From xinbiao as i1, xinbiao as i2
Where i1.id=i2.id and salary>3500
结果如下

字符串运算(like)
· SQL使用一对单引号来标示字符串,例‘math’。
· 百分号(%):匹配任意子串
下划线(_):匹配任意一个字符
select 字段
from 表名
where 字段 like '字符形式';
例:LIKE 'AACC%'
以AACC开头的所有信息
显示次序(order by)
· 默认升序:asc
· 降序:desc
Select 字段
From 表名
Where 条件
Order by 字段 升序/降序
between⋯⋯and⋯⋯
· 属性值介于某个范围内
select * from xinbiao where 属性名 between ... and ... ;

select *from xinbiao where salary between 3000 and 6000;
结果如下

分组聚集(group by)
· 聚集函数:平均值(avg)、最小值(min)、最大值(max)、总和(sum)、计数(count)。
· 出现在select语句中但没有被聚集的属性只能是出现在group by子句中的属性。
having子句(出现group by时使用)
· 有group by时,select 和 having子句中出现的属性有所限制。
· 任何出现在having子句中,但没有被聚集的属性必须出现在group by子句中。
正确查询:
select dept_name,avg(salary) as avg_salary from xinbiao group by dept_name having avg(salary)>3000
结果如下

集合成员资格
· in:测试元组是否是集合的成员
· not in:测试元组是否不是集合的成员
· in和 not in 操作符用于枚举集合。
例:
select * from xinbiao where name not in('ai','ye','er');
结果如下

集合的比较
>some:至少比某一个要大
>all:比所有的都大。
>some、=some、<=some、<>some
>all、=all、<=all
=some等价于in,<>some并不等价于not in。
<>all等价于not in,=all不等价于in。
空关系测试(exists)
EXISTS在SQL中的作用是:检验查询是否返回数据。
· 存在exists是相对于某一条元组,因而子查询中是select *。

例:查询在2009年秋季学期和2010年春季学期同时开课的所有课程
select course_id
from section as S
where semester='Fall' and year=2009 and exists(select *
from section as T
where semester='Spring' and year=2010
and S.course_id=T.course_id
);
删除某些元组
例:从instructor关系中删除与‘math’系教师有关的所有元组
delete from instructor where dept_name='math';
删除所有元组
delete from instructor;
插入一些元组
· insert into 关系名 values(⋯⋯);一次只能插入一条元组。
· insert into 关系名 selec查询语句可一次性插入多条。
更新元组
update 表名set 语句where 条件;
例:只给工资低于7000元的教师涨工资。
update instructor2set salary=salary*1.05;where salary<7000;
给工资低于7000的教师涨5%,大于7000的涨3%
update instructor2set salary=case
when salary<=7000 then salary*1.05
else salary*1.03
end