【MySQL】不允许你不知道如何插入数据

这篇具有很好参考价值的文章主要介绍了【MySQL】不允许你不知道如何插入数据。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🎬 博客主页:博主链接
🎥 本文由 M malloc 原创,首发于 CSDN🙉
🎄 学习专栏推荐:LeetCode刷题集
🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
📆 未来很长,值得我们全力奔赴更美好的生活✨

【MySQL】不允许你不知道如何插入数据,数据库sql_server,mysql,adb,数据库
【MySQL】不允许你不知道如何插入数据,数据库sql_server,mysql,adb,数据库

😇MySQL的前情介绍

😁大家好呀,今天是我第N次写MySQL,也是最近才学习MySQL,也想着记录一下自己的学习过程,并且分享给大家尼!

😇本章详情

🐤本篇文章将介绍如何利用SQL的INSERT语句将数据插入表中

😇数据插入

前言

毫无疑问,SELECT是最常使用的SQL语句了(这就是为什么前面的一章讲的都是它的原因)。但是,还有其他3个经常使用的SQL语句需要学习。第一个就是INSERT(下一篇文章介绍另外两个)。

顾名思义,INSERT是用来插入(或添加)行到数据库表的。插入可以用几种方式使用:

  1. 插入完整的行;
  2. 插入行的一部分;
  3. 插入多行
  4. 插入某些查询的结果;

下面将详细的介绍一些内容
插入及系统安全

插入及系统安全可针对每个表或每个用户,利用MySQL的安全机制禁止使用INSERT语句,这将在后面的文章进行介绍。

😇插入完整的行

💐把数据插入表中的最简单的方法是使用基本的INSERT语法,它要求指定表名和被插入到新行中的值。下面举例说明:

输入

INSERT INTO CustomersVALUES(NULL'Pep E. LaPew', '100 Main Street',
	'Los Angeles','CA','90046','USA','NULL','NULL');

分析

🌱此例子插入一个新客户到customers表。存储到每个表列中的数据在VALUES子句中给出,对每个列必须提供一个值。如果某个列没有值(如上面的cust_contact和cust_email列),应该使用NULL值(假定表允许对该列指定空值)。各个列必须以它们在表定义中出现的次序填充。第一列cust id也为NULL。这是因为每次插入一个新行时,该列由MySQL自动增量。你不想给出一个值(这是MySQL的工作),又不能省略此列(如前所述,必须给出每个列),所以指定一个NULL值 (它被MySQL忽略,MySQL在这里插入下一个可用的cust id值)。

注意!

🌻没有输出 INSERT语句一般不会产生输出


编写INSERT语句的更安全(不过更烦)的方法如下:

输入

INSERT INTO customers(cust_name,
cust_address,
cust_city,
cust_state
cust_zip,
cust_country,cust_contact,cust_emai1)VALUES('Pep ELaPew','100 Main Street','Los Angeles','CA','90046','USA','NULL','NULL');

分析

此例子完成与前一个INSERT语句完全相同的工作,但在表名后的括号里明确地给出了列名。在插入行时,MySQL将用VALUES列表中的相应值填入列表中的对应项。VALUES中的第一个值对应于第一个指定的列名。第二个值对应于第二个列名,如此等等。

因为提供了列名,VALUES必须以其指定的次序匹配指定的列名,不定按各个列出现在实际表中的次序。其优点是,即使表的结构改变,此INSERT语句仍然能正确工作。你会发现cust_id的NULL值是不必要的,cust id列并没有出现在列表中,所以不需要任何值。


下面的INSERT语句填充所有列(与前面的一样),但以一种不同的次序填充。因为给出了列名,所以插入结果仍然正确:

输入

INSERT INTO customers(cust_name,
cust_contact,cust_emai1,
cust_address,
cust_city,
cust_state,
cust_zip,
cust_country)
VALUES('Pep E. LaPew',
NULLNULL'100 Main Street',
'Los Angeles',
'90046','USA');

总是使用列的列表 一般不要使用没有明确给出列的列表的INSERT语句。使用列的列表能使SOL代码继续发挥作用,即使表结构发生了变化

