jjzjj

sequelize-cli

全部标签

ruby-on-rails - Sequel 与 ActiveRecord 结合使用有什么问题吗?

我正在考虑使用Sequel对于我发现在ActiveRecord中很难制作的一些较复杂的SQL。在同一个项目中使用Sequel和ActiveRecord有什么需要注意的吗?(除了明显的,比如续集中没有AR验证等......) 最佳答案 免责声明:我是Sequel的维护者。在使用Rails时,Sequel很容易与ActiveRecord一起使用或代替ActiveRecord。您必须手动设置数据库连接,但除此之外,用法类似。您的Sequel模型文件位于app/models中,其工作方式类似于ActiveRecord模型。设置数据库连接并不

ruby - 使用 Aruba 和 Bundler 测试基于 Ruby 的 CLI

我有一个RSpec套件,通过Bundler运行,它正在使用Aruba测试许多不同的命令行应用程序。它工作正常......只要被测试的命令本身不是使用Bundler用Ruby编写的。但我无法弄清楚如何防止RSpec套件的bundler配置干扰本身使用bundler的命令的执行-至少,并非没有极端措施。我尝试了unset_bundler_env_vars和with_clean_env的各种排列,但无济于事。这是我认为可行的技术示例:describe'myrubyapp'dobefore:each{unset_bundler_env_vars}it'shouldwork'doBundler.

ruby - 这个怎么写比较好? Ruby Sequel 链接或

在SQL中它应该是这样的:SELECT*FROM`categories_description_old`WHERE((`categories_description`='')OR(`categories_name`='')OR(`categories_heading_title`=''))我的(丑陋的)解决方案:conditions=[:categories_name,:categories_heading_title,:categories_description]b=table_categories_description_old.filter(conditions.pop=>""

ruby - 如何将 Ruby Sequel 日志记录设置为 DEBUG 级别?

默认的RubySequel行为是在INFO级别记录所有数据库查询(不同于在DEBUG级别记录的ActiveRecord)。我该如何更改? 最佳答案 以前,使用代理记录器对象相当简单,但是有足够多的人要求我实现它。使用Sequel的gitmaster分支,您现在可以:DB.sql_log_level=:debug这将在记录查询时使用调试方法而不是信息方法。 关于ruby-如何将RubySequel日志记录设置为DEBUG级别?,我们在StackOverflow上找到一个类似的问题:

ruby - 在连接之前定义 Sequel 模型

在我的(非Rails)应用程序中,我试图定义一个Sequel模型:classFoo当我运行我的应用程序时,出现错误:NodatabaseassociatedwithSequel::Model:haveyoucalledSequel.connectorSequel::Model.db=?(Sequel::Error)事实上,我没有调用连接,因为“requireFoo”发生在我的数据库代码运行之前。当然,我可以换个方式,以便在数据库连接后完成要求,但还有其他选择吗?目前,我将应用程序的所有“require”语句都放在一个文件中,最好不要为这些模型类文件破坏它。

ruby - 如何在 Ruby::Sequel 中测试非空值?

我想做类似的事情User.select(...).where(:name!=nil)没有写类似的东西User.select(...).to_a.find_all{|user|user.name}我可以选择空值,但不能选择非空值。是有什么把戏,还是在Sequel的领域之外? 最佳答案 您可以使用exclude而不是where。User.select(...).exclude(name:nil) 关于ruby-如何在Ruby::Sequel中测试非空值?,我们在StackOverflow上找

ruby - 向 Ruby Thor CLI 添加 --version 选项

如何向我的Ruby添加--version选项Thor命令行界面应用程序。例如我希望能够运行$thor_app--version>thor_appversion1.0.0这个问题与RunaCLIThorappwithoutargumentsortaskname有关,但专门添加一个不需要任务的--version选项。注意这是在self-answerformat之后编写的.鼓励添加答案和更新 最佳答案 我在这种方法上运气不错:classCLI:__print_versiondesc"--version,-v","printtheversi

ruby - 如何更新或插入 Sequel 数据集?

我刚开始在一个非常小的Sinatra应用程序中使用Sequel。因为我只有一个数据库表,所以我不需要使用模型。我想更新一条记录(如果它存在)或者插入一条新记录(如果它不存在)。我提出了以下解决方案:rec=$nums.where(:number=>n,:type=>t)if$nums.select(1).where(rec.exists)rec.update(:counter=>:counter+1)else$nums.insert(:number=>n,:counter=>1,:type=>t)end其中$nums是DB[:numbers]数据集。我相信这种方式不是“更新或插入”行为

sql - 如何使用 Sequel 运行原始 SQL 查询

我还不清楚使用Sequel运行原始SQL查询的正确方法。目前我正在尝试这个:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")do|row|@zonename=rowend我怎样才能将查询作为原始SQL运行,然后像平常一样访问结果?if@zonename.name="UK" 最佳答案 请注意,而不是:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")你应该这样做:DB.fetch("SELE

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d