数据库(基本命令)

MySQL的安装:

sudo apt-get install mysql-server mysql-client

基本命令:

  • 1、创建数据库

create database 数据库名称 charset=utf8;;

  • 2、删除数据库

drop database 数据库名称;

  • 3、查看数据库

show database;

  • 4、使用(进入)数据库

use 数据库名称;

  • 5、查看数据库当中有多少张表

show tables;

  • 数据类型三大类

1、数值类型
2、字符串类型
3、日期和时间类型

  • 常见数据类型
4.1 double浮点型
例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;4.2 char
固定长度字符串类型;

char(10)'abc '
varchar

可变长度字符串类型;
varchar(10)'abc'

text
字符串类型

blob
二进制类型
date
提起类型,格式为:yyyy-MM-dd;

time
时间类型,格式为:hh:mm:ss;

datetime
日期时间类型,格式为:yyyy-MM-dd hh:mm:ss
  • 6、创建学生表

CREATE TABLE 表名(
列名1 列名类型 [约束],
列名2 列名类型 [约束],
.....
列名N 类的类型 [约束]
)

  • 7、添加一列

ALTER TABLE 表名 ADD 列名 数据类型;

  • 8、删除一列

ALTER TABLE students drop nums;

  • 9、查看表的字段信息

desc 表名

  • 10、修改一个表的字段类型

ALTER TABLE 表名 MODIFY 字段名 数据类型;

  • 11、修改表名

RENAME TABLE 原始表名 TO 要修改的表名;

  • 12、查看表的创建细节

SHOW CREATE TABLE 表名;

  • 13、修改表的字符集gbk

ALTER TABLE students character set gbk;

  • 14、修改表的列名

ALTER TABLE students change name newname varchar(20);

  • 15、删除表

DROP TABLE 表名;

  • 16、查询表中的所有数据

SELETE * FROM 表名;

  • 17、插入操作:

INSERT INTO 表名 ( 列名1,列名2 ) VALUES (列值1, 列值2...);

  • 例子

INSERT INTO students (id,name,age,email,score) VALUES (
2,'lisi',18,'wengwenyu@aliyun.com',null
);

  • 18、添加多条数据(批量插入):

VALUES后面以逗号隔开
INSERT INTO 表名(列名1,列名2....) VALUES(列值1,列值2),(列值1,列值2)....;

  • 例子

INSERT INTO students (id,name,age,email,score) VALUES (2,'wangwu',20,'wengwenyu2@aliyun.com',20
),(
3,'maliu',21,'wengwenyu3@aliyun.com',22
);

  • 19、更新操作

UPDATE 表名 SET 列名1=列值1, 列名2=列值2... WHERE 列名=值

  • 20、把所有学生的分数改为90

UPDATE students SET score=90;

  • 21、把姓名为zs的学生分数修改为60

UPDATE students SET score=60 WHERE name='zs';

  • 22、把姓名为lisi的年龄修改为20和分数修改为70

UPDATE students SET age=30,score=70 WHERE name='lisi';

  • 23、把wangwu的年龄在原来基础上+1岁

UPDATE students SET age=age+1 WHERE name='wangwu'

  • 24、修改数据库密码

mysqladmin -u root -p password 123456

  • 25、删除操作

如果不加过滤条件就是删除所有数据
DELETE FROM 表名 [WHERE 列名=值]
例子:
DELETE FROM students WHERE name='amliu'

  • 26、删除所有数据

TRUNCATE TABLE 表名;

  • DELETE 与 TRUNCATE的区别:
DELETE可以删除指定数据也能删除所有数据 TRUNCATE只能删除所有数据

DELETE删除表中的数据,表结构还在;删除后数据还可以找回

TRUNCATE删除是把表直接DROP掉,然后再创建一个同样的新表.删除的数据不能找回.执行速度比DELETE快
  • 27、查询所有列

SELECT * FROM 表名;

  • 结果集

结果集:
通过查询语句查询出来的数据以表的形式展示,我们称这个表为虚拟结果集.存放再内存中。
查询返回的结果集就是一张虚拟表

  • 28、查询指定的列

SELECT 列名1,列名2 FROM 表名;

  • 29、条件查询:


    image.png

BETWEEN...AND; 值在什么范围
IN(set);
IS NULL; (为空)
IS NOT NULL; (不为空)
AND; 与
OR; 或
NOT; 非

  • 30、查询性别为男,并且年龄为20的学生记录

添加性别字段
ALTER table students add gender varchar(2);
查询
SELECT * FROM students WHERE gender='男' AND age=20;

  • 31、查询学号为1001 或者 名为 zs 的记录

SELECT * FROM students WHERE id=1001 OR name='zs';

  • 32、查询学号为1001 , 1002 ,1003的记录

(1)SELECT * FROM students WHERE id = 1001 OR id = 1002 OR id = 1003;
(2)SELECT * FROM students WHERE id in (1001,1002,1003);

  • 33、查询年龄为null的记录

SELECT * FROM students WHERE age IS NULL;

  • 34、查询年龄在18-20之间的学生记录

(1)SELECT * FROM students WHERE age>= 18 AND age<=20;
(2)SELECT * FROM students WHERE age BETWEEN 18 AND 20;

  • 35、查询性别非男的学生记录

SELECT * FROM students WHERE gender != '男';

  • 36、查询姓名不为null的学生记录

SELECT * FROM students WHERE name IS NOT NULL;

模糊查询

  • 37、查询姓名由5个字母构成的学生记录

5个字母就是5个下划线
SELECT * FROM students WHERE name LIKE '_____';

  • 38、查询姓名由5个字母构成,并且第5个字母为's'的学生记录

SELECT * FROM students WHERE name LIKE '____s';

  • 39、查询姓名以'm'开头的学生记录

SELECT * FROM students WHERE name LIKE 'm%';

  • 40、查询姓名中第二个字母为'u'的学生记录

SELECT * FROM students WHERE name LIKE '_u%';

  • 41、查询姓名中包含's'字母的学生记录

SELECT * FROM students WHERE name LIKE '%s%';

  • 42、去除重复记录 。 查询所有学生name信息,去除重复信息SELECT

SELECT DISTINCT name FROM students;

  • 43、把查询字段的结果进行运算,必须都要是数值型

SELECT *,字段1+字段2 FROM 表名;

  • 举例:

查出所有内容,又添加了一个新的列为age和score的和,注意* 表示查出所有,然后逗号隔开,然后age+score SELECT *,age+score FROM students;

  • 列有很多记录的值为null,因为任何东西与NULL相加的结果还是NULL,所以结算结果可能会出现NULL,下面使用了把NULL转化成数值0的函数IFNULL:

SELECT *,age+IFNULL(score,0) FROM students;

  • 对查询结果起别名 在上面的查询中出现列名为sx+IFNULL(yw,0),这很不美观,现在我们给这一列起一个别名,为total:

SELECT *,yw+IFNULL(sx,0) AS total FROM score;
省略
AS SELECT *,yw+IFNULL(sx,0) total FROM score;

  • 排序

关键字 ORDER BY
排序类型(默认是ASC)
升序ASC 从小到大
降序DESC 从大到小

  • 根据 id排序

SELECT * FROM employee ORDER BY salary DESC,id DESC;

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容