草庐IT

oracle之动态sql

全部标签

sql - 在数据库中清晰地表示电子商务产品和变体

我正在build一家电子商务商店。我正在使用Rails/ActiveRecord,但实际上没有必要回答这个问题(但是,如果您熟悉这些东西,请随时用Rails/AR来回答)。商店的一个要求是它需要代表两种类型的产品:简单产品-这些产品只有一种选择,例如乐队的CD。它有基本的价格和数量。有变化的产品-这些产品有多种选择,例如有3种尺寸和3种颜色的T恤。每种尺寸和颜色的组合都有自己的价格和数量。我以前做过这种事,做了以下几点:有一个产品表,其中包含产品的主要信息(标题等)。有一个变体表,其中包含每种变体的价格和数量信息。产品有_many变体。对于简单产品,他们只会有一个相关联的变体。有没有更

ruby-on-rails - 动态扩展 Virtus 实例属性

假设我们有一个Virtus模型UserclassUserincludeVirtus.modelattribute:name,String,default:'John',lazy:trueend然后我们创建该模型的一个实例并从Virtus.model扩展以动态添加另一个属性:user=User.newuser.extend(Virtus.model)user.attribute(:active,Virtus::Attribute::Boolean,default:true,lazy:true)当前输出:user.active?#=>trueuser.name#=>'John'但是当我尝试

ruby - ruby on rails 中的 SQL Like 运算符

我的任务是选择搜索名字以参数值和所选值中的城市开头的学生。如何在ruby​​onrails中进行设置?我确实喜欢这个,但这不起作用Controllerdefliststudentcount=Student.count()putsstudentcount@studentname=Student.where("namename1ANDcity=:cityId1",{:name1=>params[:name],:cityId1=>params[:cityId]})puts'studentname'puts@studentname.inspect@students=Student.limit(

sql - Rails 控制台和 Rails 服务器日志中输出的颜色是什么意思?

我在Ubuntu14.04中的通用终端(应用程序简称为“终端”)内运行railsserver和railsconsole。每当我运行涉及数据库的命令时,控制台都会输出它发送的SQL查询,但有时文本是绿松石色,有时是紫​​色。例如在这个控制台输出中:2.2.2:025>pl=ProjectLevel.find_by(name:'Premium')ProjectLevelLoad(0.5ms)SELECT"project_levels".*FROM"project_levels"WHERE"project_levels"."deleted_at"ISNULLAND"project_level

sql - 按年、月分组,然后在 ActiveRecord 3 中计数

我正在尝试统计一年和一个月内创建的所有用户,但以下内容似乎没有按预期工作。User.group("YEAR(created_AT),MONTH(created_at)").count("DISTINCT(id),YEAR(created_at),MONTH(created_at)")我在找类似的东西{2011=>{1=>222,2=>333,4=>444,5=>667...}}但是我得到了{1=>222,2=>333,4=>444,5=>667...}我是不是遗漏了什么,或者ActiveRecord不能在一次查询中给我这个结果? 最佳答案

ruby - 在 Ruby 中动态定义类方法

在Ruby1.9.3中,我需要创建几个类实例,每个类实例都具有相似的实例方法和类方法,但仅在几个固定参数方面有所不同。它们的类类型的区别也很重要,所以我不能简单地使用同一类的不同实例。一个简化的示例如下所示。moduleAnimalprivatedefself.make_animal(name,legs,noise)klass=Class.newklass.const_set(:NUM_LEGS,legs)klass.class.send(:define_method,:scream){noise.upcase+'!'}Animal.const_set(name,klass)endma

ruby-on-rails - 如何在动态链接中使用 HAML?

我正在尝试使用看起来像这样的HAML创建链接=link_to("Lastupdatedon",'/member/abc/def?month={Time.now.month}&range=xyz&year={Time.now.year}')它没有采用Ruby代码,而是将其显示为字符串Lastupdatedon并且在URL中它也没有采用函数Time.now.month或Time.now.year。如何在URL和字符串中传递Ruby代码? 最佳答案 你可能应该使用这样的东西:=link_to("Lastupdatedon#{@last_d

ruby-on-rails - Rails 3 动态添加虚拟属性

我的设置:Rails3.0.9、Ruby1.9.2我这样做有我的理由,但我需要的是一种将虚拟属性动态添加到activerecord结果集的方法。这意味着我没有在模型中使用attr_accessor,而是希望将虚拟属性动态添加到结果集中。例如,users=User.all#auserhasfollowingattributes:name,email,password我喜欢做的是说添加(不使用attr_accessor)虚拟属性status到users,这可能吗? 最佳答案 你应该这样做:users.eachdo|user|user.i

sql - 如何在 rails 中添加条件 where 子句

我是一名Rails新手,我正在尝试使用Rails对表执行搜索,而我只是使用我的sql知识来执行此操作。但这看起来不像是rails或ruby​​...有没有更好的方法来做我在下面做的事情?(基本上,如果日期参数已填充,则只将日期参数传递给sql)defsearch(begin_date=nil,end_date=nil)subject="andcreated_at"if!(begin_date.nil?||end_date.nil?)where_part=subject+"BETWEEN:begin_dateAND:end_date"elseif(begin_date.nil?&&end

sql - PostgreSQL 条件 where 子句

在我的RubyonRails应用程序中,我使用的是blazer(https://github.com/ankane/blazer)并且我有以下sql查询:SELECT*FROMsurvey_resultssrLEFTJOINclientscONc.id=sr.client_idWHEREsr.client_id={client_id}这个查询非常有效。但是我需要添加条件逻辑来检查client_id变量是否存在。如果是,那么我将按此变量进行过滤,如果不是,则我不会启动此where子句。我如何在PostgreSQL中执行此操作? 最佳答案