sql中如何添加数据

本文详细介绍了SQL中的数据添加、修改、删除和查询操作,包括INSERTINTO、UPDATE、ALTER等命令,并列举了Navicat工具中的实用功能如快速备份、导出查询结果等,以提升数据库管理效率。
摘要由CSDN通过智能技术生成

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

在数据库管理系统中,添加数据是一项常见的任务。无论是向现有表中添加新行,还是创建新表并插入数据,都需要使用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语句,可以轻松地向数据库表中添加新数据,为应用程序或系统提供所需的数据支持。记得始终谨慎操作,确保添加的数据符合预期,并遵循最佳实践以确保数据的完整性和一致性。

  • 39
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值