草庐IT

【PostgreSQL】存储过程

全部标签

《MySQL高级篇》四、索引的存储结构

1.为什么使用索引假如给数据使用二叉树这样的数据结构进行存储,如下图所示2、索引及其优缺点2.1索引概述2.2优点类似大学图书馆建书目索引,提高数据检索的效率,降低数据库的IO成本这也是创建索引的主要的原因。通过创建唯一索引,可以保证数据库表中每一行数据的唯一性(唯一约束)在实现数据的参考完整性方面,可以加速表和表之间的连接。换句话说,对于有依赖关系的子表和父表联合查询时,可以提高查询速度。在使用分组和排序子句进行数据查询时,可以显著减少查询中分组和排序的时间,降低了CPU的消耗。2.3缺点增加索引也有许多不利的方面,主要表现在如下几个方面:创建索引和维护索引要耗费时间(因为索引是排好序的),

ruby-on-rails - 为什么最好将电话号码存储为字符串而不是整数?

如问题所述,为什么将电话号码作为字符串而不是整数存储在telephone_number列中被认为是最佳实践?不确定我是否理解这样做的理由。请帮忙解决这个问题!谢谢! 最佳答案 电话号码是数字字符串,不是整数。例如考虑:用不同的基数表示电话号码会使它变得毫无意义将两个电话号码相加或相乘,或者对电话号码进行任何数学运算,都是没有意义的。结果不是另一个电话号码(巧合除外)电话号码应“按原样”输入连接的设备。电话号码可以有前导零。电话号码的操作,例如添加区号,是字符串操作。存储电话号码的字符串版本使其清晰明确。历史:在旧的脉冲编码拨号系统中

ruby-on-rails - 用于 postgresql 的 Ruby on Rails : How can I edit database. yml?

Rails新应用。当前的database.yml是这样的:#SQLiteversion3.x#geminstallsqlite3##EnsuretheSQLite3gemisdefinedinyourGemfile#gem'sqlite3'development:adapter:sqlite3database:db/development.sqlite3pool:5timeout:5000#Warning:Thedatabasedefinedas"test"willbeerasedand#re-generatedfromyourdevelopmentdatabasewhenyourun

ruby-on-rails - 如何使用 postgresql 在 Rails 中执行不区分大小写的顺序

我正在将我的开发环境从sqlite3切换到postgresql8.4,还有最后一个障碍。在我原来的帮助方法中有以下行;result=Users.find(:all,:order=>"namecollateNOCASE")它提供了一个非常好的不区分大小写的搜索。我不能为postgresql复制这个。应该很简单-有什么想法吗?谢谢。 最佳答案 result=Users.find(:all,:order=>"LOWER(name)")向Brad和Frank学习一点。 关于ruby-on-rai

ruby-on-rails - UUID 作为 PostgreSQL 中的主键是否会带来糟糕的索引性能?

我使用PostgreSQL数据库在Heroku上的Rails中创建了一个应用程序。它有几个表,旨在能够与移动设备同步,在这些设备上可以在不同的地方创建数据。因此,我有一个uuid字段,它是一个存储GUID以及自动递增主键的字符串。uuid是在服务器和客户端之间通信的。我在服务器端实现同步引擎后意识到,当需要一直在uuidid之间映射时,这会导致性能问题(在编写对象时,我需要先查询uuid以获取id保存和发回数据时相反)。我现在正在考虑切换到仅使用UUID作为主键,从而使写入和读取变得更加简单和快速。我读到UUID作为主键有时会在使用聚簇主键索引时导致糟糕的索引性能(索引碎片)。Post

ruby - bundler 在哪里存储 gem ?

我知道当使用geminstall时,gem将存储在/home/username/.rvm/gems/下,在gemset下安装了gem。但是如果我使用Bundler并在Gemfile中指定gem,当我运行bundleinstall时,这些gem将存储在哪里?如果我已经使用geminstall安装了gem,如果我运行bundleinstall,它会使用之前使用geminstall安装的gem吗? 最佳答案 如果你想找出特定gem的存储位置,你可以运行bundleinfo.例如:user@host$bundleinforake/var/b

ruby-on-rails - God vs. Monit 用于过程监控

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭7年前。Improvethisquestion使用哪个进行过程监控?为什么?

ruby-on-rails - 使用 PostgreSQL 时角色不存在且无法创建数据库

我的应用程序使用Heroku,它需要PostgreSQL,但您仍然可以使用SQLite3进行开发。由于Heroku强烈建议不要使用2个不同的数据库,因此我决定改用PostgreSQL进行开发。我安装了gempg,还去了官方PostgreSQL站点获取Windows安装程序,还更改了我的database.yml。在安装过程中,它需要PostgreSQL的密码,所以我做了一个。我必须将pg_hba.conf文件从使用md5更改为trust才能通过:fe_sendauth:nopasswordsupplied尝试创建数据库时。#TYPEDATABASEUSERADDRESSMETHOD#IP

ruby-on-rails - 如何处理 Ruby on Rails 错误 : "Please install the postgresql adapter: ` gem install activerecord-postgresql-adapter'"

运行RubyonRails(RoR)应用程序或使用ActiveRecord框架的Ruby代码,您会收到错误消息:Pleaseinstallthepostgresqladapter:geminstallactiverecord-postgresql-adapter尝试运行:geminstallactiverecord-postgresql-adapter也失败了,让你不知所措。 最佳答案 问题不是任何人写的。问题是postgresql数据库适配器的名称是“postgresql”,而不是“postgres”,尽管GEM的名称是“pg”。

ruby-on-rails - 在 Ubuntu 上为 Ruby on Rails 安装 PostgreSQL

我目前在Ubuntu12.04中通过RVM安装了RubyonRails。默认数据库是在SQLite3中设置的,但为了推送到Heroku,我想切换到PostgreSQL。我怎样才能做到这一点? 最佳答案 以下是我遵循的步骤:安装PostgreSQL和开发包$sudoapt-getinstallpostgresql$sudoapt-getinstalllibpq-dev设置一个与我的Ubuntu登录相同的用户$sudosupostgres-cpsqlpostgres=#CREATEROLESUPERUSERLOGIN;postgres=