数据库的命令,数据库增删改查的基本命令
很多朋友对于数据库的命令和数据库增删改查的基本命令不太懂,今天就由小编来为大家分享,希望可以帮助到大家,下面一起来看看吧!
数据库的命令都有哪些
1、显示当前存在的数据库 mysql> show databases;
2、选择数据库 mysql> USE mysql Database changed(USE和 QUIT命令不需要分号结束。),显示当前选择的数据库 mysql> select database();
3、显示当前数据库中存在的表 mysql> SHOW TABLES;
4、显示表(db)的内容 mysql>select* from db;
5、命令的取消当命令输入错误而又无法改变(多行语句情形)时,只要在分号出现前就可以用 c来取消该条命令 mysql> select-> user()-> c
6、创建一个数据库abccs mysql> CREATE DATABASE abccs;
7、选择你所创建的数据库 mysql> USE abccs Database changed;
8、创建一个数据库表首先看现在你的数据库中存在什么表: mysql> SHOW TABLES; Empty set(0.00 sec)说明刚才建立的数据库中还没有数据库表。下面来创建一个数据库表mytable:我们要建立一个你公司员工的生日表,表的内容包含员工姓名、性别、出生日期、出生城市。 mysql> CREATE TABLE mytable(name VARCHAR(20), sex CHAR(1), birth DATE, birthaddr VARCHAR(20));
9、显示表的结构: mysql> DESCRIBE mytable;
10、往表中加入记录我们先用SELECT命令来查看表中的数据: mysql> select* from mytable; Empty set(0.00 sec)这说明刚才创建的表还没有记录。加入一条新记录: mysql> insert into mytable values('abccs','f','1977-07-07','china');
11、用文本方式将数据装入一个数据库表如果一条一条地输入,很麻烦。我们可以用文本文件的方式将所有记录加入你的数据库表中。创建一个文本文件“mysql.txt”,每行包含一个记录,用定位符(tab)把值分开,并且以在 CREATE TABLE语句中列出的列次序给出,例如: abccs f 1977-07-07 china mary f 1978-12-12 usa tom m 1970-09-02 usa使用下面命令将文本文件“mytable.txt”装载到mytable表中: mysql> LOAD DATA LOCAL INFILE"mytable.txt" INTO TABLE pet;再使用如下命令看看是否已将数据输入到数据库表中: mysql> select* from mytable;
12、从数据库表中检索信息 select语句格式一般为: SELECT检索关键词 FROM被检索的表 WHERE检索条件
13、查询所有数据: mysql> select* from mytable;
14、修正错误记录:假如tom的出生日期有错误,应该是1973-09-02,则可以用update语句来修正: mysql> update mytable set birth="1973-09-02" where name="tom";
15、选择特定列假如你想查看表中的所有人的姓名,则可以这样操作: mysql> SELECT name FROM mytable;如果想列出姓名和性别两列,则可以用逗号将关键词name和birth分开: myaql> select name,birth from mytable;
16、对行进行排序我们可以对表中的记录按生日大小进行排序: mysql> SELECT name, birth FROM mytable ORDER BY birth;我们可以用DESC来进行逆序排序: mysql> SELECT name, birth FROM mytable ORDER BY birth DESC;
17、行计数数据库经常要统计一些数据,如表中员工的数目,我们就要用到行计数函数COUNT()。 COUNT()函数用于对非NULL结果的记录进行计数: mysql> SELECT COUNT(*) FROM mytable;员工中男女数量: mysql> SELECT sex, COUNT(*) FROM mytable GROUP BY sex;
18、多表查询现在我们有了两个表: mytable和 title。利用这两个表我们可以进行组合查询:例如我们要查询作者abccs的姓名、性别、文章: mysql> SELECT name,sex,title FROM mytable,title WHERE name=writer AND name='abccs';用于查询文章a2的作者、出生地和出生日期: mysql> select title,writer,birthaddr,birth from mytable,title-> where mytable.name=title.writer and title='a2';
19、增加一列:如在前面例子中的mytable表中增加一列表示是否单身single: mysql> alter table mytable add column single char(1);
20、修改记录将abccs的single记录修改为“y”: mysql> update mytable set single='y' where name='abccs';
21、增加记录前面已经讲过如何增加一条记录,为便于查看,重复与此: mysql> insert into mytable values('abc','f','1966-08-17','china','n');
22、删除记录用如下命令删除表中的一条记录: mysql> delete from mytable where name='abc'; DELETE从表中删除满足由where给出的条件的一条记录。
23、删除表: mysql> drop table****(表1的名字),***表2的名字;可以删除一个或多个表,小心使用。
24、数据库的删除: mysql> drop database
SQL数据库常用命令及语法举例
创建表:
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、<>some
>all、<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
数据库增删改查的基本命令
以下是总结的mysql的常用语句,欢迎指正和补充~
一、创建库,删除库,使用库
1.创建数据库:create database库名;
2.删除数据库:drop database库名;
3.使用数据库:use库名;
二、创建数据表
1.创建表语句:create table表名(字段名1字段类型字段约束,字段2字段类型字段约束...);
2.创建与现有表一样字段的新表:create table表名 like已有表名;
3.将查询结果创建新表:create table表名 select* from现有表 where...(查询语句);
三、查看表结构,查看建表语句,删除表
1.查看表结构:desc表名;
2.查看建表语句:show create table表名;
3.删除表:drop table表名;
四、修改表结构
1.对数据表重命名:alter table表名 rename新表名;
2.增加字段:alter table表名 add字段名字段类型字段约束;(PS:可用first/after函数调整字段位置)
3.删除字段:alter table表名 drop字段名;
4.修改字段类型及约束:alter table表名 modify字段名新类型新约束;(PS:如不加新约束,会将建表时的约束清空,主键、外键、唯一约束除外)
5.修改字段名称:alter table表名 change字段名新字段名新字段类型新约束条件;
6.修改数据库引擎:alter table表名 engine=;(PS:主要有InnoDB和MyISAM,InnoDB对经常修改表数据友好,MyISAM对经常查询表友好)
7.增加主键:alter table表名 add primary key(字段名);
8.删除主键:alter table表名 drop primary key;
9.增加外键:alter table表名 add constraint外键名 foreign kek(字段名) references主表(主键);
10.删除外键:alter table表名 drop foreign key外键名;
11.删除唯一约束:alter table表名 drop index字段名;
12.设置自动增长的初始位置:alter table表名 auto_increment=n;
五、向表中插入数据
1.向表指定字段插入多条数据:insert into表名(字段1,字段2...) values(数据1,数据2...),(数据1,数据2...),(数据1,数据2...),(数据1,数据2...);
2.将查询结果插入表:insert into表名 select字段名 from表名(查询语句);
3.加载外部数据到表:Load data local infile‘数据路径’Into table表名 Fields terminated by‘分隔符’Ignored 1 lines;
六、更新表数据、删除表数据
1.更改满足条件的字段数据:update表名 set字段计算1,字段计算2... where条件;
2.删除满足条件的数据:delele from表名 where条件;
3.删除所有数据:方式一:delete from表名;方式二:truncate table表名;方式一会逐条进行删除,速度较慢,方式二直接删除,速度快;另外对自增字段,方式一不能重置自增字段的初始位置,方式二可以重置自增字段的其实位置;
文章到此结束,如果本次分享的数据库的命令和数据库增删改查的基本命令的问题解决了您的问题,那么我们由衷的感到高兴!