(一)数据库操作

1、创建数据库

create database 数据库名;
create database study;

2、选择数据库

use 数据库名;
use study;

3、删除数据库

drop database 数据库名;
drop database study;
(二)数值类型
类型 大小 范围(有符号) 范围(无符号) 用途
TINYINT 1字节 (-128 , 127) (0, 255) 整数值
SMALLINT 2字节 (-32 768 , 32 767) (0, 65 535) 整数值
MEDIUMINT 3字节 (-8 388 608 , 8 388 607) (0, 16 777 215) 整数值
INT或 INTEGER 4字节

(-2 147 483 648,

2 147 483 647)

(0, 4 294 967 295) 整数值
BIGINT 8字节

(-9 233 372 036 854 775 808 ,

9 223 372 036 854 775 807)

(0,

18 446 744 073 709 551 615)

极大整数值
FLOAT 4字节

(-3.402 823 466 E+38 ,

-1.175 494 351 E-38) ,

0 ,

(1.175 494 351 E-38 ,

3.402 823 466 351 E+38)

0,

(1.175 494 351 E-38,

3.402 823 466 E+38)

单精度
浮点数值
DOUBLE 8字节

(-1.797 693 134 862 315 7 E+308 ,

-2.225 073 858 507 201 4 E-308),

0,

(2.225 073 858 507 201 4 E- 308 ,

1.797 693 134 862 315 7 E+308)

0 ,

(2.225 073 858 507 201 4 E-308 ,

1.797 693 134 862 315 7 E+308)

双精度
浮点数值
DECIMAL

对 DECIMAL(M,D) ,

如果M>D,

为 M+2否则为D+2

依赖于M和D的值 依赖于M和D的值 小数值


(三)数据表

1、创建数据表

