提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
前言
在数据库管理系统中,添加数据是一项常见的任务。无论是向现有表中添加新行,还是创建新表并插入数据,都需要使用SQL(Structured Query Language)语句来执行。本文将介绍SQL中如何添加数据的基本方法,以及一些常用的技巧和最佳实践。
一、sql新增操作
在SQL中,添加数据通常是通过INSERT INTO语句来实现的。以下是一个基本的示例:
INSERT INTO 表名称 (列1, 列2, 列3, ...)
VALUES (值1, 值2, 值3, ...);
如果要为表中的所有列添加数据,可以省略列名称,但必须保证值的顺序与表中列的顺序相匹配:
INSERT INTO 表名称
VALUES (值1, 值2, 值3, ...);
例如,假设有一个名为students的表,它有三列:id, name, 和 age。要添加一个新的学生记录,可以使用以下SQL语句:
INSERT INTO students (id, name, age)
VALUES (1, '张三', 20);
如果你要添加的数据是多个记录,可以使用一个INSERT INTO语句,每个值集合由逗号分隔:
INSERT INTO students (id, name, age)
VALUES (1, '张三', 20),
(2, '李四', 22),
(3, '王五', 23);
二、sql修改操作
修改表中的数据:
UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;
添加新的列:
ALTER TABLE table_name
ADD column_name datatype;
删除列:
ALTER TABLE table_name
DROP COLUMN column_name;
修改列的数据类型:
ALTER TABLE table_name
MODIFY column_name new_datatype;
重命名列:
ALTER TABLE table_name
CHANGE old_column_name new_column_name datatype;
重命名表
RENAME TABLE old_table_name TO new_table_name;
三、sql删除操作
删除表中所有记录:
DELETE FROM table_name;
根据条件删除特定记录:
DELETE FROM table_name WHERE condition;
删除多张表中的相关联记录:
DELETE t1, t2 FROM table1 AS t1 INNER JOIN table2 AS t2 ON t1.id = t2.id WHERE condition;
这里通过INNER JOIN将两张表连接起来,并且可以在WHERE子句中添加额外的条件来限制删除范围。
需要注意的是,对于大型数据库或者重要数据的删除操作,应当先备份数据再进行删除,以防止不必要的数据丢失。
清空表并重置主键
#删除当前表中已有数据
truncate table table_name;
#修改表中自增主键启始值
ALTER TABLE table_name AUTO_INCREMENT=1;
四、sql查询操作
一些常用的根据时间查询的sql
//今天
select * from 表名 where to_days(时间字段名) = to_days(now());
//昨天
SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1
//近7天
SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(时间字段名)
//近30天
SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(时间字段名)
//本月
SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )
//上一月
SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1
//查询本季度数据
select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(now());
//查询上季度数据
select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));
//查询本年数据
select * from `ht_invoice_information` where YEAR(create_date)=YEAR(NOW());
//查询上年数据
select * from `ht_invoice_information` where year(create_date)=year(date_sub(now(),interval 1 year));
//查询当前这周的数据
SELECT name,submittime FROM enterprise WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now());
//查询上周的数据
SELECT name,submittime FROM enterprise WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now())-1;
//查询上个月的数据
select name,submittime from enterprise where date_format(submittime,'%Y-%m')=date_format(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m')
select * from user where DATE_FORMAT(pudate,'%Y%m') = DATE_FORMAT(CURDATE(),'%Y%m') ;
select * from user where WEEKOFYEAR(FROM_UNIXTIME(pudate,'%y-%m-%d')) = WEEKOFYEAR(now()) select * from user where MONTH(FROM_UNIXTIME(pudate,'%y-%m-%d')) = MONTH(now())
select * from user where YEAR(FROM_UNIXTIME(pudate,'%y-%m-%d')) = YEAR(now()) and MONTH(FROM_UNIXTIME(pudate,'%y-%m-%d')) = MONTH(now())
select * from user where pudate between 上月最后一天 and 下月第一天
//查询当前月份的数据
select name,submittime from enterprise where date_format(submittime,'%Y-%m')=date_format(now(),'%Y-%m')
五、navicat的一些操作
1,快速生成sql语句
2,快速备份一张表
3,导出查询结果
4,索引设置
5,数据导入
6,存储过程创建
7,定时任务(时间)
8,表信息设置
总结
通过本文,我们了解了SQL中如何添加数据的基本方法和一些常用技巧。使用适当的INSERT INTO语句,可以轻松地向数据库表中添加新数据,为应用程序或系统提供所需的数据支持。记得始终谨慎操作,确保添加的数据符合预期,并遵循最佳实践以确保数据的完整性和一致性。