首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

不将数据存储在数据库中,而是在laravel 5.7中返回插入的id

在Laravel 5.7中,可以通过以下方式返回插入的ID,而不将数据存储在数据库中:

  1. 首先,确保你已经在数据库表中定义了自增主键字段(通常命名为"id")。
  2. 在执行插入操作后,可以使用insertGetId()方法来返回插入的ID。该方法会将数据插入数据库,并返回插入记录的自增ID。

下面是一个示例代码:

代码语言:txt
复制
$id = DB::table('your_table_name')->insertGetId([
    'column1' => 'value1',
    'column2' => 'value2',
]);

// $id 变量将包含插入的ID

在上述示例中,你需要将"your_table_name"替换为你的数据库表名,"column1"和"column2"替换为你的表中的实际列名,"value1"和"value2"替换为你要插入的实际值。

这种方式适用于不需要立即访问插入的数据,但需要获取插入ID的情况。如果你需要在插入后立即访问插入的数据,可以使用insert()方法插入数据,并使用lastInsertId()方法获取插入的ID。

希望以上信息对你有帮助!如果你对其他云计算或IT互联网领域的问题有兴趣,欢迎继续提问。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Mybatis使用generatedKey在插入数据时返回自增id始终为1,自增id实际返回到原对象当中的问题排查

今天在使用数据库的时候,遇到一个场景,即在插入数据完成后需要返回此数据对应的自增主键id,但是在使用Mybatis中的generatedKey且确认各项配置均正确无误的情况下,每次插入成功后,返回的都是...终于凭借着一次Debugg发现的问题,原来在使用Mabatis中的insert或者insertSelective方式插入时,如使用int insert(TestGenKey testGenKey)时,返回值...int表示的是插入操作受影响的行数,而不是指的自增长id,那么返回的自增id到底去哪里了呢?...通过下面的Debugg我们知道自增id返回到testGenKey的原对象中去了。 举例示范配置 数据库示例表  generator的配置文件 <?...null : sex.trim(); } } 测试及Debugg 编写测试方法测试插入 插入成功后观察对应的变量对应的值 总结:调用Insert后插入操作之后,所得到自增长Id被赋值到原对象当中