使用这种语法,还可以省略列。这表示可以只给某些列提供值,给其他列不提供值。(事实上你已经看到过这样的例子:当列名被明确列出时,cust_id可以省略。)

提高性能

提高整体性能 数据库经常被多个客户访问,对处理什么请求以及用什么次序处理进行管理是MySQL的任务。INSERT操作可能很耗时(特别是有很多索引需要更新时),而且它可能降低等待处理的SELECT语句的性能。
如果数据检索是最重要的(通常是这样),则你可以通过在INSERT和INTO之间添加关键字LOW PRIORITY,指示MySQL降低INSERT语句的优先级,如下所示:
INSERT LOW PRIORITY INTO
顺便说一下,这也适用于下一章介绍的UPDATE和DELETE语句

😇插入多个行

INSERT可以插入一行到一个表中。但如果你想插入多个行怎么办?

🌼可以使用多条INSERT语句,甚至一次提交它们,每条语句用一个分号结束,如下所示:

输入

INSERT INTO customers(cust_namecust_address,
cust_city,
cust_state,
cust_zip,
cust_country)VALUES('Pep ELaPew',
'100 Main Street',
'Los Angeles',
'CA',
'90046',
'USA');INSERT INTO customers(cust_namecust_address,
cust_city,
cust_state,
cust_zip,
cust_country)VALUES('M.Martian',
'42 Galaxy way',
'New York',
'iNY',
'11213',
'USA');

😇插入检索出的数据

INSERT一般用来给表插入一个指定列值的行。但是,INSERT还存在另一种形式,可以利用它将一条SELECT语句的结果插入表中。这就是所谓的INSERTSELECT,顾名思义,它是由一条INSERT语和一条SELECT语句组成的。

假如你想从另一表中合并客户列表到你的customers表。不需要每次读取一行,然后再将它用INSERT插入,可以如下进行:

输入

INSERT INTO customers(cust_id,
cust_contact,
cust_email,
cust_name,
cust_address,
cust_city,
cust_state
cust_zip,cust_country)SELECT cust_id,
cust_contact,
cust_email,cust_name,
cust_address
cust_city,
cust_state,
cust_zip,
cust_country FROM custnew;

分析

这个例子使用INSERT SELECT从custnew中将所有数据导入customers。SELECT语句从custnew检索出要插入的值,而不是列出它们。SELECT中列出的每个列对应于customers表名后所跟的列表中的每个列。这条语句将插入多少行有赖于custnew表中有多少行。如果这个表为空,则没有行被插入(也不产生错误,因为操作仍然是合法的)。如果这个表确实含有数据,则所有数据将被插入到customers。

🤣如何巩固学习

提示:在学习的过程中,我们需要先自行进行思考,而不是一遇到不会的就放弃思考直接看答案,如果最后遇到真的不会的题目,我们可以适当的进行观看答案,看自己的思路是否正确,在作出正确的判断

🤣本文小结

本篇文章介绍如何将行插入到数据库表。我们学习了使用INSERT的几种方法,以及为什么要明确使用列名,学习了如何用INSERT SELECT从其他表中导入行。下一章讲述如何使用UPDATE和DELETE进一步操纵表数据。

好啦今日的分享到这里就结束啦,我是爱你们的M malloc希望可以帮助到你们噢,最后别忘记三连啦!!

【MySQL】不允许你不知道如何插入数据,数据库sql_server,mysql,adb,数据库

【MySQL】不允许你不知道如何插入数据,数据库sql_server,mysql,adb,数据库文章来源地址https://www.toymoban.com/news/detail-612460.html

