草庐IT

PHP、SQL、用户数据库

全部标签

ruby-on-rails - 设置没有种子数据的数据库

我需要用表格等设置我的数据库,但在某些情况下我不想加载我的种子数据。我也不想每次想忽略我的种子数据时都删除或移动我的db/seeds.rb文件。有没有办法执行rakedb:setup的任务并忽略种子数据? 最佳答案 是的。只需使用以下两个命令:rakedb:createrakedb:schema:loadrakedb:setup所做的只是创建数据库(db:create),从db/schema.rb加载数据(db:schema:load),然后插入种子数据(db:seed)。您可以单独执行这些步骤。

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G

ruby-on-rails - Rails Devise - 当前用户为零

出于某种原因,current_user在我的无模型Controller(订阅)中返回了nil。我在Internet上找不到任何可以证明这种行为的理由...classSubscriptionsController我有一个csrf元标记:我可以提供更多代码,但我不确定哪些代码会有用。更新感谢评论/回答,我已将问题确定为一个特定的操作:create。如果我将@user=current_user添加到new,我可以在我的newView中显示当前用户的电子邮件。但是,在我的createController中,current_user返回nil。我通过表单(提交)访问了create操作。在提交表单

mysql - Rails 数据库连接池的工作原理

我正在学习Rails数据库连接池概念。在Rails应用程序中,我将池大小定义为5。我对连接池大小的理解如下。当服务器启动时,rails会自动创建n个在database.yml文件中定义的连接。在我的例子中,它将创建5个连接,因为池大小为5。在每个http请求上,如果需要访问数据库,rails将使用连接池中的可用连接来处理请求。但我的问题是,如果我一次达到1000个请求,那么大部分请求将无法访问数据库连接,因为我的连接池大小只有5个。我上面对rails连接池的理解对吗??谢谢, 最佳答案 目的:数据库连接不是线程安全的;所以Activ

ruby-on-rails - 将用户输入转换为整数

所以我有一个用户可以输入价格的表单。我正在尝试制作一个before_validation来规范化数据,如果用户输入它,则剪掉$。before_validationdounlessself.price.blank?thenself.price=self.price.to_s.gsub(/\D/,'').to_iendend如果用户输入$50此代码给我0。如果用户输入50$此代码给我50。我认为由于数据类型是整数,所以Rails在我的before_validation之前运行.to_i并在$之后剪切所有内容。如果数据类型是字符串,同样的代码也能正常工作。有人有解决方案可以让我保留整数数据类

Ruby rest-client 文件上传为具有基本身份验证的多部分表单数据

我了解如何通过Ruby的rest-client使用基本身份验证发出http请求response=RestClient::Request.new(:method=>:get,:url=>@base_url+path,:user=>@sid,:password=>@token).execute以及如何将文件作为多部分表单数据发布RestClient.post'/data',:myfile=>File.new("/path/to/image.jpg",'rb')但我似乎无法弄清楚如何将两者结合起来以便将文件发布到需要基本身份验证的服务器。有谁知道创建此请求的最佳方式是什么?

sql - Rails SQL COUNT N+1 效率低下

我有一个博客。在我的索引页面上,我拉入了所有博客文章。对于每篇博客文章,我都会计算该文章的评论数。这会导致N+1问题。我的查询如下所示:SELECT"blog_posts".*FROM"blog_posts"WHERE("blog_posts"."published"='t')ORDERBYpublished_atDESCSELECT"users".*FROM"users"WHERE("users"."id"IN(1,2,3))SELECTCOUNT(*)FROM"blog_comments"WHERE("blog_comments".blog_post_id=10)SELECTCOU

ruby - 如何干净地验证用户输入是否是 Ruby 中的整数?

我有一段代码,我要求用户输入一个数字作为我问题的答案。我可以执行to_i但棘手/垃圾输入会通过to_i逃逸。例如,如果用户输入693iirum5作为答案,#to_i会将其剥离为693。请建议一个函数,而不是正则表达式。预先感谢您的回复。 最佳答案 这将验证输入:Integer(gets)rescuenil 关于ruby-如何干净地验证用户输入是否是Ruby中的整数?,我们在StackOverflow上找到一个类似的问题: https://stackoverfl

ruby - 如何让 Ruby 'puts' 将数据写入文件?

我有以下代码,我想用它来pingIP地址和写入文件。一切正常,只是我无法将其写入文件。server=%w'192.168.150.254192.168.150.251192.168.120.1192.168.120.2'File.open('/test/test2.out','w')do|s|server.eachdo|p|r=`ping-a-n1#{p}`putsrendend 最佳答案 将putsr更改为s.putsr。您正在写入stdout而不是s。(参见Kernel#puts和IO#puts)

ruby-on-rails - 如何将数据 strip 属性添加到 text_field_tag?

在Stripedocumentation,示例表单显示以下输入我在ruby​​(rails4)中使用以下代码生成我的输入"CardNumber"%>产生但是,我无法添加数据strip属性。我想我总是可以手动添加字段而不使用rails功能。但是,替换select_year和select_month等其他函数会很乏味。那么,如何在使用Rails生成输入时添加自定义属性呢?具体来说,data-stripe="number" 最佳答案 我认为你在追求什么。 关于ruby-on-rails-如何将