1.7K10
  • 经验:在MySQL数据库中,这4种方式可以避免重复的插入数据!

    个字段,其中主键为id(自增),同时对username字段设置了唯一索引: 01 insert ignore into 即插入数据时,如果数据存在,则忽略此次插入,前提条件是插入的数据字段设置了主键或唯一索引...,测试SQL语句如下,当插入本条数据时,MySQL数据库会首先检索已有数据(也就是idx_username索引),如果存在,则忽略本次插入,如果不存在,则正常插入数据: ?...02 on duplicate key update 即插入数据时,如果数据存在,则执行更新操作,前提条件同上,也是插入的数据字段设置了主键或唯一索引,测试SQL语句如下,当插入本条记录时,MySQL数据库会首先检索已有数据...03 replace into 即插入数据时,如果数据存在,则删除再插入,前提条件同上,插入的数据字段需要设置主键或唯一索引,测试SQL语句如下,当插入本条记录时,MySQL数据库会首先检索已有数据(idx_username...,这种方式适合于插入的数据字段没有设置主键或唯一索引,当插入一条数据时,首先判断MySQL数据库中是否存在这条数据,如果不存在,则正常插入,如果存在,则忽略: ?

    4.5K40

    JDBC:数据库自定义类型与Java类的映射—将对象存储在关系数据库中(二)

    这里利用PostgreSQL扩展的JDBC方法进行数据库自定义类型和Java类的映射关系,将Java对象插入关系数据库中。...步骤如下: 1.在数据库中自定义数据类型(CREATE TYPE TypeName AS) 2.在Java中新建对应的JavaBean,继承PGobject类,实现Serializable接口。...3.将数据库连接对象Connection接口强制转换成PGConnection,添加数据类型映射 ((PGConnection)connection).addDataType(TypeName, 类型对应...利用setType方法,参数为数据库中的TypeName。 5.利用PreparedStatement的setObject方法设置。...address) { this.address = address; } public void getAddress() { return address; } } 关系映射和数据插入

    3.6K10

    JDBC:数据库自定义类型与Java类的映射—将对象存储在关系数据库中(一)

    最近在使用PostgreSQL数据库,PostgreSQL中可以自定义自己的数据类型。 那怎么利用JDBC将Java类与PostgreSQL数据库中自己定义的类型关联起来呢。...即怎么将Java对象存储在数据库中呢。我这里说的对象的存储不是讲对象序列化了以二进制的方式进行的存储,我说的是不经过序列化直接进行的存储。因为数据库中有Java对象对应的自定义类型。...下面先总结下步骤: 1.在数据库中自定义数据类型(CREATE TYPE TypeName AS) 2.在Java中新建对应的JavaBean,继承SQLData类,并实现其中的一些方法 3.利用数据库连接对象的...后来我发现PostgreSQL有扩展JDBC,还有提供其他方法,经过我的摸索,用另外一种方式映射成功了,成功将对象插入关系数据库。...详细步骤见下篇博客JDBC:数据库自定义类型与Java类的映射—将对象存储在关系数据库中(二)。

    8.3K40

    MySQL---数据库从入门走向大神系列(八)-在java中执行MySQL的存储过程

    http://blog.csdn.net/qq_26525215/article/details/52143733 在上面链接的博客中,写了如何用MySQL语句定义和执行存储过程 Java执行存储过程:...向 setter 方法传递值时,不仅需要指定要在参数中使用的实际值,还必须指定参数在存储过程中的序数位置。例如,如果存储过程包含单个 IN 参数,则其序数值为 1。...Java演示执行带输入输出参数的存储过程: 构造 call 转义序列时,请使用 ?(问号)字符来指定 OUT 参数。 此字符充当要从该存储过程返回的参数值的占位符。...要为 OUT 参数指定值,必须在运行存储过程前使用 SQLServerCallableStatement 类的 registerOutParameter 方法指定各参数的数据类型。...当您对于 OUT 参数向 registerOutParameter 方法传递一个值时,不仅必须指定要用于此参数的数据类型,而且必须在存储过程中指定此参数的序号位置或此参数的名称。

    1.1K20

    Laravel Eloquent 模型关联关系(下)

    从性能上来说,渴求式加载更优,因为它会提前从数据库一次性查询所有关联数据,而懒惰式加载在每次查询动态属性的时候才会去执行查询,会多次连接数据库,性能上差一些(数据库操作主要开销在数据库连接上,所以在开发过程中如果想优化性能...,如果返回的文章结果是列表的话,需要遍历获取作者信息,假设要循环 N 次的话,加上文章模型本身的获取,总共需要进行 N + 1 次查询,而 PHP 对数据库的连接是短连接,每次都要重新连接数据库,所以从性能角度考虑不建议使用这种方式...所以不管模型实例有多少个,关联结果只会查询一次,加上模型本身查询总共是两次查询,在列表查询时,大大减少了对数据库的连接查询次数,因而有更好的性能表现,推荐使用。...>orderBy('created_at', 'desc'); }]); 关联插入与更新 一对多关联记录插入 新增关联模型的时候,可以在父模型上调用相应方法直接插入记录到数据库,这样做的好处是不需要指定关联模型与父模型的外键关联字段值...]); } 再次访问对应 Post 模型上的 author 属性时,就会返回如下默认的空对象了: 该特性其实应用了设计模式中的空对象模式,好处是在代码里可以为不同情况编写一致性代码。

    19.6K30

    通过 Laravel 查询构建器实现简单的增删改查操作

    通过前面几篇教程的预热,我们已经连接上数据库,创建好了数据表,填充好了数据,接下来,就是在 Laravel 应用中实现对数据库的增删改查了。...`name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL)'); 只不过在 Laravel 中,我们不推荐这么做,因为这些对数据表结构的操作可以通过数据库迁移功能来实现...原生插入语句 想要在数据库中插入一条记录,通过 DB 门面提供的 insert 语句即可: $name = str_random(10); $email = str_random(10) . '@163...使用查询构建器进行增删改查 接下来,我们开始介绍 Laravel 数据库功能的核心组件 —— 查询构建器(说是核心,是因为 Eloquent 模型的底层也是基于这个查询构建器),日常开发中,我们与数据库的交互基本都是直接或间接通过它来完成的...更新记录 更新数据库记录通过 update 方法来完成,我们可以在该方法中传入待修改字段及对应修改值数组: $id = 11; $affectedRows = DB::table('users')->where

    4.2K20

    laravel 模型Eloquent ORM 添加编辑删除

    因为在模型默认不允许进行批量赋值需要先定义允许 create 方法插入到数据库的字段,就是给 $fillable 属性定义允许赋值的字段 up 先在模型中定义 $fillable 属性 /**...create 方法的返回值就是当前插入到数据库中的内容up可以通过返回值判断成功或者失败而实际开发中up经常需要返回新增数据的id那直接访问返回值的 id 属性即可。...数据中一眼就发现了后三条数据的不同,我们之前用 DB 插入到数据库中的数据 created_at 和 updated_at 字段都是空,而我们用模型插入和修改后 created_at 和 updated_at...Laravel 的 数据库迁移 有创建这个字段的方法 现在,当你在模型实例上使用 delete 方法, 当前日期时间会写入 deleted_at 字段。...执行完这个在查询下数据库 ? up 发现 deleted_at 已经被置空这个时候在请求 index 方法 ? 之前乱删除的数据变恢复回来了 但是如果要彻底删除改怎么做呢?

    1.7K21

    基于 Redis + 资源库模式实现 Laravel 应用缓存功能

    今天学院君来给大家演示如何在 Laravel 项目中基于 Redis 实现应用缓存功能,这想必也是很多人日常使用 Redis 最多的业务场景,这里的缓存指的是将数据库查询结果存储到 Redis,其目的是将数据加载从磁盘...); 在浏览器中测试这两个路由: 都可以正常返回数据,说明代码重构成功。...(如果缓存项是对象,则通过 unserialize 方法对其做反序列化操作再返回); 若缓存项不存在,则先通过数据库查询获取结果,然后基于 Redis 的 SETEX 指令将其存储到 Redis(如果待缓存项是对象...你可以到 Redis 命令行客户端去查看对应的缓存数据: 使用 Laravel 自带的缓存组件 当然,在 Laravel 项目中,如果使用 Redis 作为缓存存储器的话,推荐使用自带的缓存组件,在配置好...: 刷新该页面,由于命中了缓存,就不会再做数据库查询,而是直接返回对应的缓存项了: 热门文章排行榜路由也是类似,这里不再重复演示了。

    2.5K10

    arcengine+c# 修改存储在文件地理数据库中的ITable类型的表格中的某一列数据,逐行修改。更新属性表、修改属性表某列的值。

    作为一只菜鸟,研究了一个上午+一个下午,才把属性表的更新修改搞了出来,记录一下: 我的需求是: 已经在文件地理数据库中存放了一个ITable类型的表(不是要素类FeatureClass),注意不是要素类...FeatureClass的属性表,而是单独的一个ITable类型的表格,现在要读取其中的某一列,并统一修改这一列的值。...表在ArcCatalog中打开目录如下图所示: ? ?...= ""; //利用ICursor进行数据更新修改 ICursor updateCursor = pTable.Update(queryFilter,...网上有的代码是用的ID来索引,但是表格的ID可能并不是从0开始,也不一定是按照顺序依次增加。

    9.6K30

    Laravel5.2之Demo1——URL生成和存储

    学习主题 该demo主要涉及如下几个知识点: 创建数据库并迁移数据表 创建表单,学习Laravel的blade模板引擎 创建名为Link的模型Model 保存数据进入数据库 从数据库中获得...URL数据库,需要做几个步骤: (1)、首先创建一个数据库并定义该数据库与Laravel的连接信息,Laravel框架为数据库连接提供了配置文件:/config/database.php,Laravel...4、保存数据进入数据库 写好视图表单后,再就是写表单的提交路由及其控制器逻辑,在控制器中引用创建好的Link这个Model往links数据表里存数据。...根据提供数据在数据表里插入一个记录record 返回该链接给用户(1).使用Query Builder的where()方法,并传入Input::get('link')参数验证数据表里是否已经有该链接...6、从数据库中取出URL并且重定向 最后根据生成的URL获取其hash部分,根据hash值从links数据表取出对应的URL为了重定向,这里英文原文也是在路由中写逻辑,这里也在路由里写逻辑: Route

    24.1K31

    编写一个Java Web项目,实现从properties文件读取数据存储到数据库,并从数据库中读取数据,将结果显示在页面上。启动mysql数据库服务器端,并且创建一个名为studentinfo的数据库

    ); void update(int id, Student newStudent); } StudentdaoImpl(这个不写,但是Dao层主要是靠这个跟数据库打交道,所以挂一下) package...ResourceBundle resource = ResourceBundle.getBundle("/Student"); //解析文件以后我们将文件内容存入数据库...} } @Override public void insert(Student student) { //解析文件以后我们将文件内容存入数据库...dataOperation.jsp").forward(req,resp); } } 4结 当然其他部分还有很多,但是只要求写这几个,都给你们了哈 记得关注下 拜了个拜 打一波我自己课程的广告哈...数据库系统概论速成: https://www.bilibili.com/video/BV1jf4y147jz javaWeb课设: https://www.bilibili.com/video

    7.1K20

    【Laravel系列4.2】查询构造器

    其实就像我们上篇文章中学习过的使用原始 SQL 语句的方式来操作数据库一样,查询构造器这个东西就是在这个原始操作的基础上为我们封装了一系列的接口,能够让我们方便地来操作数据库。...使用 insertGetId() 我们可以插入一条数据并返回这条数据的主键 ID ,这个相信会是大家最常用的。当然,也有 insert() 方法,它返回的是成功失败。...另外,像上面测试代码中我们是一条一条地插入数据的,也可以整个批量地插入数据,后面我们会讲到。...在 查询构造器 中,还有其它很多的链式函数可以实现非常复杂的数据库操作,大家可以自己去研究一下。...不过需要注意的是,insert() 返回的是布尔值,表示成功失败,所以在批量插入的时候想要得到所有的插入 ID 就需要用别的方法了。

    16.8K10

    3分钟短文:Laravel模型创建数据条目的2个语法糖

    [img] 本期我们开始讲模型中,如何插入新条目,或者更新既有条目。...代码时间 我们在构建一个hello world页面的时候,已经介绍了如何使用laravel的命令行脚手架创建新的模型文件,以及通过迁移功能创建数据库表。这样就把数据操作衔接起来了。...我们在表中还有id字段,created_at字段,updated_at字段,并没有显式赋值。但是你打开数据库表查看结果的时候,发现那些值也成功的写入了。...这样laravel在处理模型数据的时候,会默认更新此二字段。 然而,对于写入数据库的那些数据,并不是所有字段都会允许写入的。在模型内我们可以手动指定哪些字段可以写,哪些字段不可以写。...新建 or 更新 接着介绍laravel模型的几个语法糖。一个常规的场景,比如在写入数据时,先判断数据库表内是否有该条记录,如果没有就创建,如何有则返回。

    1.9K00

    Laravel基础

    一、Laravel核心目录文件介绍 app:程序的核心代码和业务逻辑代码,其中的Http目录是我们业务逻辑的存放点 bootstrap:包含框架启动的和自动加载文件 config:包含所有程序中的配置文件...实现CURD(原生SQL语句操作数据库 ) 3.1.1 插入数据 (返回bool 插入是否成功) $result = DB::insert('insert into student(name,age)...= ['aa', 'bb']; //不允许批量赋值的字段 黑名单设置 $fillabel 是为了防止注入攻击,比如有的用户可能在表单中注入了一些别的信息更改数据库中的其他内容,因此我们要定义哪些数据是能被修改的...,这里就是’$fillabel’包含的内容才能够被修改.而$hidden包含的内容则是指存储时这些信息会被加密存储,这样即使数据库泄露出去,信息也不会那么容易直接被读取。...,也可以有内容,还可以被子模版扩展 在view中,模板继承: 用@extends('模板名') 模板重写: @section('重写部分的名字') 重写的内容 @stop @yield

    7.8K30

    【Laravel系列4.3】模型Eloquent ORM的使用(一)

    我们在关系型数据库中,一行数据就可以看成是一个对象,整个表就可以看成是这个对象的列表。这就是非常简单地针对 ORM 的理解。 Java 中的 Hibernate 就是早期非常经典的 ORM 框架。...通过前两篇文章的铺垫,我们很容易就能操作 Laravel 中的模型,但是,真正要改变的是你看待这种操作数据库的方式。要把数据库里的数据想像成是编程语言中的对象,这才是 ORM 最主要的内容。...在这里比较奇怪的是,我们在实例化和赋值的过程中没有给对象的主键 id 赋值,但是在 save() 之后,id 就有值了,而且是我们新插入的数据 id ,是不是很高大上。...在标准的数据库结构中,我们是有主外键的概念的,但是,说实话,在 MySQL 中使用主外键的情况还真的是非常少。之前似乎有印象说 MySQL 不是很推荐通过主外键来建立表之间的联系。...这样做的原因也正是为了保持数据的一致性和完整性。 当然,在 Laravel 中,可以不在数据库层面进行严格的设置,就可以在框架代码中实现主外键的关联。

    8.9K20

    Laravel框架关键技术解析

    ) C.PHP中的特殊语法 1.魔术方法:通常用户不会主动调用,而是在特定的时机被PHP系统自动调用,可以理解为系统事件监听方法,在事件发生时才触发执行。...2.使用static来实现,通过这种机制,“static::”不再被解析为定义当前方法所在的类,而是在实际运行时计算得到的,即为运行时最初调用的类,不仅限制于静态方法的调用 3.后期静态绑定还可以用于对象实例化中...4.两个别名:一是容器核心别名,存在Application中的$aliases,另一个是外观别名,定义在app.php配置文件中,程序运行后存储在AliasLoader类实例的$aliases属性中 5.../laravel5.4cn 十、数据库及操作 A.数据库迁移与填充 1.Laravel的数据库迁移其实是定义了一个统一的接口来实现数据库架构的创建和维护,而这种统一的接口与底层的数据库及其操作语言都是无关的...这个过程可以称为session的操作阶段。 3.当返回响应时,将session中的数据存储到相应的位置,以备下一次请求到来时使用并发送sessionID的Cookie。

    12K20

    如何在Ubuntu 16.04上使用Deployer自动部署Laravel应用程序

    在本教程中,您将自动部署Laravel应用程序,而不会出现任何宕机问题。为此,您将准备将从中部署代码的本地开发环境,然后使用Nginx和MySQL数据库配置生产服务器为该应用程序提供服务。...鉴于此,在/var/www/html目录中创建的所有新文件和子目录都应继承文件夹的组ID(www-data)。...在本地计算机上,将工作目录更改为应用程序的文件夹: $ cd /path/to/laravel-app 在laravel-app目录中运行以下命令以初始化项目文件夹中的Git存储库: $ git init...该应用程序.env在本地计算机上有一个文件,但Laravel的.gitignore文件将其从Git仓库中排除,因为在Git存储库中存储密码等敏感数据不是一个好主意,而且,应用程序需要在服务器上进行不同的设置...before('deploy:symlink', 'artisan:migrate'); 警告:这将导致数据库迁移在每个部署中自动运行。这样可以避免手动迁移数据库,但在部署之前不要忘记备份数据库。

    15.6K10
    领券