数据库01

2018-12-12  本文已影响0人  四月四七日薄暮

MySQL的安装:

sudo apt-get install mysql-server mysql-client

基本命令:

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

drop database 数据库名称;

show database;

use 数据库名称;

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

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

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

ALTER TABLE students drop nums;

desc 表名

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

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

SHOW CREATE TABLE 表名;

ALTER TABLE students character set gbk;

ALTER TABLE students change name newname varchar(20);

DROP TABLE 表名;

SELETE * FROM 表名;

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

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

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
);

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

UPDATE students SET score=90;

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

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

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

mysqladmin -u root -p password 123456

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

TRUNCATE TABLE 表名;

DELETE可以删除指定数据也能删除所有数据 TRUNCATE只能删除所有数据

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

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

SELECT * FROM 表名;

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

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

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

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

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

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

SELECT * FROM students WHERE age IS NULL;

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

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

SELECT * FROM students WHERE name IS NOT NULL;

模糊查询

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

SELECT * FROM students WHERE name LIKE '____s';

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

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

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

SELECT DISTINCT name FROM students;

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

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

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

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

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

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

上一篇 下一篇

猜你喜欢

热点阅读