到了这里,关于【MySQL】不允许你不知道如何插入数据的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySql数据库允许外网访问连接

    正常情况下,mysql数据库是不支持外网进行访问的,只能在本机进行登录操作。 下面提供两种方式对mysql进行配置,即可进行外网访问 第一步:使用客户端在本机连接MySQL服务,登录。 然后找到mysql这个数据库,里面有user这种表,打开表 第二步:找到User是root,Host是localhos

    2023年04月10日
    浏览(84)
  • 下载加速小妙招,我不允许你不知道

    在你深夜刷剧刷得最激动的时候,屏幕突然打转转…… 在你打游戏打到最精彩的团战时刻,你的网络突然404…… 在你激情澎湃,好不容易抢到心爱之物要付款的时候,页面却突然加载不出来…… 如果真要碰到这些事情,光是想一想就会让人觉得非常崩溃。想要避免这些情况

    2024年02月02日
    浏览(45)
  • 本地MySQL数据库允许用任意ip连接访问

    1、进入本地mysql,输入下面命令,然后输入密码 mysql -uroot -proot 2、进入到mysql。然后选择mysql这个数据库 use mysql 3、 找到user这个表,然后查询一下里面的user和host字段   select user,host from user; 看到里面有一个root的用户对应的host值是一个localhost或者是127.0.0.1。 接下来要把这个

    2023年04月08日
    浏览(48)
  • MySQL数据库——MySQL INSERT:插入数据(添加数据)

    数据库与表创建成功以后,需要向数据库的表中插入数据。在 MySQL 中可以使用 INSERT 语句向数据库已有的表中插入一行或者多行元组数据。 INSERT 语句有两种语法形式,分别是 INSERT…VALUES 语句和 INSERT…SET 语句。 1) INSERT…VALUES语句 INSERT VALUES 的语法格式为: 语法说明如下:

    2024年02月08日
    浏览(70)
  • MySQL 数据库表格创建、数据插入及获取插入的 ID:Python 教程

    要在MySQL中创建表格,请使用\\\"CREATE TABLE\\\"语句。 确保在创建连接时定义了数据库的名称。 示例创建一个名为 \\\"customers\\\" 的表格: 如果上述代码没有出现错误,那么您已成功创建了一个表格。 您可以通过使用\\\"SHOW TABLES\\\"语句列出数据库中的所有表格来检查表格是否存在: 示例返

    2024年02月05日
    浏览(52)
  • MySql数据库实现数据存在则更新,不存在则插入

    1.存在则更新(不影响其他字段),不存在则插入 如上语句的意思的意思是如果字段1不存在(主键,索引或者唯一条件不存在),则执行插入语句,存在则执行更新语句,该更新只更新需要的字段,不影响其他字段的值; 2.存在则更新(先删除后更新),不存在则插入 如上

    2024年02月15日
    浏览(38)
  • Python将Excel文件插入Mysql数据库(脚本)

    🌸 欢迎来到Python办公自动化专栏—Python处理办公问题,解放您的双手 🏳️‍🌈 博客主页:一晌小贪欢的博客主页 👍 该系列文章专栏:Python办公自动化专栏 文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏 ❤️ 欢迎各位佬关注! ❤️ 前言 最近接到一个

    2024年02月05日
    浏览(46)
  • MySQL数据库中对表进行创建,插入数据并对数据进行选择

    目录  1.根据此图进行建表并插入数据  2.对表进行以下操作 a:显示所有职工的基本信息 b:查询所有职工所属部门的部门号,不显示重复的部门号 c:求出所有职工的人数 d:列出最高工和最低工资 e:列出职工的平均工资和总工资 f:创建一个只有职工号、姓名和参加工作的新表,名

    2024年02月15日
    浏览(55)
  • 天天使用MySQL,你知道MySQL数据库能抗多少压力吗?附(真实案例)

            今天给大家分享一个知识点,是关于MySQL数据库架构演进的,因为很多兄弟天天基于mysql做系统开发,但是写的系统都是那种 低并发压力、小数据量 的,所以哪怕上线了也就是这么正常跑着而已,但是你知道你连接的这个MySQL数据库他到底能抗多大并发压力吗?如

    2024年02月09日
    浏览(38)
  • Mysql数据库--修改root密码的几种方法(忘记密码&知道密码)

    🍁 通过 alter user root identified by \\\'新密码\\\'; 🍁 通过 set password for 用户名@\\\'用户地址\\\' = \\\'新密码\\\'; 2.1.1 🎈 停止mysql服务 2.1.2 🎈 创建mysql-init-file.txt文件 2.1.3 🎈 init-file的权限(最好赋权一下) 2.1.3 🎈 使用–init-file选项启动mysql服务 2.1.4 🎈 新密码连接测试(密码:Zyl@123321)

    2024年02月08日
    浏览(84)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包