草庐IT

has_many

全部标签

mysql - 网站攻略 : A question about how many SQL queries are enough

我最近开始公开并慢慢推出一个自制的CMS。该站点允许进行大量自定义,并朝着国际化和自定义的方向发展,达到不需要源代码的水平。这是一个个人项目,整个目的是看看我能把自己的编程限制推到多远(处理博客、网络漫画和小型论坛的CMS的分发问题不是我愿意的)考虑一下,直到我清理它并对其进行更多的工作-同样,鉴于它是一个业余项目,我怀疑它与其他更精致的项目相比是否有任何引力......但这些不是关注的主题手头的话题。)我编写了一系列代码,可以查看每个页面的生成速度和运行的查询次数;平均而言,我看到每页执行9-13,最多12个MySQL查询。生成页面的平均时间在10-20毫秒之间。现在,在没有任何专业

MySQL CSV 导入 - 输入的日期为 0000-00-00 00 :00:00 if timestamp has milliseconds?

我目前有大量CSV文件要导入到MySQL数据库中。这些文件包含每条记录的时间戳,格式如下(例如):2011-10-1309:36:02.297000000我知道MySQL错误#8523,它表明不支持在日期时间字段中存储毫秒数。尽管如此,我还是希望日期时间字段在秒后截断记录,而不是输入为空白。我已经将问题缩小到毫秒(而不是csv等的格式),因为2011-10-1309:36:02正确导入。任何人都可以建议一种方法,让我可以在没有零的情况下导入这些数据吗?我有太多的CSV,无法手动进入每一个并调整时间戳的长度/格式。我应该指出,虽然毫秒是一个很好的选择,但它们对我的应用程序来说并不是必需的

java jdbc 设计模式 : handle many inserts

我想就我的问题寻求一些建议。我有一个批处理进行一些计算(多线程环境)并在表中进行一些插入。我想做一些类似批量插入的事情,这意味着一旦我得到一个查询,例如等待有1000个查询,然后执行批量插入(而不是一个一个地执行)。我想知道这是否有任何设计模式。我有一个解决方案,但它有点复杂:构建一个接收查询的方法将它们添加到列表(字符串和/或语句)直到列表有1000项才执行问题:我该如何处理结尾?我的意思是,最后999个查询,我什么时候执行它们,因为我永远不会达到1000个?我应该怎么办?我正在考虑一个线程,该线程每5分钟唤醒一次并检查列表中的项目数。如果他醒来两次并且次数相同,则执行已有的查询。有

mysql - 当通过关联在 has_many 上使用包含时,rails 4 保留连接对象顺序

使用Rails4.1.6和Ruby2.1.2并给出以下三个对象:classFilmCollectionhas_many:film_collection_films,->{order(:position)}has_many:films,through::film_collection_filmsendclassFilmCollectionFilmbelongs_to:film_collection_filmbelongs_to:filmendclassFilmhas_many:film_collection_filmsendFilmCollections是电影的集合,其成员通过连接对象F

php - 执行 mysqli_stmt->execute() 导致 "MySQL server has gone away"错误

好的。这是一个奇怪的。首先,这是错误:Fatalerror:Uncaughtmysqli_sql_exception:MySQLserverhasgoneawayindatabase.php:84Stacktrace:#0database.php(84):mysqli_stmt->execute()根据其他StackOverflow文章,例如this和this,那个错误,MySQLserverhasgoneaway意味着:mysqli对象在没有先关闭的情况下被重用(不,绝对不是)MySQL服务器端的连接超时变量太小最大数据包大小变量太小但是,我已将超时和最大数据包大小变量设置为其最大值

MySQL标记问题: how to select an item that has been tagged as X, Y和Z?

我正在处理一个数据库,其中的项目被“标记”了一定次数。项目(10万行)编号姓名其他内容标签(10k行)编号姓名item2tag(1,000,000行)item_idtag_id计数我正在寻找最快的解决方案:选择已标记为X、Y和Z的项目(其中X、Y和Z对应于(可能)标记名称)?这是我目前所拥有的......我只是想确保我以最好的方式做到这一点:首先从名字中获取tag_ids:SELECTtag.idWHEREnameIN("X","Y","Z");然后我按这些tag_id分组并使用Having来过滤结果:SELECTitem2tag.*,count(tag_id)FROMitem2tag

php time_sleep_until() 和 "Mysql server has gone away"

我有一个必须在每n分钟后执行的脚本。n分钟是动态的,因此我无法设置cron作业来调用脚本(在特定时间)。所以我所做的是将每隔n分钟后的时间存储在一个数组中,以便在执行脚本时,它会首先检查当前时间是否在数组中。如果在数组中找到,则继续执行,否则退出。要执行脚本,我必须使用cron作业每分钟运行一次以检查数组中的时间。不幸的是,我的虚拟主机只允许5分钟作为最短间隔。所以每次调用脚本时,我都会检查是否在数组中找到$current_time和$current_time+(4*60)//4minutes之间的值。如果是,并且如果需要,我会使用time_sleep_until来延迟脚本,直到时间达

mysql - ActiveRecord自定义has_many关联多次调用数据库

我有一对具有belongs_to...has_many关联的ActiveRecord对象,其中has_many关联是定制的。示例:第一个AR对象:classCar第二个AR对象:classRoundObject请注意,以上内容并不代表我的应用程序的功能,只是为了概述我的两个AR对象之间的关联。我遇到的问题是,当我重置缓存(因此我的Rails应用程序重新缓存数据库中的所有AR对象)时,RoundObject对象需要被重新缓存后,它会对数据库进行多次调用,一次调用与RoundObject集合关联的每个唯一vehicle_id。正在运行的SQL命令输出到控制台,所以这就是我的输出:Round

php - 设置 Yii MANY_MANY 关系

我正在尝试使用ActiveRecord在Yii中建立一个MANY_MANY关系。我有三个表简介配置文件_id简介_描述类别类别编号类别名称个人资料类别配置文件_id类别_id我的模型是Profile、Category和ProfileCategory。我正在尝试使用category_id运行查询,该查询将提取该类别中的所有配置文件。这是类别模型中的信息。publicfunctionrelations(){//NOTE:youmayneedtoadjusttherelationnameandtherelated//classnamefortherelationsautomaticallyg

MySQL 错误 2006 (HY000) 在第 406 行 : MySQL server has gone away - even after increasing dump file size setting

我正在尝试将数据库从服务器A移动到服务器B。我使用以下命令创建了一个mysql转储:mysqldump-uroot-p-c--add-drop-table--add-locks--quick--lock-tablesmydatabase>/var/log/mydatabaseJan31.sql然后在serverB上,我尝试通过执行以下操作来导入此数据:mysql-uroot-pmydatabase我几乎立即收到错误“第408行的错误2006(HY000):MySQL服务器已消失”。我已经阅读了关于相同错误消息的stackoverflow上的其他帖子,并且尝试了以下操作:修改my.cnf