CREATE TABLE 数据表名 (字段名 字段类型);
CREATE TABLE `sys_user`(
`user_id` INT UNSIGNED AUTO_INCREMENT,
`user_name` VARCHAR(100) NOT NULL,
`address` VARCHAR(40) NOT NULL,
`create_time` DATE,
PRIMARY KEY ( `user_id` )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

2、删除数据表

DROP TABLE 数据表名;
DROP TABLE sys_user;
(四)数据操作

1、增

INSERT INTO table_name(field1, field2,...fieldN )  VALUES( value1, value2,...valueN );
INSERT INTO sys_user(user_name,address,create_time) VALUES("管理员", "明春网", NOW());

2、删

DELETE FROM table_name [WHERE Clause];
DELETE FROM sys_user WHERE user_id=1;

3、改

UPDATE table_name SET field1=new-value1, field2=new-value2 [WHERE Clause];
UPDATE sys_user SET address='山西太原' WHERE user_id=1;

4、查

SELECT field1, field2,...fieldN FROM table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....

SELECT * from sys_user WHERE address='明春网';
(五)查询

1、WHERE

=

等号,检测两个值是否相等

如果相等返回true

(A = B)退回 false.
<>,!=

不等于,检测两个值是否相等,

如果不相等返回true

(A != B)返回 true.
>

大于号,检测左边的值是否大于右边的值,

如果左边的值大于右边的值返回true

(A > B)退回false。
<

小于号,检测左边的值是否小于右边的值,

如果左边的值小于右边的值返回true

(A < B)返回 true.
>=

大于等于号,检测左边的值是否大于瞄于右边的值,

如果左边的值大于于右边的值退回true

(A >= B)返回 false。
<=

小于等于号,检测左边的值是否小于于或等于右边的值.

如果左边的值小于或等于右边的值返回true

(A <= B)返回 true.

2、ORDER BY

SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER
BY field1, [field2...] [ASC [DESC]];

SELECT * from sys_user ORDER BY user_id ASC;

3、GROUP BY

GROUP BY 语句根据一个或多个列对结果集进行分组。

在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。

SELECT column_name, function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name;

SELECT address, COUNT(*) FROM sys_user GROUP BY address;

4、JOIN

JOIN 按照功能大致分为如下三类:

INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。

LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。

RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。

 

SELECT a.user_name, a.address, b.dept_name 
FROM sys_user a
INNER JOIN sys_dept b ON a.dept_id = b.id
(六)MySQL 事务

1、事务介绍

MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。

事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。

事务用来管理 insert,update,delete 语句

2、事务控制语句

BEGINSTART TRANSACTION;显式地开启一个事务;

COMMIT;也可以使用COMMIT WORK,不过二者是等价的。COMMIT会提交事务,并使已对数据库进行的所有修改成为永久性的;

ROLLBACK;有可以使用ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改;

(七)字段操作

1、增

ALTER TABLE 数据表名 ADD 新增字段 字段类型;
ALTER TABLE sys_user ADD memo VARCHAR(1024) NOT NULL DEFAULT '0' COMMENT '备注';

2、删

ALTER TABLE 数据表名 DROP 字段名;
ALTER TABLE sys_user DROP memo;

3、改

#例如,把字段 address 的类型从 VARCHAR(100) 改为 VARCHAR(1024),可以执行以下命令:
ALTER TABLE sys_user MODIFY address VARCHAR(1024);

#修改字段类型及名称
# CHANGE 关键字之后,紧跟着的是你要修改的字段名,然后指定新字段名及类型。尝试如下实例:
#例如,把字段 address 改成 字段 dizhi ,类型从 VARCHAR(1024) 改为 VARCHAR(2048),可以执行以下命令:
ALTER TABLE sys_user CHANGE address dizhi VARCHAR(2048);

#ALTER TABLE Null 值和默认值的影响
ALTER TABLE sys_user MODIFY address VARCHAR(128) NOT NULL DEFAULT 'China';

#修改字段默认值
ALTER TABLE sys_user ALTER address SET DEFAULT '中国';

#修改表名
ALTER TABLE sys_user RENAME TO mch_user;
(八)索引

1、创建普通索引

#这是最基本的索引,它没有任何限制。它有以下几种创建方式:
#(1)创建索引
CREATE INDEX indexName ON tableName(username(length));

#如果是CHARVARCHAR类型,length可以小于字段实际长度;如果是BLOBTEXT类型,必须指定 length
#(2)创建表的时候直接指定
CREATE TABLE sys_user(
user_id INT NOT NULL,
user_name VARCHAR(16) NOT NULL,
INDEX [userName] (user_name(length))
);

2、创建唯一索引

#它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。它#有以下几种创建方式:
#(1)创建索引
CREATE UNIQUE INDEX indexName ON mytable(username(length)) ;

#(2)创建表的时候直接指定
CREATE TABLE 表名( 属性名 数据类型[完整性约束条件],
属性名 数据类型[完整性约束条件],
......
属性名 数据类型
[UNIQUE | FULLTEXT | SPATIAL ] INDEX | KEY
[别名] (属性名1 [(长度)] [ASC | DESC])
);

其中,UNIQUE是可选参数,表示索引为唯一性索引FULLTEXT是可选参数,表示索引为全文索引SPATIAL也是可选参数,表示索引为空间索引INDEXKEY参数用来指定字段为索引的,两者选择其中之一就可以了,作用是一样的;"别名"是可选参数,用来给创建的索引取的新名称;"属性1"参数指定索引对应的字段的名称,该字段必须为前面定义好的字段;"长度"是可选参数,其指索引的长度,必须是字符串类型才可以使用;"ASC"和"DESC"都是可选参数,"ASC"参数表示升序排列,"DESC"参数表示降序排列。

CREATE TABLE sys_user( 
user_id INT NOT NULL,
user_name VARCHAR(16) NOT NULL,
UNIQUE [user_name] (user_name(length))
);

3、删除索引

DROP INDEX [user_name] ON sys_user; 

4、使用ALTER 命令添加和删除索引

有四种方式来添加数据表的索引:

#(1)该语句添加一个主键,这意味着索引值必须是唯一的,且不能为NULL
ALTER TABLE tableName ADD PRIMARY KEY (column_list);

#(2)这条语句创建索引的值必须是唯一的(除了NULL外,NULL可能会出现多次)。
ALTER TABLE tableName ADD UNIQUE index_name (column_list);

#(3)添加普通索引,索引值可出现多次。
ALTER TABLE tableName ADD INDEX index_name (column_list);

#(4)该语句指定了索引为 FULLTEXT ,用于全文索引。
ALTER TABLE tableName ADD FULLTEXT index_name (column_list);

#添加索引实例
ALTER TABLE tableName ADD INDEX (c);

#删除索引实例
ALTER TABLE tableName DROP INDEX c;