插入数据 INSERT
1. 插入字符和日期数据
字符和日期数据应该包含在单引号中
INSERT INTO departments (department_id, department_name, manager_id,location_id)
VALUES (280, 'PR', 100, 1700)
可能出现的问题
- 插入的数据中的一个字段时外键,而且该字段的值与外键所在的表中的值不匹配。
eg:
job_id
是该表的外键,而插入的值SA_RAP
在以job_id
为主键的表jobs
中不存在。
- 异常语句
INSERT INTO
employees(employee_id, last_name, email, hiredate, job_id)
VALUES (302, 'DDX', '779831171@qq.com', STR_TO_DATE('2019-1-1','%Y-%m-%d'), 'SA_RAP')
- 异常信息
Cannot add or update a child row: a foreign key constraint fails (`myemployees`.`employees`, CONSTRAINT `job_id_fk` FOREIGN KEY (`job_id`) REFERENCES `jobs` (`job_id`))
2. 插入空值
隐式插入: 在列表名中省略该列的值
INSERT INTO departments (department_id, department_name )
VALUES (290, 'PR')
显式插入 在VALUES
中指定空值
INSERT INTO departments
VALUES (300, 'PR', NULL, NULL)
修改(更新)数据 UPDATE
WHERE
子句指定需要更新的数据,如果省略WHERER
子句,则表中的所有数据都更新。- 可以一次更新多条数据,如果要回滚数据,在进行操作前要设置
SET AUTOCOMMIT = FALSE
。
UPDATE employees
SET department_id = 70
WHERE employee_id = 113
删除数据 DELETE
WHERE
子句指定要删除的记录。
DELETE FROM departments
WHERE departments.department_name = 'Finance'
常用函数
1. 字符函数
-
大小写控制函数
-
字符控制函数
2. 数字函数
四舍五入, 截断小数位数, 求余
3. 日期函数
获取当前日期,字符串转化为日期,日期转化为字符串
日期函数常用的格式控制符