MySQL 総合 Part24

このエントリーをはてなブックマークに追加
221NAME IS NULL
>>219
有難うございます、そこまでやって頂いて感謝です。
おっしゃる通り、どうやらデータ量(100万件ぐらい)が若干多いせいみたいでオプティマイザがインデックス使ってくれないみたいです。

色々試してみたのですが、下記の方法でインデックスを使ってくれるようになりました。

改善前 SELECT * FROM A JOIN B ON B.id = A.id WHERE B.column1 = CAST(RAND() AS CHAR) ORDER BY A.create_date;

改善後 SELECT * FROM A JOIN B ON B.id = A.id WHERE A.create_date < now() and B.column1 = CAST(RAND() AS CHAR) ORDER BY A.create_date;

思ったより面倒な対処しなくて済みそうで良かったです、有難うございます!

>>220
そうですね・・・ちとアホの子ですね・・・。小さい規模はPostgreSQLで、大規模はMySQLでってのが少しわかりました。
小さい規模はORMでSQL文気にしないでプログラムしても大抵インデックス使われるけど、MySQLはオプティマイザを考慮したSQL文書かないとダメだからちょっと工数かかる、その代りスケールしやすいって感じなんですかね。
222NAME IS NULL:2013/11/17(日) 17:55:23.84 ID:???
>>221
まず基本として
USE INDEXをつけてインデックスを使うものは
データやプランナの問題か、根本的に必要がない。
USE INDEXをつけてインデックスを使わないものは
DBの仕様の問題か、インデックスの貼りかたの問題

これPostgreSQLでも常識だろうが

で、USE INDEXをつけたときとつけないときの、応答速度はどうなんだい?

>>221
>小さい規模はPostgreSQLで、大規模はMySQL
それは気のせいだ
223NAME IS NULL:2013/11/17(日) 18:19:00.46 ID:???
>>222
USE INDEXをつけてインデックスが使われた場合は0.03秒、使われなかった場合は1.2秒といった結果でした。
PostgreSQLは適当にSQL文書いても、割とインデックス使ってくれます・・・。
224NAME IS NULL:2013/11/17(日) 19:23:22.79 ID:???
>>223
インデックスを使わないシークの数の上限設定ができたはず。
225NAME IS NULL:2013/11/17(日) 23:19:03.43 ID:???
>>224
有難うございます、調べてみます。
226NAME IS NULL:2013/11/18(月) 00:03:34.97 ID:???
PostgreSQLを触っててMySQL触りだすと
昔と違って今だと、シビアにチューニングできなければつらいだけ

ポテンシャルはMySQLのがまだ高いけど、大体はPostgreSQLに負ける
227NAME IS NULL:2013/11/18(月) 00:48:29.83 ID:???
でもなんとなくgoogleとかfacebookが使ってるMySQLを使ってしまう。
228NAME IS NULL:2013/11/18(月) 01:27:01.33 ID:???
そりゃシビアにチューニングできる会社だからな

同じく出来るなら使えばいいんじゃね

ホスティングとか自社サービスじゃない系はPostgreSQLかそれベースのものが増えてるからな
229NAME IS NULL:2013/11/18(月) 18:23:49.15 ID:???
大規模はMySQLて何を根拠にしてんだろ?
230NAME IS NULL:2013/11/18(月) 19:20:10.35 ID:???
google mysql やめるって
231NAME IS NULL:2013/11/18(月) 19:20:33.81 ID:???
MariaDBにするってだけでしょ?
232NAME IS NULL:2013/11/18(月) 22:11:09.31 ID:???
自力で実装しなきゃなんないシャーディンクを
標準機能とでも思ってるのでは
233NAME IS NULL:2013/11/18(月) 23:41:16.44 ID:WRQu7dQ3
というか、オラクルがスキあらば金取ろうとして超うざい。
わざわざ会社にまで電話かけてくんなマンカス>日本オラクルの馬鹿女
234NAME IS NULL:2013/11/19(火) 00:45:22.59 ID:???
>>222
> >>221
> >小さい規模はPostgreSQLで、大規模はMySQL
> それは気のせいだ
元ネタはこれだな。
http://www.slideshare.net/matsunobu/ss-28303485
235NAME IS NULL:2013/11/19(火) 08:40:09.04 ID:???
今となっての大きな違いはマルチスレッドかマルチコアかぐらいの違いぐらいか。
236NAME IS NULL:2013/11/19(火) 10:16:03.29 ID:???
クラスタリングに関してはMySQLだろう
大規模ってそういう事じゃないの?
237NAME IS NULL:2013/11/19(火) 10:45:52.58 ID:???
>>236
枯れきってるって意味ではな

サポート頼るならpostgresのがいい
238NAME IS NULL:2013/11/19(火) 13:08:48.11 ID:???
>>234
読んできた。結構知識が偏ってるようで

2004年で日本は既にMySQL > PostgreSQLだったような
今は逆に、世界の方がPostgreSQLの比率が多い
239NAME IS NULL:2013/11/19(火) 13:41:47.64 ID:???
postgresもamazon rdsでもサポート始まったしな
MySQLはオワコン
かといって素直にみんなMariaいくかと言えば
「まてよ」と一度考察が入るのでそうでもない。
オラクルのMySQLつぶしはほとんど成功だな
240NAME IS NULL:2013/11/19(火) 14:32:02.61 ID:???
>>239
FaceBookが利用してるやり方やDeNAがやってることとか考えると
MySQLじゃないとだめな用途はちゃんとある

PostgreSQLもビッグデータ系で多々使われるようになってるし
クラウドと実は相性が良いということもあるし

どっちもこれからまだまだいける
241NAME IS NULL:2013/11/19(火) 15:56:51.82 ID:???
>>240
>FaceBookが利用してるやり方やDeNAがやってることとか考えると
>MySQLじゃないとだめな用途はちゃんとある

例えばどんな? 否定でなく、単純に知りたい。

>>238
> 読んできた。結構知識が偏ってるようで


俺もそう思う。大規模の定義がFBとGoogle。この2社以外はコスト的にAWSに敵わないみたいに読める。
実際はそんな簡単じゃないんだけども。

データを自社に置くか置かないをコストだけで判断しない業種がたくさんあるわけだが、
そういう視点がすっぽり抜けてる。
242NAME IS NULL:2013/11/19(火) 16:12:06.41 ID:???
243NAME IS NULL:2013/11/19(火) 17:28:08.74 ID:???
>>242

いや、2010年ころの話をされても。。。。って思った訳っす。

上のスライドの趣旨としては、2000年−2005年くらいの状況として
大規模はMySQLを選んだみたいに言ってるようにみえるから。
244NAME IS NULL:2013/11/19(火) 17:38:27.38 ID:???
>>242

ついでにいうとFBやGoogleみたいに中身をぐちゃぐちゃに改造して
大規模対応って言われてもなぁみたいな。

中を改変しちまえば、そりゃなんでもできるじゃないという。


MySQLは大規模に向いているという理由が理解できない。
245NAME IS NULL:2013/11/19(火) 19:23:08.56 ID:???
スレッドベースだとなんでLLと相性いいの?
246NAME IS NULL:2013/11/19(火) 19:24:33.26 ID:???
>>243
どこにもそんな古い話ではかかれてないよ
今の話だよ
247NAME IS NULL:2013/11/19(火) 19:26:31.32 ID:???
>>244
それは作者に聞いてください

MySQLがPostgreSQLより大規模に向いてるとは僕は思ってない
248NAME IS NULL:2013/11/19(火) 19:34:05.44 ID:???
>>245

RDBMSのコネクションプーリングとかその辺の話 - wyukawa’s blog
http://d.hatena.ne.jp/wyukawa/20131116/1384621867
249NAME IS NULL:2013/11/19(火) 19:45:12.17 ID:???
>>241

知識は偏ってるね。
まぁ、元 MySQL のサポートエンジニアでその後は WEB系でしか働いてない人だししゃーないかな。

>> 俺もそう思う。大規模の定義がFBとGoogle。この2社以外はコスト的にAWSに敵わないみたいに読める。
>> 実際はそんな簡単じゃないんだけども。
>> データを自社に置くか置かないをコストだけで判断しない業種がたくさんあるわけだが、
>> そういう視点がすっぽり抜けてる。

俺もそう思うが、そういう人は相手にしてない資料なんじゃないかな。
正直、人事系とか外に出すなんてって思っちゃうけど、
今後 AWS 使うのは普通になる世の中が来るのかね。

昔は業務系、今は WEB系で働いてるが、WEB系に関しては、
よっぽどのことがない限りコストでは AWS の RDS のほうが有利だね。
細かなチューニングとか、トラブル時の調査とかしにくいけど、
チューニング出来る人雇うぐらいならスケールアップしたほうが安いっていう。
250NAME IS NULL:2013/11/19(火) 20:33:40.90 ID:???
>>248
一通り見た。
コネクションプールを使わない場合は
MySQLのがコネクションを貼るコストがスレッドだから安いから速いってことか

複数台構成の場合コネクションプール使うし
1台の場合貼りっぱなしで問題ないから理解が出来なかった
251NAME IS NULL:2013/11/19(火) 20:57:41.27 ID:???
>>249

コストの話も極論だよな。つうか、DBAなんてコスト部門でしかないわけでさ。
効率化すればするほど自分たちのクビを締めることになるんだよ。

だからMySQL使ってると、
バージョンアップ毎に膨大な作業が発生してDBAのクビが繋がる、
マッチポンプ ウマーって思うときもある。

>>250

そう。そのレベルでMySQL大規模有利っておかしい。
JAVAならプーリング使えばいいし、LLでもpgpool使えばよかったわけだし。
252NAME IS NULL:2013/11/19(火) 21:08:15.31 ID:???
>>249
> まぁ、元 MySQL のサポートエンジニアでその後は WEB系でしか働いてない人だししゃーないかな。


キャリア戦略で「ダメな技術は誰もダメといわない。自分で見分けろ。」って書いてるけど、
これってMySQLのことかと思ったw
253NAME IS NULL:2013/11/19(火) 22:40:00.85 ID:???
pgpool使っても接続数減るわけじゃないからな。
あれはポスグレへの接続コスト削減とロードバランシングか主なメリット。
それとも今のバージョンでは1コネクションで同時にクエリー発行できたりするの?
254NAME IS NULL:2013/11/19(火) 22:55:21.61 ID:???
よくわからんが接続コスト低けりゃそれでいいんじゃないの?
スライドの主張についての話なら。

接続数はMySQLもポスグレも変わらないだろ。カネ払ってスレッドプール入れるなら別だけど。

接続数が多い場合、昔はポスグレもMySQLも遅かったよ。
そんでポスグレのほうが並列実行性能がはやく向上した。
InnoDBはずっと遅いままだった。
255249:2013/11/20(水) 00:27:28.94 ID:???
昔に関して言えば、ポスグレはレプがなかったのと
VACUUMのせいで避けるようになってしまってたな。
レプがないのは、Web系では結構つらい印象(参照系がおおいので)

大規模、小規模関係なく、プール(≠永続化)しない場合は
スレッドベースである MySQL のほうが性能は稼げるかな。
プールをはさむと管理、トラブル対応めんどいとかもあるし。
256NAME IS NULL:2013/11/20(水) 00:36:15.63 ID:???
>>255
レプとVACUUMの問題が解決してから世界で一気に利用者増えたし
そういうことなんだろうな

台数が多いとプールはさんだ方が管理、トラブル対応は楽よ
257249:2013/11/20(水) 00:41:29.88 ID:???
>>251

> コストの話も極論だよな。つうか、DBAなんてコスト部門でしかないわけでさ。
> 効率化すればするほど自分たちのクビを締めることになるんだよ。

> だからMySQL使ってると、
> バージョンアップ毎に膨大な作業が発生してDBAのクビが繋がる、
> マッチポンプ ウマーって思うときもある

要は、AWS で RDS(マネージドDB)使うのが当たり前になると、
そういう仕事が少なくなるから、フルスタックエンジニアに成るか、
スペシャリストになって AWS では満足しないような大規模なところで
働くかしかなくなってくるよって書いてあるんだよね。

AWS(RDS) なんてって思うっちゃうけど、利便性とか対障害性とか
本当にローコストで使えてしまって、エンジニアとしてあれに対抗するの
きちいって最近いつも思ってる。
258NAME IS NULL:2013/11/20(水) 00:45:35.01 ID:???
.>>256
オラクルに問題があるだけじゃないの?
259249:2013/11/20(水) 00:51:08.95 ID:???
>>256

> レプとVACUUMの問題が解決してから世界で一気に利用者増えたし
> そういうことなんだろうな
多分最大の問題は Oracle だ。
あのニュースが流れた時、ポスグレに移行するかほんとうに悩んだ。

> 台数が多いとプールはさんだ方が管理、トラブル対応は楽よ
プールがある方が性能は上がると思うんだけど、
管理とかトラブルはどうなんだろ。
接続先を増やすときとか、アプリのコードだけじゃなくて、
プールの設定も追加しないとだめだよね?
別のものを挟むとやっぱり面倒くさくない?
260NAME IS NULL:2013/11/20(水) 00:58:44.65 ID:???
同時接続数を制御下におけるのはでかいと思うよ

基本アプリにはコネクションプールが接続先
なので、DB台数が増えたときはコネクションプールの設定だけ
261NAME IS NULL:2013/11/20(水) 01:23:35.52 ID:???
>>255
Linuxなら今やスレッド起動もプロセス起動もコストはほとんど変わりないけどね。
2000年頃は確かに違ったけど、2005年頃には(カーネルバージョン忘れたけど)
プロセス起動も軽快になったんだけどね。


レプリケーションは確かにWEB系では必須だわな。
ただし、非同期レプリケーションで参照分散つうのが大規模といわれてもなぁと思うわけだ。


>>257
>要は、AWS で RDS(マネージドDB)使うのが当たり前になると、
>そういう仕事が少なくなるから、フルスタックエンジニアに成るか、
>スペシャリストになって AWS では満足しないような大規模なところで
>働くかしかなくなってくるよって書いてあるんだよね。

それは一理あるんだけど、コスト+利便性でいえば集中型が最もよいけど
世の中、かならず集中と分散を繰り返すじゃない?RDSの先に何がくるか考えてるよ、俺。


スライド書いた人、ソニー、MySQL、DeNA、顔本らしいね。いく先々クラッシュしてるのが面白いと思った。
そういう価値観で会社選んで、キャリア戦略なんつうスライド書いたんだなって。
262NAME IS NULL:2013/11/20(水) 04:44:14.06 ID:???
ポスグレはDBの機能として、
ファイルシステムレベルでオンラインバックアップの取得が可能
レプリカも全く止めずに作成可能

これがいい
263NAME IS NULL:2013/11/20(水) 09:26:41.73 ID:Md8IW4i/
http://postgresql.g.hatena.ne.jp/pgsql/20100704

nippondanjinippondanji2010/08/06 14:44
MySQLをよく知る者です。少し補足を入れさせてください。少し誤解があるようなので。
初回コピー時ですが、これは特に更新を停止せずに行うことが可能です。(ただしInnoDB利用時に限りますが、InnoDBがほぼ標準なので問題ないと思います。)まず第一の方法は、ZFSやLVMなどのスナップショットを利用する方法です。

nippondanjinippondanji2010/08/09 00:28
こんばんは。

> FLUSH TABLES WITH READ LOCK は一瞬では終わらないでしょうから、問題になるケースもあるのではないでしょうか? PGのオンライン・バックアップは、一瞬たりともロックを必要としません。

そういうニーズがある場合、MySQLではファイルシステムやストレージ側のスナップショットを使うことが多いですね。MySQL Enterprise Backup(旧名InnoDB Hot Backup)などを利用してもロック不要のオンラインバックアップが可能です。

結構、MySQLではオンラインバックアップ出来ないということをおっしゃる方が多いのですが、実際出来ますから、あんまり「出来ない出来ない」とは言わないで欲しいです。


と、自称ギークは言っておりますがw
264NAME IS NULL:2013/11/20(水) 13:26:25.30 ID:???
何で急にストレージ側の機能が出てくるんだ。

要するに出来ないんだろ。
こいつの突っかかり方キモイな。
265NAME IS NULL:2013/11/20(水) 13:54:35.08 ID:???
TechCrunchにこんな事書かれちゃうのは仕方ないよね
> PostgreSQLは、OracleがSun Microsystemsを買収してMySQLを手中にして以降、人気が増大している。
> OracleはMySQLのオープンソースな側面に関心を示さなくなったため、メンテ放棄を恐れたユーザはPostgreSQLへの引越しを開始したのだ。

これから日本は>>234に書いてあるような日本市場の特殊性が起きるわけだ
266NAME IS NULL:2013/11/20(水) 14:23:40.46 ID:???
>>264
>こいつの突っかかり方キモイな

こいつだなんて、自称ギーグの日本男児様をしらないのかw
日本男児様のブログさえ読んでればトランザクションも知らないWEB野郎たちは幸せに暮らせるんだ。
なにせ日本男児様はMySQLを完全無欠にみせてくれるからw
267NAME IS NULL:2013/11/20(水) 20:29:36.32 ID:???
postgresにhandlersocket的なものがあれば移るわ。
268NAME IS NULL:2013/11/20(水) 20:36:43.67 ID:???
>>267
FDWのエクステンションつくればいいんでね?
269NAME IS NULL:2013/11/20(水) 21:29:52.99 ID:kMGPfKTL
mysqlってwindowで使用するよりlinuxで使われること多いのか?
270NAME IS NULL:2013/11/20(水) 21:52:33.24 ID:???
windowsで使われることが多いRDBMSなんてAccessとSQL Serverくらいだから
271NAME IS NULL:2013/11/20(水) 23:05:59.44 ID:???
>>269

LAMP

俺はWin+MySQL+Excelですけどw
272NAME IS NULL:2013/11/21(木) 00:35:20.21 ID:???
>>265

> これから日本は>>234に書いてあるような日本市場の特殊性が起きるわけだ


どうだろうねえ。
新規プロダクトはポスグレも増えるだろうけど、
すでにMySQL方言でガチガチにつくりこんだプロダクトはマリア一択だね。

オープンソースのデファクトプロダクトの多くはMySQL依存が強烈だから。
273NAME IS NULL:2013/11/21(木) 00:40:25.85 ID:???
逆だろ、世界はpostgresにいくのに日本はmysqlのままってことよ
274NAME IS NULL:2013/11/21(木) 00:48:56.07 ID:???
mariaってinnodb使えなくて大丈夫なの?
275NAME IS NULL:2013/11/21(木) 08:34:09.35 ID:???
>>273

いやいや、世界がポスグレに流れるのかって。

もともとビジネスユースはOracle->ポスグレの流れはあった。ビジネスユースでMySQLなんて使いものにならないじゃない。
まともにジョインもできない、コロコロ仕様がかわるし。

WEB系はMySQLが強くて、オープンソースのプロダクトもMySQL依存が強い。
MySQL独自SQLを使いまくってるプロダクトが多いから、いまさらポスグレに移植できないものも多いのが実情。

どのプロダクトだってのは書かないけど、かなり多いよ。
移植が失敗したプロダクトもいくつか知ってる。どれもその分野のデファクトでポスグレ未対応。
DB詳しくない人たちが開発するから、MySQL独自機能をつかいまくって移植不可能なくらい
複雑なコードになってたり、
「PHPのDBO使ってるから移植できるっしょ」くらい軽いノリの開発者ばかりなんで
移植の問題自体を認識されてないとか。

DB屋とアプリ屋の溝はとても深いよ。
276NAME IS NULL:2013/11/21(木) 08:39:57.24 ID:???
>>274
> mariaってinnodb使えなくて大丈夫なの?

MariaDBはInnoDBバンドルされてるよ。
InnoDBは一応オープンソースだし、Oracleが改造した機能をMariaDBも独自に取り込んでる。
それとInnoDB互換のXtraDBもバンドルされてるし。
277NAME IS NULL:2013/11/21(木) 09:07:16.26 ID:???
Oracleに潰された
278NAME IS NULL:2013/11/21(木) 09:13:47.33 ID:???
>>276
それでライセンスとかオラクルの存在とか大丈夫なの?

mysqlから世界が逃げ出したのって、INNODBが買収されたとき始まったんよね
279NAME IS NULL:2013/11/21(木) 09:24:01.84 ID:???
xtradb作ったのは別の会社なんだよな。
使ってみたいけどサーバースペックある程度無いとinnodbと性能変わらないんだっけ?
280NAME IS NULL:2013/11/21(木) 09:42:34.94 ID:???
>>279

性能がどういういう奴にかぎって、ろくでもない馬鹿SQL走らせてるよなあ。
ベンチマークばっかやってる奴とか。
281NAME IS NULL:2013/11/21(木) 09:44:57.27 ID:???
>>278

だからオープンソースっていってるじゃん。
マリアだってMySQLのフォークなんだし。
自分たちでなんとかするのがオープンソース。
282NAME IS NULL:2013/11/21(木) 09:47:37.57 ID:???
>>281
ライセンスやオラクルに対する見方が違うのがよくわかった
283NAME IS NULL:2013/11/21(木) 11:36:23.02 ID:???
>>276 XtraDBはGPLv2下のInnoDBをフォークして魔改造 したもので、ライセンスは勿論GPLv2。
開発元はPercona。 5.5のXtraDBはMySQL 5.5から、5.6のXtraDBは MySQL 5.6からブランチしなおしてるから、
Oracle がMySQL潰したら多分進化は止まる。
進化は止ま るけど既存のフォークはGPLのまま影響を受けない ので、今あるところまでは問題なくXtraDB使える (これはInnoDBも一緒だが)

http://www.percona.com/software/percona-xtradb

XtraDBとInnoDBは共存できない。XtraDBが入って る環境でCREATE TABLE .. Engine= InnoDBってやる とXtraDBが使われる。 例外的に10.0.3〜10.0.5くらいではInnoDBが入って いたけど、MariaDBでは5.3以来ずっとXtraDB。
284NAME IS NULL:2013/11/22(金) 16:14:50.55 ID:???
>>283

maria5.5.32にstorage/innobaseとstorage/xtradbがあるんだけど、
それでもCREATE TABLE .. Engine=InnoDBってやるとXtraDBになるの?
だとすると、なんでソースがバンドルされてんだろ。
285NAME IS NULL:2013/11/22(金) 22:05:01.99 ID:???
>>284
なんでか知らないけど昔から両方ある。
Percona ServerのXtraDBはstorage/innobaseの下にしかないんだけどね。

SHOW ENGINESをよく見ると、InnoDBの説明にXtraDBって書いてあって、どっちやねんてかんじだけど。
286NAME IS NULL:2013/11/23(土) 07:16:12.52 ID:qVAyetp/
mysqlを勉強してる
タブレットにインストールすることは
可能?
まったく的外れだったら申し訳ない
287NAME IS NULL:2013/11/23(土) 07:19:10.96 ID:???
タブレットにもいろいろあってだな・・・
288NAME IS NULL:2013/11/23(土) 07:38:07.05 ID:???
windowsのタブレットなら出来るんじゃない
windows8がそのまま入ってるんでしょ?あれ
タブレットに入れる意味はないと思うけどな
289NAME IS NULL:2013/11/23(土) 08:55:54.32 ID:qVAyetp/
286
プラットホームを書き忘れてました
Android4.2.2 Snapdragon
タブです
Windowsタブだったら問題なかったんですが
いかんせんandroidなんで、
外出先での勉強用としてと思ってます
NotePC持ってるんですが
タブレットの軽さに慣れてしまって。
290NAME IS NULL:2013/11/23(土) 09:06:30.04 ID:???
ネットにつながるならVPSなりを借りて使うのが無難
どう入れるのか知らんがarmでもmysqlは動くようなので入れようと思えば入れらるんじゃないか
足りないパッケージは多そうだけど
291NAME IS NULL:2013/11/23(土) 09:47:49.05 ID:???
sqliteの勉強だったら出来るけどな
android標準dbだし
292NAME IS NULL:2013/11/23(土) 10:10:20.34 ID:???
>>289
Androidスマホだけど、Bit Web Serverってのを使ってる。200円くらいだったはず。
293NAME IS NULL:2013/11/26(火) 15:31:50.01 ID:???
こっちで聞けと言われたので質問させてください
mysql5系の質問です
DBを作る時の「MyISAM」と「InnoDB」の違いがよくわかりません。
ゴミでもわかりやすいように教えて頂けないでしょうか?
294NAME IS NULL:2013/11/26(火) 15:40:14.37 ID:???
>>293ですが解決しました
295NAME IS NULL:2013/11/27(水) 00:12:05.36 ID:???
  _, ._
( ゚ Д゚)
( つ旦O
と_)_)
  _, ._
( ゚ Д゚)   ガシャ
( つ O. __
と_)_) (__()、;.o:。
          ゚*・:.。
296NAME IS NULL:2013/11/27(水) 00:24:56.63 ID:???
以上ゴミがお伝えしました
297NAME IS NULL:2013/11/29(金) 19:14:57.94 ID:ld8Q8jAS
mixiやfaceookみたいなsnsのサイトにMemberテーブルがあって、Memberテーブルの各情報に対して個別に全体公開をかけるとき
その情報と対となる公開設定列が必要になるのでしょうか?

名前
年齢
住所
プロフィール
出身校

という情報があって個別に全体に公開するか設定できるとき


name
name_is_public
age
age_is_public
address
address_is_public
profile
profile_is_public
graduate
graduate_is_public


みたいな風に列を作らないといけませんか・・・?
298NAME IS NULL:2013/11/29(金) 20:22:04.33 ID:???
しないといけないってことはないけど、それでも実装はできるんじゃない?
逆に値の列だけでどうにかしようとすると、先頭に"!!"をつけているものは非公開と判定するとか
ユーザーが入力したものかどうかを確実に判断できるように実装しないとバグるけど
299NAME IS NULL:2013/11/29(金) 20:31:49.84 ID:???
作らないといけないっていうか、普通そう作るよね
何が嫌なんだ?
300NAME IS NULL:2013/11/29(金) 20:33:23.34 ID:???
それか公開情報カラムを1つで作ることも出来るけどね
そのカラムの数字が
2の倍数なら名前公開
3の倍数なら年齢公開
5の倍数なら住所公開
7の倍数ならプロフィール公開
11の倍数なら出身校公開
みたいに
いや、普通はやらんが
301NAME IS NULL:2013/11/29(金) 20:48:03.33 ID:ld8Q8jAS
>>298-300
普通はこうするんですね
列の数が増えてしまうのが嫌だったのですが正攻法なのであればこれでいきます
302NAME IS NULL:2013/11/29(金) 23:33:23.20 ID:???
>>301
あんまりお勧めしないけど、どうしても嫌なら公開情報テーブルを別に作る

ユーザーID
該当テーブル名
公表フラグ

あとは公表フラグを元にプログラムで判定させる。
もしくはmemberテーブル自体を、

ユーザーID
該当項目(該当テーブル名)

公表フラグ

にしてしまう。これなら横に追加しなくても良い。
303NAME IS NULL:2013/11/30(土) 20:53:53.22 ID:???
MySQLのスレでポスグレでもオラクルでもできるテーブル設計の話
ドヤ顔で始めるチンカスってなんなの?
304NAME IS NULL:2013/12/01(日) 14:48:22.43 ID:u1FkK0X5
305NAME IS NULL:2013/12/01(日) 15:51:04.11 ID:???
>>304
ggrks
306NAME IS NULL:2013/12/01(日) 20:46:29.75 ID:???
答えは
1:g, 2:g, 3:r, 4:k, 5:s
ですね!ありがとうございます!
307NAME IS NULL:2013/12/01(日) 21:00:32.43 ID:???
wwww
308NAME IS NULL:2013/12/01(日) 21:34:18.67 ID:???
>>304
もうちょっと画質が良いのないの?
309NAME IS NULL:2013/12/01(日) 23:21:39.96 ID:???
まるち、ていわないんだ
310NAME IS NULL:2013/12/09(月) 17:10:32.62 ID:KDrt2ZmL
予約語を避けるにはどうしたらいいかな
適当な接頭語をつけるのが一番楽かな
311NAME IS NULL:2013/12/13(金) 15:44:13.33 ID:UakRrOee
312NAME IS NULL:2013/12/13(金) 16:51:05.75 ID:???
本気環境で使うのにRedhat標準のものをずっと使い続けることがありえない。
特にMariaの方はVersionUpも頻繁に行われるだろうし。
313NAME IS NULL:2013/12/13(金) 17:13:52.04 ID:???
RHELにはいったのはMariaDB5.5。安定版だよ。
それにディストリ固有のパッケージ使いたい人たちが多数。
普通はパッケージ管理なんてやりたくないんだよ。


そもそもMySQLのバージョンアップのほうがキツいだろ。
ボロボロの状態でGAリリース、何年たっても不安定。
314NAME IS NULL:2013/12/13(金) 17:18:31.08 ID:???
この人たち、裏で必死に転職活動してそうだわ

https://twitter.com/RKajiyama/status/387821488759250944
315NAME IS NULL:2013/12/13(金) 20:39:35.32 ID:???
>>313
出たばっかの頃はいいが、そっから3年くらいはずっとそのままのバージョンで行くんだぜ。。。
そなるといずれは自分で入れることになるんだから。
316NAME IS NULL:2013/12/13(金) 22:59:32.28 ID:???
>>315

>そなるといずれは自分で入れることになるんだから。

MariaDBをだろ
だからMySQL終了だっつうのw

>出たばっかの頃はいいが、そっから3年くらいはずっとそのままのバージョンで行くんだぜ。。。

まじめな話、Maria10.0なんてまだαだし、5.5で数年行くのは正しいだろ。
Maria5.5とMySQL5.5はほとんど同じだし。

RHELなど主要ディストリビューションがMySQLからMaria5.5から切り替えたのはデカイよ。
よほどの物好きか、最新版大好きの素人しかMySQL5.6に移行しないだろう。
317NAME IS NULL:2013/12/13(金) 23:56:53.11 ID:???
もうずいぶん前から予想できたことだろ
このスレでも何回もMySQLはオワコン、Oracle完全犯罪的な話出てきたろ
既定路線
318NAME IS NULL:2013/12/14(土) 13:06:29.41 ID:???
インデックス張ってももう無理だ
レコードが7億いった・・・
319NAME IS NULL:2013/12/14(土) 14:58:58.68 ID:???
すっごw
320249:2013/12/14(土) 15:52:25.95 ID:???
>>318
十分なメモリと、最適なインデックスの追加、利用さえしておけば、
レコード数だけが問題になることはない気がするが...
(1レコードのサイズが大きいテーブルのレコード数が増えるのは問題
メモリが足りないんだったら、SSD にするかメモリつむ以外ないんじゃないかな。

経験上は下手なインデックスの利用、下手なテーブル定義が問題となることが多い。
メモリ 72G で 20億レコード、インデックス含めて64Gのテーブルとか運用してるけど
レコード数がどうこうより、データサイズどうにかしたい。
321NAME IS NULL:2013/12/15(日) 11:14:44.47 ID:???
7億レコードなんて別に大したことじゃ無いと思うが。
インデックスがメモリに乗らなくなったって言いたいんだろうけど。
322NAME IS NULL:2013/12/15(日) 11:50:57.01 ID:???
日本レコード大賞
323NAME IS NULL:2013/12/17(火) 16:35:22.30 ID:???
一度にひとつのキーでしか検索しない設計なんですが
どのキーで検索するかは状況によってバラバラです

検索に使われる予定のキーに かたっぱしからインデックスを
張っといた方がいいですかね?
324NAME IS NULL:2013/12/17(火) 17:04:56.45 ID:???
>>323
実測しろ
325NAME IS NULL:2013/12/17(火) 18:32:42.40 ID:???
>>324
そりゃするけどさ、念のために聞いておきたかっただけじゃん?


あと、これも実測しろと言われるの間違いなしなんだけど、
結果がひとつだけだと確信できるクエリのときも、あえて
LIMIT 1をつけたほうが速いのかな。 速そうな印象はある
326NAME IS NULL:2013/12/17(火) 20:31:46.85 ID:???
テーブルスキャンのときは LIMIT 1 で早くなるはず
327NAME IS NULL:2013/12/17(火) 22:44:58.13 ID:???
>>318
四の五の言わずにioDrive入れちまえ。あのコスパの良さは明らかに異常。
328NAME IS NULL:2013/12/23(月) 22:10:41.65 ID:???
インストールするときにChoosing a Setup Typeのとこで
Developper Default, Server only, Client only, Full, Customから選びますがどのような違いがあるのでしょうか?
329NAME IS NULL:2013/12/24(火) 21:55:49.74 ID:???
その質問をする人は、Defaultで問題ない
簡単に言うとインストールされるファイルの組み合わせを選ぶ
具体的な違いを教えろって?ggr
330NAME IS NULL:2013/12/25(水) 22:40:19.62 ID:???
試しにインストールしてみたのですが、Developper DefaultとFullは同じな気がします。
331NAME IS NULL:2013/12/27(金) 11:01:17.77 ID:RABYehPe
InnoDB三ヶ月に1回ぶっ壊れるようにわざとしてるだろ?
不満なら有料のもの買えってことか。
タダより高いものはないな。
332NAME IS NULL:2013/12/27(金) 12:39:19.36 ID:???
壊れねぇよ
どういう使い方してんだ
333NAME IS NULL:2013/12/27(金) 15:24:27.52 ID:9aKIae9M
練習用としてXAMPPを使用しています
バックアップとして
mysqldumpを使います
mysql>mysqldump -u root -p9999 c_9>c_9dump.sqlで
あってるのでしょうか。
mysql>(コマンドプロンプロが間違ってる?)
334NAME IS NULL:2013/12/27(金) 19:03:50.29 ID:???
--password=9999
335NAME IS NULL:2013/12/28(土) 18:29:01.47 ID:ZNxoVZ7w
WIN7のこまんどぷろんぷとから実行したいのですがstartしてるのを確認してmysql -u root -pを実行しても
バッチファイルとして認識してませんで出来ないです 助けて
336NAME IS NULL:2013/12/28(土) 18:43:08.57 ID:ZNxoVZ7w
自己解決
環境変数だった
337NAME IS NULL:2014/01/10(金) 11:05:07.42 ID:oqp795AA
在日の親は、子供を朝鮮幼稚園・朝鮮学校に入れたいっていうのが多いのよ。
日本人からすると、なんでだろうって思うけど、日本人の学校では、民族の誇りを持った教育がしてもらえないんだそうだ。
よく分からないけど、流刑者の白丁が密入国して住み着いたじゃ誇りが持てないけど、日本人に強制連行された被害者なら誇りが持てる、とかそういう事かな??

市原市の能満は昔から市街化調整区域で、新規の建物は造れないことになっている。
そのため土地が安く、日本の法律を無視した在日が、次々と移り住んできた。
そこで問題になったのが、朝鮮学校だ。なかなか許可が下りず、一番近くても千葉市にしかない。
そこで在日居住区の能満内にあった、能満幼稚園・市原小・市原中・緑高の保育士や教師を、朝鮮化する事を考えた。
今では通称在日幼稚園の保育士は全て朝鮮帰化人で、在日の父兄からの絶大な支持を受けている。
遠くからでも、わざわざ通称在日幼稚園に入園させたいという在日の親は、後を絶たない。
この在日幼稚園卒園者はほぼ朝鮮系の帰化人と在日で、現在各所でクレーマーとなり問題を起こしている。
338NAME IS NULL:2014/01/13(月) 11:07:38.33 ID:JNIvUl1u
MySQL5.5でInnoDBでロックのためにSELECT FOR UPDATEを使ってるんだけど
運用したら、ユーザー2名に同時に参照される不具合が起きてしまった
ユーザーAのトランザクション中は、ユーザーBはその行を読み出せないと思ってたけど違うの?
339NAME IS NULL:2014/01/13(月) 12:32:29.31 ID:???
>>338
〜〜 FOR UPDATE で排他ロックをかけてるときは、理解の通りロックかけたトランザクションが
コミットかロールバックするまで、ほかのトランザクションはいかなるアクセスもできないはず。
340NAME IS NULL:2014/01/13(月) 16:12:42.90 ID:???
読みだしはできる
341NAME IS NULL:2014/01/13(月) 16:15:38.53 ID:JNIvUl1u
>>339-340
どっちが本当?
342NAME IS NULL:2014/01/13(月) 16:24:09.24 ID:???
ユーザーBのSQL次第
343NAME IS NULL:2014/01/13(月) 16:31:32.26 ID:JNIvUl1u
なるほど、やることはAB両方共同じで

トランザクション開始
SELECT FOR UPDATEでレコード取得
有効レコードなら無効(売約済み)にUPDATE
トランザクションコミット

というコードになっています。
ところがAB共同じレコードを取得してしまった、という問題です。
この場合どこがおかしいのか、悩んでしまって…。
344NAME IS NULL:2014/01/13(月) 17:27:20.43 ID:???
両方 UPDATE 付いてたら待たされるはず。
ロックかかってるとSELECT失敗するわけじゃなくて、終わるまで待つだけよ?

試しに手入力でやってみては
345NAME IS NULL:2014/01/13(月) 17:42:32.66 ID:JNIvUl1u
2窓で手でbegin; select xxxx for update; update xxxx とかやってみたら、
ちゃんと後からのselectは待たされ、updateした方がcommitしたらupdate後の値が取得された。
これなら想定通りなんだが、なぜか運用すると両方共update前の値を取得したような動きをする。
CakePHP通してSQLを発行しているので、そこが何か悪さしてるのかな。だとしたら調査に時間がかかりそうだ。
346NAME IS NULL:2014/01/13(月) 18:44:14.12 ID:???
>>345
実はSQLでデータ取っていなくて、サーバのキャッシュを取得していたとかいうオチでは?
347NAME IS NULL:2014/01/13(月) 19:10:51.42 ID:JNIvUl1u
>>346
CakeのSQL発行関数にcache=falseの指定はしているんだが
そのくらいしか考えられないな…もう一度確認してみますわ
348NAME IS NULL:2014/01/13(月) 19:22:08.42 ID:???
クエリーログ取るんじゃダメ?
349NAME IS NULL:2014/01/13(月) 19:31:35.69 ID:JNIvUl1u
うーん、何度見てもキャッシュはしっかりfalse指定されてた
実は滅多に再現しないから、ログ取るようにして気長に再発を待つしかないかな
350NAME IS NULL:2014/01/14(火) 10:41:08.32 ID:???
どこかに FOR UPDATE 抜けたやつが紛れ込んでるな
351NAME IS NULL:2014/01/14(火) 12:19:47.09 ID:5XYg85D5
それがなさそうなんだよねえ…。コード中1個所しかないし。
引き続き調べ中ですが、再現が難しい感じです。
352NAME IS NULL:2014/01/14(火) 12:52:58.14 ID:???
データベースサーバは1台だよな
353NAME IS NULL:2014/01/14(火) 16:19:13.50 ID:k7q4QSRl
トランザクションレベルはどうなってんすか?
354NAME IS NULL:2014/01/14(火) 16:26:11.87 ID:???
実はInnoDBじゃない
分離モードがREAD UNCOMITTED
FOR UPDATEついてないSQLで取得したデータ見てる
355NAME IS NULL:2014/01/14(火) 17:09:48.23 ID:???
横やり失礼。
先発のトランザクションが SELECT ~ FOR UPDATE している間、
後発のトランザクションの読み込みを待たせたい場合は、
後発のクエリに「LOCK IN SHARE MODE」をつければOKって認識であってますか?
356NAME IS NULL:2014/01/14(火) 17:11:53.87 ID:5XYg85D5
DBはマスターとスレーブの2台。今回の処理はすべてマスターに対して行っている。
テーブルは全てInnoDB。
分離モードはREPEATABLE-READ。
FOR UPDATEついてないSQLが万が一にも発行されていないか調べているが、アクセスするコードは1ヵ所しかないので考えにくい。
てな状況です。
ありがとうございます。
357NAME IS NULL:2014/01/14(火) 17:47:19.60 ID:???
>>356
SQL文のログは取って調べたのかな?
アプリ側のコードとにらめっこしていてもしょうがないよ。

[mysqld]
log=ログファイル
358NAME IS NULL:2014/01/15(水) 15:57:16.22 ID:???
MySQLユーザ会 MariaDB分科会だってさ
ttp://www.mysql.gr.jp/mysqlml/mysql/msg/16045

MySQLユーザ会って何もしない利権狙いの親父集団だろ
MariaDBの利権にも唾つけようと必死だな

tutuiって2009年にも利権確保に動いて止めたけど
ttp://tutui.net/
また盛り上がってきたら動くようだ
359NAME IS NULL:2014/01/17(金) 07:45:07.07 ID:SEZl444W
[mysql5 apache cakephp2]
バッチ処理中にテーブルロックをかけており、
バッチ処理中はクライアントからのselectをエラーとして返したいです。

こちらで試したものは、
innodb_lock_wait_timeoutを設定し、selectをタイムアウトさせる
というものでしたが
タイムアウトしませんでした。
(詳細)
バッチ処理側でlock writeをしているので、
クライアント側からselectするとタイムアウトすると思われたのですが、
タイムアウトすることなく、ずっとクエリ結果を待っている。
さらに、クライアント側が結果を待っている間に、
バッチ処理側でunlockをすると、
クライアント側にphp実行時間オーバーというエラーが表示されます。

どのようにすればタイムアウト(もしくはテーブルロックを検知)できるのでしょうか?
360NAME IS NULL:2014/01/17(金) 12:50:09.28 ID:???
>>359
お、まさにそれをやりたいと思ってた。
できないんでしょうか。

ttp://dev.mysql.com/doc/refman/5.1/ja/innodb-parameters.html#optvar_innodb_lock_wait_timeout
ttp://blog.kimuradb.com/?eid=877250
> これまではグローバルで全体の指定を変えなければならなかった処理がセッションで、その接続だけ変更できるようになり、かなり敷居が下がりしました。
361NAME IS NULL:2014/01/19(日) 00:58:19.88 ID:???
http://dev.mysql.com/doc/refman/5.1/en/innodb-parameters.html#sysvar_innodb_lock_wait_timeout
> innodb_lock_wait_timeout applies to InnoDB row locks only. A MySQL table lock does not happen inside InnoDB and this timeout does not apply to waits for table locks.
テーブルロックだと、この機能効かないってよ
362NAME IS NULL:2014/01/19(日) 01:14:34.95 ID:???
http://dev.mysql.com/doc/refman/5.5/en/server-system-variables.html#sysvar_lock_wait_timeout
5.5.3以降なら、@@lock_wait_timeoutで期待した動作を実現できそうだな
363NAME IS NULL:2014/01/19(日) 12:16:32.40 ID:hD4Sosha
>>362
5.5.2やったわ。
試してみます。ありがとう!
364NAME IS NULL:2014/01/19(日) 20:10:06.21 ID:yCiVwpc9
Linuxに入ってるMySQLを外部PCからリモートで操作して
ユーザ作成する場合、ホスト名はLinuxのホスト名で大丈夫ですか?
365NAME IS NULL:2014/01/19(日) 22:08:43.58 ID:???
>>364
そのLinuxのプログラムでデータを取り扱うのならlocalhostでいいんじゃね。
366NAME IS NULL:2014/01/20(月) 21:00:44.21 ID:???
>>364
それMySQLの話ちゃうやろと思いつつ、 hostsとかその手のファイル、DNS次第。
367NAME IS NULL:2014/01/22(水) 00:22:45.75 ID:???
MySQLチームで募集中のプリセールスエンジニアは技術が重視されるので営業関連の経験は無くてもかまいません。ご興味のある方はDM下さい。 #mysql_jp

We Are Hiring!! 業務急拡大中につきMySQLチームでは日本でプリセールスエンジニアを募集しています。
ttps
t.co / xUXSf2pO3C

お前らの出番だぞw
368NAME IS NULL:2014/01/22(水) 00:42:08.85 ID:???
転職めんどい
369NAME IS NULL:2014/01/23(木) 02:48:16.58 ID:???
業務拡大じゃなくて
人が逃げたから集めるようにみえて仕方がない
370NAME IS NULL:2014/01/25(土) 01:36:12.00 ID:???
Oracleの奴隷(プゲラ
371NAME IS NULL:2014/01/27(月) 18:36:42.89 ID:???
あるテーブルの主キーになってるserial型columnを他のテーブルで外部キーに指定しようとしてもできません。助けてください。
372NAME IS NULL:2014/01/29(水) 20:58:51.13 ID:???
そんなはずがない
373NAME IS NULL:2014/01/29(水) 22:50:36.43 ID:???
「他のテーブル」でインデックスも何も張ってないとかいうオチでは?
374371:2014/01/30(木) 23:41:25.25 ID:???
たぶん>>373これでした。ありがとうございましたm(_ _ )m
375NAME IS NULL:2014/01/30(木) 23:46:46.92 ID:???
たぶん ってw
376NAME IS NULL:2014/01/30(木) 23:48:02.54 ID:???
おいおい大丈夫かよ・・・本職じゃないよな
377NAME IS NULL:2014/02/06(木) 21:01:38.51 ID:???
5.6で高スペックサーバでの性能が飛躍的に向上したな
PostgreSQL抜き返したかな?
378NAME IS NULL:2014/02/08(土) 17:53:27.37 ID:???
innodbにphpmyadminで33000件のデータをインポートしたのですが、なせか表示は31000件です。移動ボタンで最後のページまで飛ぶと33000件目を含むデータが表示されます。これは仕様なのでしょうか?それともどこかを修正すれば表示を改善出来ますか?
379NAME IS NULL:2014/02/08(土) 18:49:02.64 ID:???
>>378
今DBに登録されてるデータをinto outfile してインポートしたデータと比べてみてはどうでしょう。
380NAME IS NULL:2014/02/08(土) 19:41:33.12 ID:???
dbに 「33000件のデータをインポートし」てselect count(*)で33000件って出たらmysql側には問題なし
php側の方がおかしいんでしょ
381NAME IS NULL:2014/02/09(日) 18:26:20.52 ID:???
phpがおかしい
382NAME IS NULL:2014/02/10(月) 00:52:28.74 ID:???
>>378
phpMyAdmin で表示されるレコード数は、INFORMATION_SCHEMA というメタデータから引っ張ってきてるのですが、
InnoDB では概算値となるため、実際のレコード数と phpMyAdmin 上で表示させる値に誤差が生じます。
正確なレコード数を取得するには SELECT COUNT(1) FROM **** クエリを発行してください。
383NAME IS NULL:2014/02/10(月) 11:31:04.11 ID:???
>>378 です。
皆さんありごとうこざいます。
innodbの仕様だったんですね。
安心しました。
384NAME IS NULL:2014/02/12(水) 19:53:59.77 ID:???
はじめまして、相談です。

現在140万行あるテーブルに対して、以下のようなSQLを発行しています。
SELECT word , x,y, last FROM table_test where first != 1 and prev1 = '予測' and prev2 = 'は' and prev3 = 'に' ORDER BY RAND() LIMIT 1
こちらがテーブルです。
http://www.dotup.org/uploda/www.dotup.org4869247.png
(現時点で厳しい物があるため、わざと使用していないカラムがいくつかあります)

SQL一回の結果が返ってくるまでに1.8秒ほど、大体10〜20処理するので、1分前後かかっています。またこの先テーブルはますます大きくなります。
インデックスを貼って見ましたが、あまり早くなりません。これぐらいが普通なのでしょうか。
また、他に少しでも早くする方法はありますか?

このテーブルの用途は、趣味で作っている人工無能です。
385NAME IS NULL:2014/02/12(水) 21:03:54.10 ID:???
>>384
インデックスは、first, prev1, prev2, prev3 の複合インデックス張ってる?

いまの主キー、インデックスも教えてくれないとわからん。
あと1万行くらいのダンプデータがあると検証ができてなおよし。
386384:2014/02/12(水) 21:48:45.80 ID:RkkOXYbS
>>384です。環境を忘れていました。
xamppです。
Apache/2.4.3 (Win32) OpenSSL/1.0.1c PHP/5.4.7
Client API version mysqlnd 5.0.10 - 20111026
です。

>>385
ありがとうございます。
1万行のダンプデータというのはこれでいいでしょうか
http://www.dotup.org/uploda/www.dotup.org4869465.sql

複合INDEXを初めて聞いたので検索、実行してみました
http://www.dotup.org/uploda/www.dotup.org4869541.png
恐らくindex自体は作成されていると思うのですが、うまく使えない状態です
387NAME IS NULL:2014/02/12(水) 21:57:28.07 ID:???
WHERE条件で大量のデータが返るのならORDER BY RAND()ではなく
対象件数を取得、その範囲の乱数を生成、LIMIT <乱数値>, 1とした方が早いかも。
EXPLAINでインデックスが使用されているか調べることが先だけど。
388NAME IS NULL:2014/02/12(水) 22:02:04.52 ID:???
>>384
可能であればdescの結果か、show create table の結果を貼ってください。
389NAME IS NULL:2014/02/12(水) 22:04:40.54 ID:???
>>386
388です。すいません、更新してませんでした。
ちょっとあっぷして頂いたデータでやってみます。
390NAME IS NULL:2014/02/12(水) 22:06:23.20 ID:???
mysql> desc cc_ai_c;
+-----------------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------------+-------------+------+-----+---------+-------+
| id | int(11) | NO | | 0 | |
| word | varchar(10) | NO | | NULL | |
| hinsi | varchar(10) | NO | | NULL | |
| first | int(11) | NO | | NULL | |
| last | int(11) | NO | | NULL | |
| noudo | double | NO | | NULL | |
| x | int(11) | NO | | NULL | |
| y | int(11) | NO | | NULL | |
| z | int(11) | NO | | NULL | |
| next | varchar(10) | NO | | NULL | |
| prev1 | varchar(10) | NO | | NULL | |
| prev2 | varchar(10) | NO | | NULL | |
| prev3 | varchar(10) | NO | | NULL | |
| hinsisaibunrui1 | varchar(10) | NO | | NULL | |
| hinsisaibunrui2 | varchar(10) | NO | | NULL | |
| hinsisaibunrui3 | varchar(10) | NO | | NULL | |
| katuyoukei | varchar(10) | NO | | NULL | |
| katuyougata | varchar(10) | NO | | NULL | |
| genkei | varchar(10) | NO | | NULL | |
| yomi | varchar(10) | NO | | NULL | |
| hatuon | varchar(10) | NO | | NULL | |
+-----------------+-------------+------+-----+---------+-------+
21 rows in set (0.01 sec)

どう見てもインデックスがないんですが。
391384:2014/02/12(水) 22:15:51.66 ID:RkkOXYbS
>>390
すいません、すいません…
indexってmysqlで「構造」のカラムにチェックして、インデックスをクリックすれば作れると思っていました

そしてもうデータベースにもアクセスできずにどうしていいかわからないです…orz
Fatal error: Maximum execution time of 30 seconds exceeded in C:\xampp\phpMyAdmin\libraries\session.inc.php on line 96

ちょっと勉強してきます。。。
392NAME IS NULL:2014/02/12(水) 22:22:13.58 ID:???
なるほど、確かにインデックスを設定すれば15倍はやくなりそう
393NAME IS NULL:2014/02/12(水) 22:27:06.84 ID:???
>>391
388です。
1万件のデータで例にあったselectしてみたけど、0.07秒(初回)でした。
CPUはAMDのE450というatom以下のCPUです。

で、keyがよくわかんないから
alter table cc_ai_c add key (first);
alter table cc_ai_c add key (prev1);
alter table cc_ai_c add key (prev2);
alter table cc_ai_c add key (prev3);
して同じselectしたら0.00秒でした。

ちなみにクエリキャッシュは使ってないので、keyを設定するだけでも改善すると思います。
394384:2014/02/12(水) 23:22:10.38 ID:RkkOXYbS
うおー!ありがとうございます!!凄まじく早くなりました。
http://www.dotup.org/uploda/www.dotup.org4869827.png
しばらくは問題なさそうです

複合インデックス、今後も大事にします、ありがとうございました!
395NAME IS NULL:2014/02/13(木) 12:37:46.60 ID:???
「同時に1つのインデックスしか使えない」って仕様に引っかかりやすいよね。
複合インデックスは頭からしか使えないからカラムの順序に注意。

あとインデックスには指定したカラムに加え、主キーが入るってことも知っておくと役立つ。
396NAME IS NULL:2014/02/13(木) 20:55:55.13 ID:???
64bit版のRHEL6.4にバンドルされてる5.1.66で
got signal 11
のエラーがでてmysqlが再起動します。

mysqlのバグで5.1.59以降では治ってるって書いてある
サイトがあったんだけど、再発したんでしょうか?

回避する方法ってなんかあります?
397NAME IS NULL:2014/02/14(金) 22:22:54.64 ID:???
ちょっとヒントがほしいです
Using Index が表示されるのに、 Using temporary; Using filesort が出てしまうのは、設定ファイルがいけないのだろうか?

EXPLAIN SELECT article_date,count(id)
FROM `log`
WHERE user = 4 and FIND_IN_SET(“aaa”,`category`) and date between ‘2013-01-01’ and ‘2013-12-31’ group by date

複合は(user、category、date)に貼っていて、ちゃんとに使われている。
398NAME IS NULL:2014/02/14(金) 23:30:34.76 ID:???
>>397
FIND_IN_SETのカラムにインデックスを張っても効率化されないと思う。
関係者にごめんなさいして第一正規化するか、
とりあえず妥協して複合インデックスを(user, date)に張ってみる。

それからSELECT article_dateなのにGROUP BY dateとなっているが、
転記ミスでなければこれはGROUP BYのよくない使い方。
SET sql_mode = ONLY_FULL_GROUP_BY;
で動くSQLに直してからチューニングを考えたほうがよいかも。
399NAME IS NULL:2014/02/14(金) 23:34:59.20 ID:???
>>397
別になんの不思議もないと思いますが?
インデックスを使ってレコードを絞り込めるが、
それの集計やソートにテンポラリテーブルやクイックソートが必要ってことかと。
400NAME IS NULL:2014/02/15(土) 14:10:54.99 ID:???
urlを保存する時って
1つのカラムに「http」削って
://〜
って保存するのと、「0=http://、1=https://、2=http://www」とかって定義して2つのカラムに
1(int) 2
0   yahoo.co.jp
って保存するのでは後者の方がいいよね?みんなの保存方法を聞きたいです。
401NAME IS NULL:2014/02/15(土) 14:17:35.66 ID:???
この後どう使いたいかにもよるんだろうけど
加工せず丸ごと保存ではだめなのか?
402NAME IS NULL:2014/02/15(土) 14:18:53.46 ID:???
>>400
区切らない
それで節約できるのはURL読み出し時の数バイト
とんでもなく大量にhttp〜で始まるなら別だが、普通に要らない
403NAME IS NULL:2014/02/15(土) 14:19:28.27 ID:???
この後はただそのurlを表示するだけの用途で検索対象にはなりません。
少しでも容量を減らしとけばいいんじゃないかな、と思ったのでそういう工夫をしている人がいたならと思い聞きました。
TEXT型で丸ごと保存が一般的なんでしょうか?
404NAME IS NULL:2014/02/15(土) 14:21:18.30 ID:???
>>402
ありがとうございます。
ググってもそういう話題がなかったので、普通はそういう必要はないってことなんですね。
データは千万以上はいきそうです。
405NAME IS NULL:2014/02/15(土) 14:32:37.01 ID:???
>>404
はい。インデックスさえ貼れば割となんとでも
406NAME IS NULL:2014/02/15(土) 14:38:16.98 ID:???
>>404
ありがとうございます。
innoDBで5.514なんですが先輩にTEXT型はなるべく使うなと言われてまして、varchara(255)で
日本語文字urlの場合、decodeしたりして保存したりしようと試行錯誤してます。
TEXT型で保存が一般的なんですね。参考にさせていただきます。
407NAME IS NULL:2014/02/15(土) 17:07:29.99 ID:???
先輩がTEXT型使うなと言っているのは分かるけど、
URLのような長い文字列を扱うなら仕方ない。
1億レコードを超えたあたりからキツくなってくる感じかな。
408NAME IS NULL:2014/02/16(日) 14:28:23.13 ID:???
便乗質問で悪いんだが>>397のケースの場合ってmy.cnfの設定がダメってことなんかな?
409NAME IS NULL:2014/02/16(日) 18:28:07.60 ID:???
FLOAT型の列column_aに対して以下のSQLを発行したのですが、データが取得できませんでした。
column_aの値が15.55のレコードは存在しています。

SELECT * FROM table_a WHERE column_a = 15.55;

基本的なことで申し訳ないのですが、どこがおかしいのか教えていただけないでしょうか。
MySQLのバージョンは5.6.14です。よろしくお願いいたします。
410NAME IS NULL:2014/02/16(日) 22:05:46.28 ID:???
411NAME IS NULL:2014/02/16(日) 22:33:56.79 ID:???
>>410
ありがとうございます!まさにこの通りでした。
412NAME IS NULL:2014/02/19(水) 15:10:28.80 ID:???
レンタルサーバー借りる基準にMySQLのバージョンって重要視する?
エックスサーバーが5.5.xって書いてたから借りたら金払った後に5.0.xだとわかった。
なんか腹立たしい気がするけど5.5と5.0って速度違うの?
413NAME IS NULL:2014/02/19(水) 15:27:46.66 ID:???
>>412
違う
414NAME IS NULL:2014/02/19(水) 19:35:53.34 ID:???
>>412
もしかして5のDBサーバー2台あるんじゃない?
接続先確かめてみたら?
415NAME IS NULL:2014/02/19(水) 19:40:11.28 ID:???
>>413
>>414
エックスサーバーに問い合わせたら、今アカウントを取り直したら5.5.x使えるよ、今使ってるアカウントじゃ使えないよって答えられた。
先月アカウント買ったばかりなのに。
416NAME IS NULL:2014/02/19(水) 19:59:20.24 ID:???
>>415
>エックスサーバーが5.5.xって書いてたから借りた

この辺を強く出してみたら?
417NAME IS NULL:2014/02/19(水) 20:34:38.27 ID:???
>>416
うーん、まだサイトは作成中だし初期費用と3ヶ月しか支払ってないからアカウント取り直そうかな。
たぶん言ってもどうにもならないと思うし。
418NAME IS NULL:2014/02/26(水) 07:40:50.28 ID:???
>>417
vpsを借りたら?
419NAME IS NULL:2014/02/26(水) 13:58:33.80 ID:???
>>418
余計お金掛かりそう…。
さくらは5.5が提供されたら同じアカウント内で変更できるみたいだね。
失敗したかなあ。
420NAME IS NULL:2014/02/26(水) 20:16:07.34 ID:???
win7home & mysql 5.5.19です
init_file = c:/stock2test.sql

stock2test.sqlの中身
delete from test.stock_master;
insert into test.stock_master
select * from stock.stock_master;

なんですが、errファイル見ると
ERROR: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1
140226 20:09:52 [Note] C:\Program Files (x86)\MySQL\MySQL Server 5.5\bin\mysqld: ready for connections.
とエラーになってしまってるんです。
一応musqlコンソールでstock2test.sqlの中身を打つと正常に更新はされるんですけど…
なんで??
421420:2014/02/26(水) 20:27:00.53 ID:???
くそっ訳わからんw
insert into test.stock_master
select * from stock.stock_master;
を改行なくして
insert into test.stock_master select * from stock.stock_master;
にしたらそれだけで正常に終わった^^;
なんなんだよー w
422NAME IS NULL:2014/02/26(水) 21:00:15.58 ID:2PZcjpuv
初めまして、検索してもどうもお目当ての記述が引っかからなかったので、ここで質問させて頂きました。

MySQLに、PHPコードと日本語テキストを含んだHTMLの記述 (以下これを「HTMLの記述A」と呼びます) を、
そのままデータベースに保存するのはやはり邪道というものでしょうか?
これがもし邪道であるとしたら、『PHPページに「HTMLの記述A」を複数並べてHTML形式で表示させる方法』として、
どのような方法が考えられるでしょうか。

私はこの「HTMLの記述A」の中のデータを入れ替えながら、
「HTMLの記述A-1」「HTMLの記述A-2」「HTMLの記述A-3」というように1ページに10件ずつ表示させていきたいと思っています。
どなたか解る方がいれば、ご教授お願い致します。
423NAME IS NULL:2014/02/26(水) 23:14:41.39 ID:???
>>422
やりたいようにやればいいんじゃないかな。不具合が無くて問題無く動くなら邪道も何もないよ。
つか処理に問題があるかどうかを聞きたいならここで質問する内容ではない。
424249:2014/02/27(木) 13:56:12.28 ID:???
>>420
改行コードとかじゃないのかね。

手元の 5.6.16(Ubuntu 12.04) だと LF でも CRLF でも大丈夫だったが、
Windows だとか Version によってダメなのかな。

それぐらいしか思いつかない。
425NAME IS NULL:2014/03/01(土) 20:18:22.40 ID:???
mysql自体のクエリキャッシュ機能と
javaのehcacheみたいなアプリ側でのキャッシュライブラリは
どういう基準で使い分けるんですか?
426249:2014/03/01(土) 22:31:26.99 ID:???
>>425
Webサーバが2台(A,B)あったとして、
AのキャッシュにMySQLのデータの一部が乗っている場合、
Bが MySQL を更新した場合どうする?

DBに入ってるデータとしては
ほとんど更新されないけどDBなどに入れておきたい
なにかのマスターデータとかは、アプリ起動時にDBから
とってきてローカルにキャッシュ。更新されたらアプリを再起動。
それ以外はクエリキャッシュとかが多いんじゃないかね。

まぁ、クエリキャッシュはアプリによっては切ったほうが
性能がいいけどな
427NAME IS NULL:2014/03/02(日) 09:41:30.61 ID:???
クエリキャッシュ、最近は非推奨って言ってる人が多いね。
近年の数十〜数百コアのCPUで並列処理させると逆にパフォーマンスが落ちるとかで。
428426:2014/03/02(日) 15:22:24.04 ID:???
クエリキャッシュって全部のクエリで必ず最初に実行する
大きなメモリテーブルがあるようなもんで、
そのテーブルを更新しまくりなのでロックがはんぱない。

で、クエリキャッシュにそこそこ(経験上全クエリの4割以上)
ヒットするならいいけど、そうでないならば切ってしまったほうがいい。
# このへんは HW 性能や、クエリ数などによっても変わるので、
# 試す人は検証してね。query_cache_size はオンデマンドで減らすことは
# できるけど、増やすのは再起動を伴うからね。

どうしてもバッチなどで必要なら、query_cache_size は確保しといて、
query_cache_type を 「DEMAND」にして必要な物だけ
select SQL_CACHE ... として実行した方がいい。

参考:
http://dsas.blog.klab.org/archives/52021866.html
429NAME IS NULL:2014/03/07(金) 09:08:33.45 ID:???
Linuxで5.6入れたら今までの方法でエラーでまくりワロタw
このデフォルトでエラー吐きまくる糞仕様のmy.cnfなんとかならんかな
しかもエラーコードも全然役に立たないし。

重要な調整項目についても全然解説ねーし、
1つバージョン違うだけでオプション変更されすぎ。
ただでさえクソ長い英語のドキュメント読みなら作業してんのに報われなさすぎ。
430NAME IS NULL:2014/03/07(金) 10:46:50.41 ID:???
ポスグレは日本語のドキュメントが充実してるのに
MySQLはなんでないんだろう?

金にならないから?
431NAME IS NULL:2014/03/07(金) 21:25:07.43 ID:???
>>429
仕事で5.6の構築手順書作ったけど、5.5からはだいぶ変わったよ。
英語のドキュメントを読んでも情報不足なんだよなー
432NAME IS NULL:2014/03/07(金) 22:53:03.84 ID:???
>>429
いれて3分でデータベース とかってうたい文句はどうしたんだろうなw
433NAME IS NULL:2014/03/07(金) 23:16:13.58 ID:???
mysql本体のバージョンはすぐ判るんですけど、PCに入っているodbcドライバのバージョンは
どうやったら確認出来るんでしょうか?
434NAME IS NULL:2014/03/08(土) 01:40:11.95 ID:???
つーか、パッケージ名もコロコロ変えすぎ。
なにがどれに対応してるのか一覧書けや
あーイライラするー!
435433:2014/03/08(土) 18:49:43.83 ID:???
管理ツール→データソース(odbc)→ドライバー
で確認


以上
436NAME IS NULL:2014/03/09(日) 11:32:57.02 ID:???
XADataSourceにXAリカバリ失敗のバグがあるの?
437NAME IS NULL:2014/03/10(月) 01:13:07.29 ID:???
ORACLEはゆっくりとMySQLを殺そうとしてるんだろ。
Win版のセットアッププログラムとかどんどんクソになってるよ。
438NAME IS NULL:2014/03/10(月) 14:57:27.55 ID:???
公式のMySQLインストールした場合って、
phpmyadminってどこの入れたらいいの?

いつもどおりyumでremiの入れようとすると、
remi版のMySQLインスコしようとしてバッティングするんだけど。
教えてエロい人。
439NAME IS NULL:2014/03/10(月) 17:00:16.16 ID:???
何言ってんのかわからん
phpmyadminって普通にディレクトリに置いてブラウザからアクセスするだけでしょ?
ていうか、そんなphpで作ったやつじゃなくて普通のSQLクライアントだったらHeidiSQLとかOracleのMySQL Workbenchがオススメだけど
440NAME IS NULL:2014/03/10(月) 20:05:04.34 ID:???
441NAME IS NULL:2014/03/10(月) 20:50:35.76 ID:???
>>739
ホントだ。解凍して置いて設定したら動いたわー。
これってそんな簡単な構造だったんだね。

MySQL公式のリポジトリでインストールしたMySQLってyumで依存関係めちゃくちゃになるんだね。
元々サードパティのライブラリなんかは共存するように設計されていないんだろうけど、
悩んだ悩んだ。

ありがとうエロイ人
442NAME IS NULL:2014/03/10(月) 20:55:48.40 ID:TC9gqAVZ
739はどんなことを書くんだろう
443NAME IS NULL:2014/03/10(月) 20:57:46.07 ID:???
今年中に739までいくのかね
444NAME IS NULL:2014/03/10(月) 21:06:40.10 ID:???
>>437
Glassfishのようにな
445NAME IS NULL:2014/03/10(月) 21:35:33.06 ID:???
呼んだか、139
446NAME IS NULL:2014/03/13(木) 16:01:01.79 ID:???
mysqlの全文検索とelasticsearch
どっちがいいですか?
447NAME IS NULL:2014/03/14(金) 23:58:45.62 ID:???
>>446
groonga
448NAME IS NULL:2014/03/15(土) 00:01:35.58 ID:???
>>446
Mroongaだった
449NAME IS NULL:2014/03/15(土) 22:36:02.07 ID:???
>>441
おま、yumってことは、redhatかcentかfedoraか
ディストリビューション使うなら外のrpmとかソースからコンパイルとかダメだぞ
何のためのディストリビューションなのかわからん
自由にやるならfreebsdかなんかにすべし
450NAME IS NULL:2014/03/15(土) 23:55:51.80 ID:???
>>449
その考えは流石に偏りすぎ。
451NAME IS NULL:2014/03/17(月) 22:43:31.86 ID:DVOkasB3
mysql> create table topics (
-> id INT UNSIGNED NOT NULL AUTO INCREMENT,
-> title VARCHAR(255) NOT NULL,
-> description VARCHAR(255) NOT NULL,
-> created_at DATETIME NOT NULL,
-> updated_at DATETIME NOT NULL,
-> PRIMARY KEY(id)
-> );

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '-> id INT UNSIGNED NOT NULL AUTO INCREMENT,
-> title VARCHAR(255) NOT NULL' at line 2


どこか間違ってるかわからんのだが。。
452NAME IS NULL:2014/03/17(月) 22:47:01.43 ID:???
AUTO_INCREMENT
453NAME IS NULL:2014/03/17(月) 22:47:16.67 ID:???
アンダースコアがない
auto_increment
454NAME IS NULL:2014/03/17(月) 22:59:01.88 ID:???
AUTO INCREMENTと見せかけて

> use near '-> id

いやAUTOも間違ってるんだけど
455NAME IS NULL:2014/03/17(月) 23:00:30.74 ID:DVOkasB3
ごめん
これでもだめだった

create table topics (
-> id INT UNSIGNED NOT NULL AUTO_INCREMENT,
-> title VARCHAR(255) NOT NULL,
-> description VARCHAR(255) NOT NULL,
-> created_at DATETIME NOT NULL,
-> updated_at DATETIME NOT NULL,
-> PRIMARY KEY(id)
-> );


ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '-> id INT UNSIGNED NOT NULL AUTO_INCREMENT,
-> title VARCHAR(255) NOT NULL' at line 2
456NAME IS NULL:2014/03/17(月) 23:18:41.44 ID:DVOkasB3
454さん
ありがとう御座います。

create table topics ( id INT UNSIGNED NOT NULL AUTO_INCREMENT,title VARCHAR(255) NOT NULL,description VARCHAR(255) NOT NULL,created_at DATETIME NOT NULL,updated_at DATETIME NOT NULL,PRIMARY KEY(id));
でできましたが、多分454さんが意図していたことと齟齬があると思います。
よければ教えて頂けないでしょうか
457NAME IS NULL:2014/03/18(火) 00:32:15.36 ID:???
>>456
書き方が悪かったね
AUTO INCREMENT だけじゃなくて -> も間違ってると示したかっただけだよ
458NAME IS NULL:2014/03/18(火) 00:38:21.23 ID:???
なるほど mysql> も打ち込んじゃうタイプか。
新人研修のときそういう同期いたなあ
459NAME IS NULL:2014/03/18(火) 01:02:40.19 ID:YYxIyd7p
ありがとう御座います!
460NAME IS NULL:2014/03/18(火) 06:29:17.69 ID:???
プログラミングの入門書で本のサンプルを行番号込で打ち込むようなもんか
461NAME IS NULL:2014/03/18(火) 13:05:32.96 ID:We3J6S8O
【社会】厚労省の中で男が刃物取り出す 銃刀法違反の現行犯で逮捕
ttp://genzo.org/read/uni.2ch.net/newsplus/1389346716/

今後の犯罪傾向の予測と考察

事前面接(偽装請負)の犯罪に憤りをもつ派遣社員、非正規労働者、失業者が
比較的警備の薄い厚労省、労働局、 労基署にいく可能性がある。しかし他の可能性
を考えてみた。
事前面接中(指揮命令中)に派遣先と派遣元の担当者をターゲットにしたテロである。 派遣社員の事前面接(指揮命令)は違法であり、事前面接中(指揮命令中)に派遣社員(請負労働者)が暴れだした場合は
警察に通報できない状況となる。つまり通報すれば労基法6条違反、
職安法44条違反などの犯罪事実が報道で日本中に周知され、グッドウィル事件の再現となる可能性 が出てくる。そのため被害者である派遣先・派遣元が加害者に高額の口止め料
(影響を考慮すれば3000万円以上が妥当)を支払い隠蔽しようとする奇妙なテロがおきうるのだ。
※グッドウィル摘発のきっかけとなった事故は、現場の派遣スタッフの意図的な自傷事故だったとする説がある。

仮に、怒りに我を忘れた派遣社員が、派遣営業や面接官の小指を切り落とすような
凶行がおきた場合、小指を失った社員は転職や社会活動が難しいため、現在の会社で
は降格・減給などの奴隷的待遇を一生耐えるしかない。会社は隠蔽を優先し
派遣社員への高額の口止め料で手を打ち、被害社員はひたすら耐えるだけだ。
※非力な女性でも防犯スプレーとスタンガンで社員の抵抗を事前に抑止して小指の切断ができる可能性がある。

非正規の奴隷的待遇は、共産・民主党を支援してきた労働組合が
構成員である大企業の正社員の雇用や、給与水準をまもるための正社員保護主義の結果である。非正規や下請け正社員はその犠牲であり受給調整弁として中間搾取等をされたり労働者の権利を剥奪された。正社員の解雇ルールが立法化されれば、大企業も正社員
を増員し、違法な中間搾取、雇用・契約止めの脅し、理不尽な待遇、差別をする要因が排除されるが、これを労働組合は派遣・非正規を
犠牲にし正社員の給与水準を高くするため徹底して反対している。このため非正規
労働者が労働組合、民主党や「連合」の襲撃をする余地がある。
462NAME IS NULL:2014/03/20(木) 19:28:22.45 ID:???
あ、レスきてたw

CentOSでやってました。アドバイスありがとう。
既にコンパイルはあきらめてyumでインストールしましたw
最新のものに食いつくにはCentOSは向かないね。

安定ヽ(´ー`)ノマンセー
463NAME IS NULL:2014/03/28(金) 19:16:16.93 ID:???
mysql 5.6.17
464NAME IS NULL:2014/04/02(水) 05:13:06.05 ID:RYzsF+0W
↓の方法で、ControllerからModelにアクセスすると
public function hoge() {
 $this->loadModel('Hoge');
 $Users = $this->Hoge->find('all');
}

このようなエラーが表示されてしまいます。
Missing Datasource
Error: Datasource class Mysql could not be found.
Datasource is not found in Model/Datasource package.

↓の中には"empty"というファイルしか入っていないのですが、
cakephp\app\Model\Datasource

やはり何かファイルが足りないのでしょうか?
465464:2014/04/02(水) 05:13:46.30 ID:???
ごめんなさい
すいません投稿スレ間違えました・・・
466NAME IS NULL:2014/04/02(水) 08:14:45.70 ID:???
レプリケーションの設定をしたいのですが、
レプリケーション先のデータベース名を違ったものにすることはできますか?
こんな感じです。
SRC:TESTDB
DST:TESTDB_REPLICA

マニュアル見てみたのですが、該当する項目がありませんでした。
バージョンは、5.6です。
467NAME IS NULL:2014/04/02(水) 10:30:46.07 ID:???
>>466

statement-based の場合なら、
slave 側で trigger 使えば出来そうな気がする
# 一時的には同名テーブルにデータが存在してしまうが

mix/row-based の場合は厳しいんじゃないかな

通常の方法では難しいと思う
468NAME IS NULL:2014/04/02(水) 12:49:59.72 ID:???
Microsoft、「Microsoft SQL Server 2014」を一般公開
ttp://www.forest.impress.co.jp/docs/news/20140402_642417.html
469NAME IS NULL:2014/04/02(水) 22:12:39.36 ID:???
>>467
クエリの中で、UUID()関数を使用しているため、SBRでは難しそうですね。
諦めて同名レプリケート運用にしたいと思います。
貴重なアドバイスありがとうございました。
470NAME IS NULL:2014/04/02(水) 22:48:24.01 ID:???
471NAME IS NULL:2014/04/04(金) 19:10:13.69 ID:???
MySQL 初心者で、アドバイスお願いいたします。

ID(1〜)にインデックスが張ってあり数万件あるとします。
一番大きなIDから(降順)10件取り出したい場合

SELECT * FROM `テーブル` ORDER BY `id` DESC limit 0,10

で取り出せるのですが、インデックスがあっても全文検索?になり
今後件数が増えると時間がかかりそうです。

高速に取得する一般的な方法はどうやるのでしょうか?
別のカラムを使ったり、複数のSQLになってもかまいません。
MySQLのバージョンは5.5で、言語はPHPを使ってやりとりしております。
472NAME IS NULL:2014/04/04(金) 19:51:01.72 ID:???
>>471
 idが「1から連番で抜けがない」という都合のいい前提が許されるなら
where句に`id` between 1 and 10でいいと思うけど、まずダメよね。

 元のクエリはインデックスを頭からスキャンしていく(末端にいくほ
ど遅くなる)けど、テーブルのフルスキャンほど遅くはない(と思う)
ので、実際に想定される最大数のレコードを作ってみて許容できる速度
かどうか見てみるのがいいんじゃないかな。

 ちなみにうちはMariaDBだけど、10万レコード作ってlimit 99990,10で
クエリ走らせてみたら0.06秒だった。
473NAME IS NULL:2014/04/04(金) 19:56:04.75 ID:???
limitはlimit 1000,10とか、offsetの値が多くなればなるほど重くなる。
だからできるだけ避けた方が良い。
474NAME IS NULL:2014/04/04(金) 20:07:02.63 ID:???
>>471
limit 10000,10みたいに真ん中取り出してもインデックス使われませんか?
475NAME IS NULL:2014/04/04(金) 20:07:32.82 ID:???
offsetがでかいとかなら分かるが、
SELECT * FROM `テーブル` ORDER BY `id` DESC limit 0,10
が遅いというのがわかんない
どうやって「全文検索」って判断したんだろ
476471:2014/04/04(金) 21:02:06.33 ID:???
みなさまアドバイスどうもです。

インデックスが使われているかどうかもよくわからないんですよね。
EXPLAIN で type が index だと全文検索?ですよね。
471 のSQLだとでちゃいます。

このSQLで0.1秒、今後10万件とか増えてきてもこの時間で処理されるんだろうか
心配になってお聞きしました。

>>475
「ORDER BY 使うとインデックスが使われない時がある」?みたいな記事を読んでです。
477NAME IS NULL:2014/04/04(金) 21:07:43.85 ID:???
>>476
explainでrowsの数が検索数だと思
478NAME IS NULL:2014/04/04(金) 21:21:03.02 ID:???
>>476
typeがALLになってたらフルスキャン。
479NAME IS NULL:2014/04/04(金) 21:44:24.76 ID:???
>>476
 typeが"ALL"ならテーブルのフルスキャン、"index"ならインデックスの
フルスキャン。ということでインデックスは一応使われてる。

 >>471のクエリの場合、「インデックスの頭」からoffset+limitレコード
をなめる(limit 10000,10なら10010レコード)けど、これでインデックス
を張ってなかったらテーブルスキャンになって全レコードをなめに行く。

 それにしても先頭10件で0.1秒は遅すぎじゃないかな。
480NAME IS NULL:2014/04/04(金) 21:52:20.21 ID:???
>>476
type=indexは通常、インデックスフルスキャンなので一般的に重いが、
order by `index_column` limit ?の場合は例外で、
インデックスの先頭もしくは後ろから数件読むだけなんで高速。
(offsetが大きくなるなら別)

> 「ORDER BY 使うとインデックスが使われない時がある」?
というのは、
select * from where `index_column` = ? order by `primary_key`
みたいなクエリのとき、通常はindex_columnのインデックスが使われるはずだが、
オプティマイザが主キーインデックスを使ってしまうケースがあって、
その場合にフルテーブルスキャンを引き起こして、洒落にならないくらいにクソ重くなることはある
481471:2014/04/04(金) 21:57:11.63 ID:???
>>477-479
type 'index' は インデックスのフルスキャンでしたか!
インデックスが使われていることに一安心しましたw

>それにしても先頭10件で0.1秒は遅すぎじゃないかな。
phpMyAdmin上で実行しているので
実際はもっと高速なのかもしれません。

アドバイスどうもでした
482NAME IS NULL:2014/04/05(土) 10:35:04.66 ID:???
clustered?
483NAME IS NULL:2014/04/06(日) 21:44:58.68 ID:???
助けてください。
MysqlをインストールするとConfiguration OverViewでインストールが止まってしまいます。
バージョンを変えたりとかインストール場所の変更とか管理者権限で動作させたりしたましたが
必ず同じ場所で止まります。

【環境】
OS:Windows7 64bit Pro
MySQL:mysql-installer-community-5.6.17.0.msi
      mysql-5.1.73-winx64.msi
mysql-installer-community-5.5.37.0.msi

【現象】
http://www.rupan.net/uploader/download/1396787881.png
この状態から先に進みません。5分程放置しましたが全く反応がありません。


【試した事】
・MYSQLのバージョンを変更
・インストールの場所を変更
 デフォルト(Serverのインスコ先):D:\/(Dataのインスコ先)C:\ProgramData\MySQL\MYSQL_x.xxx\
変更先:(Serverのインスコ先):C:\Program Files\MYSQL\/(Dataのインスコ先)C:\Program Files\MYSQL\Data\MYSQL_x.xxx\
・msiを管理者権限で開く(コマンドプロンプトを管理者権限で開いてC:\msiexec -i [msiファイル]で開く)

どれも毎回アンインストールして、再起動してから入れなおしました。
わかる人がいましたら是非回答をお願いします。
484NAME IS NULL:2014/04/06(日) 22:00:03.04 ID:???
全くの当てずっぽうでゴメンだけどサービス名が既に登録されてしまっててそれが被っているとか?????

とりあえず
アンインストール失敗などで残ったWindowsのサービスを削除する方法
http://ub.blog85.fc2.com/blog-entry-287.html
でmysqlのサービスがどうなっているか確認してみたら?

ただし全く自信はないので外れていても勘弁
485NAME IS NULL:2014/04/07(月) 00:10:07.87 ID:???
なんか同様の報告は海外フォーラムで結構あがってるようなんだけど、
ざっと見た感じパスがおかしいとかそういうのが多いな。

C:\Program Files\MYSQL\/(Dataのインスコ先)C:\Program Files\MYSQL\Data\MYSQL_x.xxx\
ところでこれは何で2回ドライブレターが出てるの?こぴぺみす?
486483:2014/04/07(月) 21:24:39.95 ID:???
環境
OS:Windows 7 64bit Professional
MySQL:mysql-installer-community-5.6.17.0.msi

前準備
1. コントロールパネルからMySQL関連の情報を削除
2. C:\を全検索し"MYSQL"と"my*.ini"を検索し削除
3. CCleanでレジスストリをスキャンして削除(MYSQL関連がわんさか出る)
4. OSを再起動
5. コントロールパネル→管理ツール→サービスが存在しない事を確認

動作
1. cmd.exeを管理者として実行
2. >msiexec.exe -i D:\mysql-installer-community-5.6.17.0.msi 実行
3. Install Product -> Developer Defaultを選択
⇒ Installation Path: C:\Program Files\MySQL\
⇒ Data Path:C:\MySQL\MySQL Server 5.6\
4. 後はMySQL Server Configurationまで[Next]
5. 設定は以下の通り
⇒ConfigType:Development Machine
⇒Port:3306 Open Firewall port network access チェック入
⇒MySQL Root Password:0123456789
⇒Windows Service Name: MySQL56(デフォルト) Start the MySQL Server at System starupチェック入
⇒Run Windows Service as : Standard System Account


ああああ・・・・やっぱりあかん。
487NAME IS NULL:2014/04/07(月) 21:28:16.69 ID:???
>>484
レスありがとうございます。
手法は違いますがレジストリからは情報を消して挑んでました。
サービスからMYSQLを起動させると1067エラーが出ますね。
>>485さんの言われている通りパスのエラーのようですが・・・。

>>485
Installation Path/Data Pathを分けて書いたんですが、余計にわかりにくくなってますね。
ごめんなさい。
確かにご指摘の通りパスがおかしそうなんですが、iniファイルとかを見直して見ます。
488NAME IS NULL:2014/04/07(月) 21:41:56.21 ID:???
msiじゃなく、これもダメ?
WindowsにMySQL(zip版)をインストールする
http://www.koikikukan.com/archives/2013/06/18-011111.php
489483:2014/04/08(火) 00:13:20.36 ID:???
>>488
ありがとうございます。
早速試してみたのですが、C:\mysql\bin>mysql -u root ところで
コマンドが無いとメッセージが出ました。
正しく解凍がされてないなかったのか。もう一度やり直してみます。

http://www.rupan.net/uploader/download/1396883432.png
490483:2014/04/08(火) 19:59:30.84 ID:???
導入できました。
あの後も色々試しましたが結局の所msiファイルからのインストールはできませんでした。
その代わり>>488さんから教えて頂いたzipからの導入方法で無事動く事を確認できました。

benchもzipで導入してMySQLエディタが動作する事を確認できました。
ありがとうございます。
491NAME IS NULL:2014/04/09(水) 16:36:51.01 ID:UnA+HtrF
mysql-connector-cでプログラムを書いているのですが、mysql_queryでUPDATEのSQLを実行したときに
WHEREで該当するレコードがなかった場合にはエラーになるのでしょうか

実行した時にエラーが返ってくるのですが
492NAME IS NULL:2014/04/09(水) 17:05:31.81 ID:???
以前図書館から借りたMySQL クイックリファレンス( オライリー)
のC APIの部分をテキストでコピってたのを見ると

第2引数で指定されたSQLクエリを実行するために使用する。指定できるSQL文は1つ
のみ
バイナリデータを含むクエリの場合はmysql_real_query()関数を使用する。
実行に成功した場合は0、失敗した場合は0以外を返す

とある。

というか、
23.2.3.51. mysql_query()
http://dev.mysql.com/doc/refman/5.1/ja/mysql-query.html

にそう書いてますがなw
493NAME IS NULL:2014/04/10(木) 23:24:19.32 ID:???
5.6のGTIDってバグりまくりで使いものにならないってほんと?
494NAME IS NULL:2014/04/11(金) 06:38:49.91 ID:???
5.6.17まででだいたい直ったと思う
495NAME IS NULL:2014/04/11(金) 23:53:18.40 ID:???
質問です。XP、xampp1.7.4です。
ずっと正常に使えていたんですが、XPのネット接続を無効にするために
いろいろいじっていたらphpmyadminのログインが通らなくなりました。
そこで再度xamppをインストールし、localhost/phpmyadminのページを開くと、
#2002 - The server is not responding (or the local MySQL server's socket is not correctly configured)
といったエラー文が出て、そこから何をしたら良いか全然わからず困っています。
上記メッセージで検索すると出てくる解決法は前提条件が違ったり、
書いてある解決法が省略されすぎていて理解できません。
何をどうすればよいのか教えていただきたく。
496NAME IS NULL:2014/04/12(土) 04:03:30.40 ID:???
>>495
PMAを使わない。
497NAME IS NULL:2014/04/12(土) 11:29:08.55 ID:???
レスありがとうございます。
しかしおっしゃっている意味がわかりません。
具体的にどうすればよいのでしょうか。
ちなみにログインはrootユーザで行っています。
pmaユーザでログインはしていません。
498NAME IS NULL:2014/04/12(土) 12:40:27.29 ID:???
MySQLのクエリくらい簡単だから直打ちしやがれ。
499NAME IS NULL:2014/04/12(土) 15:06:14.81 ID:???
PHPなんだから、自分でPMAだけ入れなおせばいいじゃん
セッティングスクリプトはちゃんと消しておけよ
500NAME IS NULL:2014/04/12(土) 15:36:42.35 ID:???
質問ですがFacebookとかのいいね!ボタンの設計ってどうなってるんでしょうか?
・webページ毎のカウントtable(url、カウント
・誰がドコにいいね!したのか記録table(ユーザー、url
を作ったとしても1兆レコードぐらい簡単に行ってしまいそうな気がするんですがmysqlは大丈夫なんですか?
それとももっと良い設計とかあるんでしょうか?
501NAME IS NULL:2014/04/12(土) 15:45:42.37 ID:???
>>500
テーブル分ければ良いだけだからさ
502NAME IS NULL:2014/04/12(土) 16:09:50.15 ID:???
webサイト毎にtable作るってのも考えたんですが
以前ココで1000万テーブル作ったりするのは設計ミスとか言われたんで
503NAME IS NULL:2014/04/12(土) 17:05:45.33 ID:???
>>502
どんな質問をして設計ミスって言われたのか知らん。
ただ言えることは、規模とか用途とかによってテーブル設計が変わる。
まあそれでも1000万テーブル作るってことは無いと思うけど。
504NAME IS NULL:2014/04/12(土) 23:41:03.96 ID:???
>>502
テーブルパーティショニングとかそこらへんの話だろ
505NAME IS NULL:2014/04/14(月) 23:49:27.71 ID:???
Oracle Critical Patch Update Pre-Release Announcement - April 2014
ttp://www.oracle.com/technetwork/topics/security/cpuapr2014-1972952.html
Oracle MySQL Server, versions 5.5, 5.6

米国15日(日本16日)
506NAME IS NULL:2014/04/15(火) 07:04:56.00 ID:???
やっとでたか
507NAME IS NULL:2014/04/15(火) 13:57:42.65 ID:???
SQLインジェクション対策したいんですが、

$test = $_GET['data'];

//エスケープ
$test = mysql_real_escape_string($test);

$result = mysql_query("select * from aaa where name = '{$test}'");


このようにmysql_real_escape_stringでエスケープしてれば、SQLインジェクションって防げますよね?
防げない場合どういうパターンがあるのか教えてください
508NAME IS NULL:2014/04/15(火) 17:40:11.51 ID:+eHKgKM6
レプリケーション時に マスターに障害発生したら
スレーブ⇒マスター切り替え はよく目にするんだけど

その後元マスターが復旧したときに
マスター⇒スレーブ を安全におこなう方法がよくわからない
DB起動する前にマスターがいたら云々というバッチを作るの?
509NAME IS NULL:2014/04/15(火) 19:44:51.55 ID:???
>>507
スレ違い
510NAME IS NULL:2014/04/15(火) 21:29:02.65 ID:???
一度死んだ奴をマスタに戻す必要があるのか?
511NAME IS NULL:2014/04/15(火) 21:34:46.75 ID:???
俺が見てるスレだけでも3つのスレでマルチしてるなコイツ
PHPスレで回答もらったっぽいけど
512NAME IS NULL:2014/04/15(火) 21:49:47.80 ID:???
普通にchange masterすればいいんじゃね
posがずれていないかとか、そもそもパラメータがACID特性を満たす設定になっているとか確認すべき項目はあるが
513NAME IS NULL:2014/04/17(木) 16:43:11.04 ID:???
インデックスがかかっているカラムに対してIN句を使って
データを抽出したいと思っています。

WHERE id IN (id1, id2, id3……)

ソースが雑なのと条件が増えた時に遅くなりそうなのでもう少しスマートな
方法はないものかと思っているのですが、いい処理方法はないでしょうか?
514NAME IS NULL:2014/04/17(木) 16:58:02.84 ID:???
id1,2,3はどうやって出してるの?
515NAME IS NULL:2014/04/17(木) 17:15:44.63 ID:???
>>514
それは前画面にチェックボックスがあって、そこでチェックした時にidを仕込んで
次画面でREQUESTから取得して、配列からカンマ区切りにしてid1,id2,id3…としています。

前画面というものが条件に合致したデータを全て表示して、
そこからチェックボックスで選択したものだけに対して、次画面でデータを
再度引っ張ってきてデータ内容の詳細表示をするというような画面になっています。

IN句を使えばできてはいるのですが、何かちょっと…と思いまして。
516NAME IS NULL:2014/04/17(木) 18:37:43.03 ID:???
idを出す手段に規則性が無いならそうやるしかないと思うけど。
517NAME IS NULL:2014/04/17(木) 18:43:34.68 ID:???
>>516
やっぱりそうですかー
このままやることにします。ありがとうございました。
518NAME IS NULL:2014/04/18(金) 16:35:02.33 ID:???
集計のクエリーについて質問です

例えば都道府県の名前をユニークキーとしたマスターテーブルがあり
そのキーを使用したログテーブルがあるとします 訪れた場所[北海道、千葉、東京、千葉、大阪]

それを
北海道 1
千葉 2
東京 1
大阪 1
のように複数レコードで集計したいのですが下記のように書くと

SELECT 県名, count( 県名, ) FROM ログ WHERE ログ.県名 IN ( SELECT マスター.県名 FROM 都道府県 マスター )

最初の県名[北海道]と全ての合計数[5]と1レコードで終了してしまいます
各合計を求めるにはどのようにすればよいでしょうか?

よろしくお願いします
519NAME IS NULL:2014/04/18(金) 16:43:22.48 ID:???
ああ・・・こういう時にGROUP BY を使うのですね
失礼しました
520NAME IS NULL:2014/04/19(土) 14:30:09.16 ID:tdLBPxz0
デフォルトストレージエンジンがMyISAMのままなんだけど
デフォルトストレージエンジンをInnoDBに変更することに
なにかメリットはありますか?

MyISAMは使ってませんがテーブル作るときはちゃんと
InnoDB指定してるから今まで気づかなかったわ
521NAME IS NULL:2014/04/19(土) 14:33:41.09 ID:???
指定しなくてもInnoDBになる
それだけ
522NAME IS NULL:2014/04/19(土) 15:22:42.42 ID:???
最近のバージョンだと、システムのデータベースもInnoDBになるとかなかったっけ
523NAME IS NULL:2014/04/20(日) 15:14:39.65 ID:???
>>521
おうサンキュウ
それくらいしかメリットないなら面倒くさいし放置しとくわ
524NAME IS NULL:2014/04/23(水) 00:42:43.69 ID:???
InnoDBってバックアップ取りにくくていやなんだよな
525NAME IS NULL:2014/04/23(水) 15:26:30.46 ID:???
みんなテーブル名は大文字小文字混ぜてる?
大文字固定? 小文字限定?
526NAME IS NULL:2014/04/23(水) 18:03:58.61 ID:???
何も考えずにSELECTしたときのソート順が
なぜか主キー順になってるんだけど、そういうもの?

以前は適当というか、順保証なんてなかった気がするけど
いつのまにかデフォルトソート順が仕様で決まったとかある?
527NAME IS NULL:2014/04/23(水) 18:20:50.17 ID:???
主キーが連番で、UPDATEしたことが無いテーブルなんだろ
528NAME IS NULL:2014/04/23(水) 19:36:45.32 ID:???
InnoDBでフルテーブルスキャンしたら、主キー順番になるはず
それはInnoDBが行データをクラスタ化インデックスで保持しているから。
MyISAMなら、ばらばらになるんじゃないかな
529NAME IS NULL:2014/04/23(水) 20:58:39.22 ID:???
>>528
そういうことね
InnoDB使うようになって日が浅いから気づかなかったわ
ありがとう
530NAME IS NULL:2014/04/23(水) 22:14:24.98 ID:???
InnoDBの構造上きれいなテーブルなら、上からなめれば主キー順になるだろうけど
それはたまたまたで「主キー順になることは保証しません」ってことでしょ。
531NAME IS NULL:2014/04/23(水) 22:47:36.54 ID:???
まぁ、実務でSELECTする時にORDER BYを付けない
シチュエーションなんてほとんどないからどうでもいい話しだ
532NAME IS NULL:2014/04/24(木) 00:06:22.16 ID:???
>>530
勘弁してくださいよ
533NAME IS NULL:2014/04/26(土) 00:44:05.99 ID:???
事情があり、サーバーマシンのホスト名を変更しました
mysqlでエラーが出ているので調べたところ、
pidファイルにサーバー名が使われていました。
mysql運用中にサーバーマシンのホスト名を変更したため、ファイルが壊れたようです
バッチバックアップでは修復処理も走らせているのですが、それでも修復できていませんでした
こういう壊れ方をしたファイルを修復することはできないのでしょうか?
534NAME IS NULL:2014/04/26(土) 01:46:03.07 ID:???
古いプロセスをkillしてから
myisamchk --safe-recover
したら、エラーなく起動しました
思わぬトラブルで青ざめました
535NAME IS NULL:2014/04/28(月) 13:41:34.40 ID:yPNR6/Ul
InnoDBでファイルコピーのみでバックアップ取りたいけど
どのファイルをコピーしたらいいかな?
536NAME IS NULL:2014/04/29(火) 08:37:28.69 ID:???
/
537NAME IS NULL:2014/05/03(土) 15:09:45.20 ID:???
MySQLモニタ上で

mysql> ほにゃららこまんど
'>

ってなるんですが '> ってどういう時に表示されますか?
またネットで検索するときに「mysql '>」とか検索しても '> が無視されているような感じで
今後自力で検索するときにはどうやって検索すればいいでしょうか?
538NAME IS NULL:2014/05/03(土) 15:22:16.52 ID:???
ほにゃららこまんどの末尾に;を付けてないから
539NAME IS NULL:2014/05/03(土) 15:24:09.03 ID:???
;ついてます(´・ω;;;;;;;;`)

->じゃなくて
'>
540NAME IS NULL:2014/05/03(土) 15:57:25.67 ID:???
select 'ほにゃららこまんど
541NAME IS NULL:2014/05/03(土) 19:02:19.01 ID:???
だな
542NAME IS NULL:2014/05/04(日) 16:24:38.17 ID:???
主キー って「しゅきー」って読みでいいんでしょうか
543NAME IS NULL:2014/05/04(日) 16:58:07.86 ID:???
あるじキー
ぬしキー
544NAME IS NULL:2014/05/04(日) 17:05:32.03 ID:???
だいしゅきぃ
545NAME IS NULL:2014/05/04(日) 19:54:21.39 ID:???
だいちらい
546NAME IS NULL:2014/05/05(月) 11:55:44.80 ID:???
547NAME IS NULL:2014/05/12(月) 20:57:11.88 ID:???
どうしても分からないorz
社内で、情報参照のためにMySQL+PEAR+PHP+Apacheでデータベース作ったんだけど、
これが好評で社外に公表してはどうか、という話があるんだけど、これってどっかに
ライセンス料収めないとあかんの? PostgresSQLなら問題ないという話もあるけど。
WEBブラウドで使うPHPで作ったデータベースのUIが「プログラム」にあたるとすると
GPL汚染されてアウトなんだろうか。こんなんでデータ公開みたいなことになると
正直やってけませんが。別に無料で普通に使い続けていいよね?
548NAME IS NULL:2014/05/12(月) 21:18:11.97 ID:???
MySQL関連だと下記のことをやっていたら、すべてのプログラムのソースコードを公開する必要がある
・MySQLのプログラム自体を改造
・PHPからMySQLに接続する際、libmysqlclientを使用している場合(これは可能性があるって話だったかも)

一つ目は多分していないだろうし、二つ目はPHP5.3以降に組み込まれているmysqlndを使用すれば問題ない。

普通に使う分には問題無いと思うけど、それでも気になるならMariaDBを検討すればいいんじゃね?
549NAME IS NULL:2014/05/12(月) 22:05:23.21 ID:???
え、libmysql 叩いただけでGPL感染するの?
550NAME IS NULL:2014/05/13(火) 00:05:53.73 ID:???
インタプリタによるリンクはNG
動的リンクのみOK

PHP自体もGPLにしなければいけなくなって
Mysqlに除外条項が作られたんだよ
551NAME IS NULL:2014/05/14(水) 12:27:31.73 ID:3pPFWZhr
alter tableで特定のテーブルのcharacter_set_clientを変更することはできますか?
552NAME IS NULL:2014/05/15(木) 00:24:58.72 ID:???
>>551
できます。
553NAME IS NULL:2014/05/15(木) 10:38:18.02 ID:7rqME05r
>>552
ぐぐっても見つけられないのですが
やり方を教えてもらえますか

ちょっと特殊な要件でinsertやupdateは自動変換してほしくて、selectは変換しないでほしいと言った
使い方をしたいのですが
554NAME IS NULL:2014/05/15(木) 12:50:46.89 ID:???
>>553
要件はしらんが、やり方はぐぐってすぐわかるんだが。
ググり方下手なんじゃないの?
555NAME IS NULL:2014/05/15(木) 19:40:14.02 ID:???
>>553
> ちょっと特殊な要件でinsertやupdateは自動変換してほしくて、selectは変換しないでほしいと言った
> 使い方をしたいのですが
そもそもalter tableで解決するの?
保存している文字列自体の文字コードを、character_set_clientを変更することにより自動で変換したいように見える。
もちろんそんなことは出来ないけど。
556NAME IS NULL:2014/05/15(木) 20:27:39.03 ID:???
具体的に言うと、テレビのEPGデータがshift_jisと思われるのですが
海外のソフトを使うとテーブルがUTF8なんで文字化けしちゃうので
EPGテーブルをテーブルにinsertするときに変換して
検索するときにはUTF8で使いたいという内容です
557NAME IS NULL:2014/05/15(木) 21:02:53.84 ID:???
>>556
character_set_clientを変更しても解決しない。
アプリ側で文字列をUTF-8にエンコードするしかないね。
558NAME IS NULL:2014/05/15(木) 21:33:02.27 ID:???
ものすごい初歩的なこと聞いていい?
日付データ的なもので、年と月までのデータがあるんだけど、
これってどうするの? 今はとりあえずテキストで1999年12月
とか入れてあるけど、期間で検索できないから困ってる。
559NAME IS NULL:2014/05/15(木) 21:37:30.35 ID:???
日付に1を入れておく、とか?
560NAME IS NULL:2014/05/15(木) 21:51:48.98 ID:???
カラムの詳細(型とか)と最終的にやりたいことが分からないから答えようがない。
まとまったら
http://toro.2ch.net/test/read.cgi/db/1371476534/
で聞けばいい。
561NAME IS NULL:2014/05/15(木) 21:59:33.80 ID:???
昔の文献のデータベースを作ってるんだけど、
昔の文献には作成年月日が詳細に書かれていないものが多くて、
月までしかわからないものは月までにしておかないと、
詳細に作成年月日がわかっているものと区別がつかなくなる。
それに下手に1日とか15日とか入れちゃうと、期間検索したときに
不都合多そうで。
562NAME IS NULL:2014/05/15(木) 23:17:56.76 ID:???
mysqlだと日付に0入れることが出来るけどね
こんな感じで
insert into dd values ('2014-05-00');
563NAME IS NULL:2014/05/16(金) 04:38:32.72 ID:???
>>561
昔、悩んだことがある。
日だけ別のフィールドを作れば理論的には区別できるけど面倒。

実用的には日まで気にして検索することは少ないので、日が不明なのは15日と仮定し、オリジナルのデータを別フィールドで持つことにした。
564NAME IS NULL:2014/05/16(金) 08:14:30.39 ID:???
>>562
それって言語によって2014-04-30と認識しちゃうとか?
ポスグレ移行も考えてるのでなるべく標準に近いデータにしたい。

どうすりゃいいんだろ。普通に年・月のデータってあると思うんだけど
ググってもわからないし。
565NAME IS NULL:2014/05/16(金) 08:27:04.68 ID:???
え、6桁の数字とか文字にするのはだめなの
566NAME IS NULL:2014/05/16(金) 08:47:37.04 ID:???
うちの音楽DBは不明は1日にしちゃってる
567NAME IS NULL:2014/05/16(金) 13:39:56.94 ID:???
>>565
日付の足し算、引き算の必要がないなら、ストリングでよいですね。
期間指定して検索もできます。
568NAME IS NULL:2014/05/16(金) 15:03:40.33 ID:???
INTEGER でいいじゃんか。
計算も工夫すりゃそのままできるし
569NAME IS NULL:2014/05/17(土) 07:49:28.47 ID:???
>>565
>>568
いやそれだと日付が詳細まで入力してあるのが、、、、、と思ったけど、
10桁の数字にして月までのデータは末尾0000にすればいいのか?
期間検索できるし。日数計算できないけど、それは考えようか。
、、、、、、、とすると、今まで入力した日付データを変換するには、、、、
5000くらいデータあるけど、手修正かorz? 質問してよかったぁ。
数万になってからでは目もあてられんかったorz

数字10桁の期間検索用フィールド入力→日付データに日付型に
変換して入力(月までのデータは適当に)とかかなあ。あー面倒orz。
570NAME IS NULL:2014/05/17(土) 10:15:29.35 ID:???
俺なら精度のカラム作るな
571NAME IS NULL:2014/05/17(土) 10:33:16.95 ID:???
>>569
まあどれがいいかは今後の運用方法によるけど
変換はUPDATE文工夫すれば数十万件なら一瞬だよ
572NAME IS NULL:2014/05/17(土) 12:08:37.27 ID:???
>>570
ぜひ詳しく。

>>571
ですよね〜。SQLおぼつかないから勉強しないと。
573NAME IS NULL:2014/05/17(土) 17:56:26.38 ID:???
>>572
文字型では難しくて、日付型だと簡単なのは、日付の足し算、引き算だけでは?
>>561 の文献データベースなら、日付の足し算とか引き算は

文字型でも期間指定で検索ができるよ。
PubDate >= "1853年07月08日" AND PubDate <= "1854年06月01日"

少し話は違うけど、「嘉永6年」ではなくて「癸丑」と干支だけ書かれた文献もあるよ。
574NAME IS NULL:2014/05/17(土) 17:57:42.50 ID:???
>>573

× >>561 の文献データベースなら、日付の足し算とか引き算は
○ >>561 の文献データベースなら、日付の足し算とか引き算は不要では
575NAME IS NULL:2014/05/19(月) 22:16:03.67 ID:???
(´・ω・`)バックアップ取るとき、default-character-setにbinaryを指定するのって変?
576NAME IS NULL:2014/05/20(火) 13:05:08.37 ID:???
>>575
安全
577NAME IS NULL:2014/05/22(木) 01:44:14.44 ID:???
バイナリーが文字コード依存じゃないからよいのでわー
578NAME IS NULL:2014/05/22(木) 17:52:03.74 ID:???
Mariaさまがみてる
579NAME IS NULL:2014/05/22(木) 22:53:46.84 ID:???
会社でmysql使ってるんだけど
Dumpしたデータをリストアしようとしたら、途中から急にメモリが跳ね上がってサービスが強制終了するんだけどなんで?
どこ調べても解決しない
580NAME IS NULL:2014/05/24(土) 01:04:48.00 ID:???
>>579
インデックスの構築で死んでるのでは?
581NAME IS NULL:2014/05/26(月) 23:37:23.25 ID:???
入門本というか基礎本一冊終わらしたんですが次に買うのにオススメの本はありますか?
582NAME IS NULL:2014/05/27(火) 00:07:18.05 ID:???
本読むのも良いし止めろとは言わないけど、自分で実際にデータ入れて作業してみたら?
そこで、外部制約かけたりとかストアドプロシジャ作ってみるとか

それから自分で出来る言語でDBアプリ作ってみるとか
583NAME IS NULL:2014/05/27(火) 12:57:46.93 ID:???
phpMyAdminでインポートタブのなかのフォーマットの中にCSV load dataみたいな名前のやつがあったのに無くなってしまった
元に戻すにはどうしたらよいですか?
584NAME IS NULL:2014/05/28(水) 01:12:02.68 ID:t9RKPMWp
books テーブル 300万件
1 book_id int(11)
2 book_title varchar(256)
3 deleted tinyint(4)

comments テーブル 50万件
1 comment_id int(11)
2 book_id int(11)
3 comment varchar(256)

で削除されていない本のコメント数を知りたいのですが
SELECT count(*)
FROM comments
LEFT JOIN books
ON comments.book_id = books.book_id
WHERE books.deleted=0
が遅すぎるので早くする方法ありませんか?
もしくは遅い原因など知りたいです。

下のでは物凄く早いのですが。。設定値とか見直すとこや他の件数の出し方あればお願いします。
SELECT comments.comment_id
FROM comments
LEFT JOIN books
ON comments.book_id = books.book_id
WHERE books.deleted=0
585NAME IS NULL:2014/05/28(水) 05:20:49.87 ID:???
>>584
下のが早いならそれでいいじゃん。
count(*)してるからじゃないの?
586NAME IS NULL:2014/05/28(水) 20:51:20.13 ID:???
>>584
books.book_idには主キーかインデックスを作ってあると思うけど、
それを大前提として、それでも遅いならディスクI/Oかなあ。
Linuxならiostat -xm 1 で r/s と %util を見て。Windowsは知らん
587NAME IS NULL:2014/05/28(水) 21:19:12.68 ID:???
>>584
2つのクエリのEXPLAINの結果を張ってくれ
588NAME IS NULL:2014/05/29(木) 00:49:09.08 ID:0XuSN7uc
返信遅くてすみません。

>>585
すみません、上の結果がほしいのです。
というよりは件数がわかればなんでもいいのですが。

>>586
確認してみます。

>>587

上が2.2秒ほどで

id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE comments index book_id book_id 4 NULL 500509 Using index
1 SIMPLE books eq_ref PRIMARY PRIMARY 4 test.comments.book_id 1 Using where


下が0.0027 秒

id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE comments index book_id book_id 4 NULL 500509 Using index
1 SIMPLE books eq_ref PRIMARY PRIMARY 4 test.comments.book_id 1 Using where

上はSending Dataが2秒以上かかっているので
COUNTが原因なのはわかったのですが
JOINすることでtmpテーブルがつくられてしまってなど原因があるのでしょうか
数えたりしてるために遅いのでしょうか?
589NAME IS NULL:2014/05/29(木) 01:34:48.86 ID:???
>>588
プラン同じだね。
下は結果がが50万行出てくるけど、50万行垂れ流すのが0.0027秒で終わるわけがない。
何らかのGUIツールを使っていて、1画面だけ表示、暗黙的にLIMIT 100とかしてない?
つまり上が遅いのではなく、下がインチキしている(最後まで処理をしていない)と言いたい。
プラン見る限り一時テーブルは作ってない。

それで個人的な感想ですけど、50万行の集計が2.2秒というのは「十分に速い」です。
明らかにI/Oはしていない。I/Oしてたら数分かかる。
もっと速くしたいなら前段にmemcachedなどを入れて結果をキャッシュしよう。
590NAME IS NULL:2014/05/29(木) 01:59:43.88 ID:???
あと、メンテナンスがつらくなるのでおすすめはしないけど
テーブルを非正規化してcommentsテーブルにdeletedカラムを入れてもいいと思う。
それで1秒は切れると予想。
591NAME IS NULL:2014/05/29(木) 06:31:55.57 ID:???
>>584
なぜcountなのにgroup byがないのですか?

left join使わず、出力も1行でいいですよね?
592NAME IS NULL:2014/05/29(木) 10:04:08.44 ID:???
>>588
booksにdeleted,book_idの複合インデックスってないのかな?
あとはleftでなくinnerかな。こっちのが普通かと
593NAME IS NULL:2014/05/29(木) 19:32:40.25 ID:???
>>588
ちなみに、count(comments.comment_id)だとどう?
594NAME IS NULL:2014/05/29(木) 21:22:03.18 ID:???
つまり*は重いので、取得は1列。
他は内部結合、インデックスと。
595NAME IS NULL:2014/05/30(金) 00:12:28.93 ID:???
こんなんんで2秒かかってたらPostgreSQLにボロ負けなんで許せません
あっちはハッシュを使ってくるのでどう戦いますかな
596NAME IS NULL:2014/05/30(金) 00:35:43.06 ID:rm2UkD9z
phpmyadmin 使っていて、下は自動でLIMITがかかってるので早いだけのようです。
すみません。

皆さんの意見を参考に下記に書き換えてみたのですが、速度は変わらず。。

SELECT count(comments.comment_id)
FROM comments
INNER JOIN books
ON comments.book_id = books.book_id
WHERE books.deleted=0

id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE comments index book_id book_id 4 NULL 500509 Using index
1 SIMPLE books eq_ref PRIMARY,test,book_deleted PRIMARY 4 test.comments.book_id 1 Using where

もうcountだからこの速度はどうしようもないってことでしょうか。
memcachedなどを使うなど、このSQL以外のとこで速度をあげるようにすべきでしょうか。
597NAME IS NULL:2014/05/30(金) 01:26:26.61 ID:???
> FROM (SELECT books.book_id FROM books WHERE deleted=0)
> INNER JOIN comments USING(book_id)
もEXPLAIN同じだろうし

comments.book_idには既にインデックス付けてるだろうし

↓しかないかも?
ttps://github.com/nekoatcafe/wiki/wiki/MySQL%EF%BC%9Acount(*)%E5%AF%BE%E7%AD%96
598NAME IS NULL:2014/05/30(金) 01:31:03.79 ID:???
>>596
あまり期待しないでほしいのだけれど、テーブル結合順を逆にする案。
大半の本が削除されている(deleted = 0が少ない)場合はこちらの方が速い。

CREATE INDEX books_deleted ON books (deleted);
CREATE INDEX comments_book_id ON comments (book_id)

SELECT STRAIGHT_JOIN COUNT(comments.comment_id)
FROM books INNER JOIN comments ON books.book_id = comments.book_id
WHERE books.deleted = 0
599NAME IS NULL:2014/05/30(金) 09:12:28.43 ID:???
>>596
複合インデックスはあったの?
600NAME IS NULL:2014/06/01(日) 17:38:21.57 ID:otWRvot4
稲城市立向陽台小学校評判
http://tn.en.fishki.net/26/upload/en/201406/01/1273947/uhio5396.jpg
稲城市立向陽台小学校評判
601NAME IS NULL:2014/06/03(火) 18:01:08.24 ID:???
Mysql + HeidiSQLを使って社内でデータ管理をしようと考えています。
データベースを作成し、データを数千件インポートしたところまではよかったのですが
数人で編集した場合に HeidiSQL では排他制御が掛らずに上書きされてしまいます。
HeidiSQL でロックすることは可能でしょうか?
602NAME IS NULL:2014/06/03(火) 19:14:07.28 ID:???
その前に当然のことながらInnodbにしていて、トランザクションはかけていると。だよね?
んでその分離レベルは?
603NAME IS NULL:2014/06/03(火) 20:46:26.79 ID:???
こういうツールは複数人で同時に編集するものじゃないでしょ。
トランザクション使って排他制御したとしても、古いデータを上書きする確率は減らないと思うよ。
604NAME IS NULL:2014/06/03(火) 20:56:08.68 ID:???
selectしてから右クリックして編集押して編集完了して…までずーーーーっとロックしとくの?
アホかよ
605NAME IS NULL:2014/06/03(火) 21:46:26.87 ID:???
DBをweb化して社内でどう活用する予定ですか?
いつ誰がどのくらい処理を発生させるんですか?
phpなどを使わないなら、accessだけで十分では?
606NAME IS NULL:2014/06/04(水) 10:17:45.22 ID:???
601です。皆様ありがとうございます。
まだ勉強不足で質問するのが早かったように思います。
申し訳ありません。

>>602
データタイプはInnodbです。トランザクションに関してはわかりませんので調べてみます。
分離レベルの答えになっていないかもしれませんが、テーブル単位でロック出来ればと考えていました。

>>603
phpMyAdminよりも使いやすいツールを探してHeidiSQLを選びました。
複数人で同時編集には向いていないのですね。

>>605
DBは顧客管理になるのですが、複数の営業所で情報を一元管理するのが狙いです。
更新作業は5〜6人が日に数件ほどかと思います。
accessでは排他制御と矛盾していますが、同時編集が出来ないと聞いていましたので
除外していました、再検討してみます。
607NAME IS NULL:2014/06/04(水) 16:00:44.63 ID:???
管理ツールをみんなでクライアント代わりに使うなんて
共有フォルダにエクセルのファイルおいてみんなで使うようなもんか
608NAME IS NULL:2014/06/04(水) 20:38:33.42 ID:???
ACCESSだと今誰が編集中とか分かるし、時間ずらせば問題はない
ただ負荷がかかるとしょっちゅうファイルぶっ壊れるから正直嫌い
でもすぐ修復できるしバックアップも簡単で使いこなせば便利で安い
もしぶっ壊れるなら、PHPとかで外注がいい、その程度なら多分安いよ
もしくはGUI内製、簡単だよ、プログラム多少分かる人いればすぐ作れる


そういやinnodbで「where句なしcountがクソ遅い」問題どうなったかな?
本来WHERE句省けるところ、GROUP BYさせてWHERE句つけても結局遅いのかな
609NAME IS NULL:2014/06/05(木) 10:05:56.79 ID:???
みんなで編集はGoogleDocsまじおすすめ
610NAME IS NULL:2014/06/05(木) 10:22:27.03 ID:???
>>608
countが遅いって何?
611NAME IS NULL:2014/06/10(火) 01:13:53.01 ID:???
>>610
innodbのcountは遅いんだよ
612白バラ十字軍:2014/06/10(火) 15:47:48.99 ID:gr7v9uKn
今では殺人事件凶悪事件が起こると創価員かというぐらい
ネットではささやかれる時代になりました。刑務所受刑者の33%は創価員という事実は有名な話ですが、以下を見れば納得ができます

創価員が裁かれる    判決の際 法廷にこだまする「 池 田 先 生 万 歳 !」
◎以下これ以外にまだまだ創価員の犯罪多数あり、書類送検されていないだけであなたの街でも多数すさまじい事件の数が
発生しましたし、まだまだ毎日のように創価員による凶悪事件は発生しているのです!
しかもこれ以外にもTVでも報道された凶悪事件多数あり!。あなたの周りにも潜んでいる。
危険です。危機的状況です。酒鬼薔薇だけではありません。実にたくさんいるのです
あなたの街でも善良な人間のように取り繕い潜んでいるのです。

●宅間守(在日)→大阪 附属池田小学校児童殺傷 創価学会員。大量殺人犯 。8人殺害 15人が重軽傷。悪徳 朝鮮人部落出身。
(悪徳カルト)両親も創価学会員。獄中結婚したが相手の女も創価員。さすが創価員は悪徳な者を好む。あえて結婚する
とは殺人破壊者を賛美、美化、擁護する行為 2004年死刑執行 獄中結婚した女は慰謝料損害賠償払ったのか?被害者に詫びたのか?
宅間は被害者に詫びていない。つまり・・・判決の際 法廷にこだまする「 池 田 先 生 万 歳 !」ということ
日本の犯罪史上、稀に見る大事件
●畠山鈴香 (在日)→秋田県児童連続殺害事件 創価学会員。悪徳。(悪徳カルト)
●斉藤勇太 →JR取手駅前バス無差別殺傷事件 創価学会員。悪徳。(悪徳カルト)
●酒鬼薔薇聖斗→ 東慎一郎(在日)神戸の首切り魔で酒鬼薔薇聖斗 創価学会員。神戸の首切り魔。生首を校門に飾る。悪徳2人殺害。
元在日朝鮮人。両親も創価学会員(悪徳カルト)
●福田孝行(在日)→山口県母子殺害 殺害後屍姦、乳児も殺害 創価学会員。悪徳(悪徳カルト)
●阿部隆 →長野母子バラバラ殺人事件(平成元年)船橋市幼児バラバラ殺人事件 千葉県船橋市の熱心な創価学会員・A・A子さんと長男
のHちゃんが、同じく学会員である夫のA・Tに殺された。動機は生活苦。バラバラにされた死体が聖教新聞に包まれ、長野県の山中に捨
てられていた 悪徳(悪徳カルト)
613NAME IS NULL:2014/06/10(火) 16:53:41.37 ID:???
おまえさんはどこのカルトだい
614NAME IS NULL:2014/06/11(水) 20:18:55.26 ID:???
cakephpからDBへの値の送り方がわからない
615NAME IS NULL:2014/06/11(水) 20:34:08.59 ID:???
まずマルチやめろや
616NAME IS NULL:2014/06/14(土) 10:30:07.13 ID:???
すごい前のレスだけど
直接物理バックアップ取るなら隠しフォルダのprogramData内にMysqlのフォルダがあるのでその中のdataフォルダをコピーすればいい。ただし、MySQL止めた状態で。
ぐぐれば詳細出てくるはず。
617NAME IS NULL:2014/06/15(日) 23:00:32.66 ID:???
ENUM型を使う場合、予め明確に列挙された許容値リストを作ってテーブルを
作るみたいだけど(これはSET型も同じみたいだけど)、リストを拡張したい
時ってどうするんですか?

alterでその都度追加(出来るんですか)?
618617:2014/06/15(日) 23:38:13.08 ID:???
CREATE TABLE testenum(
id int primary key,
col ENUM('red','blue','yellow')
);

mysql> insert into testenum(id,col)
-> values(4,'black');
ERROR 1265 (01000): Data truncated for column 'col' at row 1


alter table testenum modify column
col enum('red','blue','yellow','black');

mysql> insert into testenum(id,col)
-> values(4,'black');
Query OK, 1 row affected (0.00 sec)


で、出来ました^^;
619マッチ棒:2014/06/18(水) 15:28:57.11 ID:???
こんにちは質問です
mySQLのテーブルに、Excelのように計算式をもった列はやれますか。
たとえば売上フィールドと原価フィールドをもとに、粗利フィールドには自動で値がセットされるようにしたいのです。
Web画面に表示するときにそのつど計算させると重くなるので、テーブルに持たせたいのです。
620NAME IS NULL:2014/06/18(水) 15:31:07.20 ID:???
君日本語怪しいけど大丈夫?
621マッチ棒:2014/06/18(水) 17:21:35.37 ID:???
まあそう言わんと
622NAME IS NULL:2014/06/18(水) 17:39:58.59 ID:???
>>619
 INSERT/UPDATE時に計算結果を書き込むのではダメ?
623NAME IS NULL:2014/06/18(水) 17:46:04.47 ID:???
いや普通に演算子使えるだろ
SELECT 売上-原価 AS 粗利 FROM 商品 WHERE 商品id=1;
ってことだろ?
624NAME IS NULL:2014/06/18(水) 17:47:03.29 ID:???
この程度の計算で重くなるとか何を考えてるのかわからない
実際に測ったの???
重くなるのが嫌なら全パターンのhtml用意するしかないね
625NAME IS NULL:2014/06/18(水) 18:12:09.34 ID:???
Excelのイメージでやりたいなら、計算式付きのSELECT文をVIEWにすることだろうな。
計算のタイミングは取得時でかわらんけどな。

どうしても格納時にやりたいけど、INSERTやUPDATE文に入れられないならトリガという手もある。
626マッチ棒:2014/06/18(水) 18:27:40.01 ID:???
こんばんは。
表示するときに動的にクリエーするのが一般的なんでしょうか
ご意見ありがとうございます
627NAME IS NULL:2014/06/18(水) 18:46:00.90 ID:???
まず日本語マスターしてきてくれ
628マッチ棒:2014/06/18(水) 19:26:59.35 ID:???
まあそう言わんと
629NAME IS NULL:2014/06/18(水) 20:48:52.88 ID:???
>>627
クライアント(プログラム)側でやるという手もあるにはある。
たとえば、クライアントがブラウザならJavaScriptで。

ただし、クライアントで計算させることの危険性については、考えないといかんけど。
630NAME IS NULL:2014/06/18(水) 20:54:42.51 ID:???
2つ値を送信するコストと
ただ引き算するだけのコストと
どっちのほうが大きいか

まあ、どっちも何の支障もないレベルだけど
そんな小さい小さい事考えるよりお前の汚いソース最適化しろ
631NAME IS NULL:2014/06/21(土) 11:36:02.31 ID:???
libmysqlclient.soを利用したアプリのライセンスは
オープンソースのライセンスにしなければいけないと聞いたのですが本当ですか?
632NAME IS NULL:2014/06/21(土) 12:14:00.93 ID:???
>>631
本当です。
MariaDB Client LibraryならLGPLだから、こっちを使えばいいよ。
https://mariadb.com/kb/en/mariadb-client-library-for-c/
633マッチ棒:2014/06/21(土) 12:30:35.37 ID:???
>>619の件ですけど
結局mysql側ではそういう機能ないのですかね
要は、売上額が変わっても、外注額が変わっても、自動で粗利額が変わりたいです。
レコード編集時にアップデート計算するのが普通ですけ
634NAME IS NULL:2014/06/21(土) 14:05:08.22 ID:???
select 単価 , 数量 , 単価 x 数量 as 売上金額 from 〜
で何がダメなのか教えて
635NAME IS NULL:2014/06/21(土) 14:05:28.10 ID:???
>>633
>>625 でトリガを使えばできるって書いてあるでしょ
636634:2014/06/21(土) 14:06:55.80 ID:???
真面目に読んで無かったんで取り消し w
637NAME IS NULL:2014/06/21(土) 14:20:31.64 ID:???
>>632
ありがとうございます
LGPLなら利用するだけならライセンスを縛られないのですね

mysqlのapiと互換性があるmariadbのクライアントライブラリを
利用する方法があるとはしりませんでした

mysqlの昔のLGPLの頃のコードと
phpのmysqlクライアントのソースから作ってるんですね

あとはlibmysqlclient.soの変わりにうまく使わせられればいい感じですね
ありがとうございます
638NAME IS NULL:2014/06/21(土) 15:52:34.92 ID:???
(´・ω・`)redhatもmariadbにしたんか
639マッチ棒:2014/06/21(土) 16:31:34.80 ID:???
こんにちはいつもありがとうございます。
案件一覧テーブルと、仕入一覧テーブルがあって
案件IDと引当IDをヒモヅケして集計しようとしています
一つの案件に、複数の仕入があります
さて、どうしたらいいんでしょうか

追伸
>>633の件は、レコード編集時にそのつどクリエーすることで解決しました
640マッチ棒:2014/06/21(土) 16:35:15.12 ID:???
いま思いつく方針は、JOINくで案件ごとの仕入合計を計算済みのテーブルをつくり、
その後SELECT SUMで合計しなおすことです
けど全くやりかたがわかりませんね
641マッチ棒:2014/06/21(土) 17:52:41.92 ID:???
うまくいきましたありがとうございます
642マッチ棒:2014/06/21(土) 17:54:19.43 ID:???
案件の締め切り管理と、外注費の管理をしたいのですけど、
カスタマイズが簡単なフリースクリプトはありませんか?
643NAME IS NULL:2014/06/21(土) 18:45:52.25 ID:???
Excelでやれ
644NAME IS NULL:2014/06/21(土) 19:57:34.55 ID:???
日付でSELECTしたいんだが下記まではうまくいくが

SELECT * FROM test WHERE uriDay BETWEEN "2014-05-01" AND "2014-05-31";

この日付指定2カ所を変数で渡したいんだよ
フォームの値を入れたいわけ
けどどうしてもうまくいかん
日付が数値として処理されてるのかな
誰かサンプルを提示してくれないけ
645NAME IS NULL:2014/06/21(土) 20:34:38.49 ID:???
>>644
よくやる間違いだが、sql文には日付の引用符が必要だぞ
引用符つきでストリングを渡すか、sql側に引用符をつけておく
646645:2014/06/21(土) 20:46:21.75 ID:???
>>644
つまりこんな感じ

'SELECT * FROM test WHERE uriDay BETWEEN "'.$fromDate.'" AND "'.$toDate.'"';
647NAME IS NULL:2014/06/21(土) 20:56:27.57 ID:???
>>646
648NAME IS NULL:2014/06/21(土) 21:31:51.59 ID:???
>>644
該当の言語スレで聞いたほうがいいな。
内容はもっと詳細に書いた方がいい。
最低限いるのは言語名(該当言語スレに行くならいらない)と処理に失敗するコードの内容。
あと>>645->>646のことは忘れろ。
649644:2014/06/21(土) 22:39:55.15 ID:???
>>646
できましたありがとう
650NAME IS NULL:2014/06/21(土) 23:03:32.15 ID:???
PHPがなぜクソと言われるのか、その一端が分かる流れだと思いました(小並感)
651NAME IS NULL:2014/06/21(土) 23:14:46.02 ID:???
PHPのdate関数で、3/31の1ヶ月前が3/3になってブチ切れた事あるわ
mysqlのdate_add、date_subはちゃんと2/28を返すのに
652NAME IS NULL:2014/06/21(土) 23:33:30.95 ID:???
date関数はそういう用途で使うものじゃないから。
別にそういう風にできる関数や、日付を取り扱うクラスが用意されている。
スレチだから詳細は書かないけど。
653NAME IS NULL:2014/06/21(土) 23:57:17.45 ID:???
全世界で、秒針がゼロを指すのは同時なんでしょ
どういうことなの
654NAME IS NULL:2014/06/22(日) 15:54:30.59 ID:???
>>649
SQLインジェクションはちゃんと対策してくれよ

>>652
DateTime::addとかがそういう仕様だよ
655NAME IS NULL:2014/06/22(日) 16:17:44.52 ID:???
すみませんがお助けください
この画像のように、2つのテーブルがあり、左の案件1つにつき複数のコストがあります。
そのコストを引き当てIDにもとづいて合計して案件テーブルに格納したいです。
よろしくおねがいします

http://i.imgur.com/4wZKQIM.jpg
656NAME IS NULL:2014/06/22(日) 16:28:58.89 ID:???
SELECT t1.案件,COLLAPSE(SUM(t2.金額),0) FROM 案件 AS t1 LEFT OUTER JOIN コスト AS t2 ON t1.ID=t2.引当ID GROUP BY 引当ID

テストはしてない
657NAME IS NULL:2014/06/22(日) 16:30:39.75 ID:???
格納か
適宜INSERTなりUPDATEなり書き換えてくれ
658655:2014/06/22(日) 17:20:28.74 ID:???
>>657
格納じゃなくていいです
目的のテーブルがえらるれば
659NAME IS NULL:2014/06/22(日) 18:46:44.57 ID:???
>>656
うーん、なぜかエラーが出てしまう。
僕が意味を理解できていないので、エラー内容もわけがわからない
660NAME IS NULL:2014/06/22(日) 18:50:05.48 ID:???
>>659
俺らは理解できるから、ちょっとエラー内容教えてみ
661655:2014/06/22(日) 19:05:00.96 ID:???
FUNCTION db.COLLAPSE does not exist
とかいろいろエラーが出ます
662655:2014/06/22(日) 19:05:50.85 ID:???
なおphpMyadminのクエリ欄で試している状況です
663NAME IS NULL:2014/06/22(日) 19:31:35.64 ID:???
collapse() って何ですか?
664NAME IS NULL:2014/06/22(日) 20:06:53.27 ID:???
ごめん656だけど
COALESCEだったわ
全然違うわ
一から出直す…
665NAME IS NULL:2014/06/22(日) 20:34:15.34 ID:???
ごじょういって、攘夷のこと?
666NAME IS NULL:2014/06/22(日) 20:59:47.04 ID:???
書き込むスレ間違えてた……
667655:2014/06/23(月) 00:39:24.54 ID:???
>>655ですけど
現状、下記のクエリでかなり近いところまできました

SELECT t1.anken , SUM(t2.金額) FROM t1 ,t2 WHERE t1.id = t2.引当id GROUP BY t2.引当id

ただし、金額がゼロの案件が表示されないです
ひきつづきアドバイスよろしくおねがいします
668NAME IS NULL:2014/06/23(月) 00:59:52.43 ID:???
>>667
COALESCE
669NAME IS NULL:2014/06/23(月) 07:25:03.41 ID:???
COALESCEでNULLを0に変換するのも必要だけど
まず>>656が外部結合で例を示してるのにそれ自分で外しちゃってるから
670655:2014/06/23(月) 12:53:17.95 ID:???
いまさら聞きにくいことなんですけど、
SELECTで合成されたテーブルは、実体はあるんですか?
そのテーブルに対しさらにクエリできますか
またそのテーブルはいつまで存在してるのでしょうけ?
671655:2014/06/23(月) 14:17:08.66 ID:???
たびたびお世話になります
あらためて整理して見ました
この画像のように2つのテーブルを合成したいです。
ご指導もらったコレラセでやると、コストの登録のないものが表示されません。
コストテーブルにないものは0と表示したいです。案件テーブルにある件数すべてが表示されたいということです。
よろしくご指導おねがいします
672655:2014/06/23(月) 14:17:48.52 ID:???
http://i.imgur.com/mpEF3Mg.jpg
画像はこれです
よろしくおねがします
673NAME IS NULL:2014/06/23(月) 14:41:01.10 ID:???
>>670
SQL view でググって勉強されたらいかが?
674NAME IS NULL:2014/06/23(月) 15:53:27.51 ID:Na+XSE7A
>>656の関数名の間違いだけなおしたらいけるんじゃねーの?
なんで無視してるの?
675NAME IS NULL:2014/06/23(月) 16:13:26.93 ID:???
>>671
仕事か学校の課題か知らないが、
一度データデースの入門書でも読んだ方がいい。
676NAME IS NULL:2014/06/23(月) 16:16:21.85 ID:???
実体を残せるのはテンポラリテーブル
ttp://logic.moo.jp/data/archives/11.html

UPDATE JOIN GROUP BY でググれば一発だが
まず LEFT JOIN が分からんとどうにもならん
677655:2014/06/23(月) 17:26:10.97 ID:???
>>674
すみません>>671で報告したように、コスト一覧に対応がないものつまりコスト0の案件がリストアップされないのである
678655:2014/06/23(月) 17:27:12.90 ID:???
なんだかんだ言って、誰もやれないのかな?
679NAME IS NULL:2014/06/23(月) 17:28:54.98 ID:???
お前が勝手にLEFT JOIN外したからじゃん
680655:2014/06/23(月) 17:36:42.58 ID:???
じゃあ>>656で出来るといいたい?
681655:2014/06/23(月) 17:56:16.15 ID:???
結局、自力でやれました

SELECT anken.id,anken.anken_name,COALESCE(SUM(cost.cost_gaku),0)
FROM anken
LEFT JOIN cost
ON anken.id = cost.rel_id
group by anken.id

ちみらほんとに使えないインターネッツやな
682NAME IS NULL:2014/06/23(月) 18:06:49.24 ID:???
>>681
>>656と同じものにたどり着けたね。おめでとう
683NAME IS NULL:2014/06/23(月) 18:49:32.38 ID:???
何がしたかったんだコイツ
684NAME IS NULL:2014/06/23(月) 18:50:14.83 ID:???
>>681
答えが殆ど出ていたにもかかわらず正答に辿り着くまで時間がかかったとはいえなんとか解決できてよかったね。
おめでとう。
685NAME IS NULL:2014/06/23(月) 19:41:27.82 ID:???
>>655ってどう見ても>>626>>639のマッチ棒だよな?
クリエーとか言ってるし…
686NAME IS NULL:2014/06/24(火) 01:36:06.69 ID:???
マッチ棒wwww
687NAME IS NULL:2014/06/24(火) 09:56:22.79 ID:???
クリエーってその場だけのタイプミスじゃなかったのか、、、w
688NAME IS NULL:2014/06/24(火) 11:30:39.95 ID:U+KduEjR
◎2chスレッド勢いランキングサイトリスト◎

★+ニュース板
・ 2NN (推奨サイト)
・ 2chTimes
★+ニュース板新着
・ 2NN新着
・ Headline BBY
・ unker Headline
★+ニュース板その他
・ Desktop2ch
・ 記者別一覧
★全板
・ 全板縦断勢いランキング (推奨サイト)
・ スレッドランキング総合ランキング
・ ログ速
★全板実況込み
・ 2勢 (推奨サイト)
・ READ2CH
・ i-ikioi

※ 要タイトル検索
※ 2chブラウザ併用推奨
689NAME IS NULL:2014/06/24(火) 15:33:47.11 ID:???
セレクトの結果、何もヒットしなかった場合、フェッチアソック時にエラーが出てしまうのをなんとかしたい。
よろしくお願いします
690NAME IS NULL:2014/06/24(火) 15:53:06.98 ID:???
ここはMySQLのスレ。判ってますか?
691NAME IS NULL:2014/06/24(火) 15:58:32.03 ID:???
そんなもん結果行数数えて0ならFetchしないようにしろよ
そもそも何?その欠陥ラッパ
692NAME IS NULL:2014/06/24(火) 16:07:00.31 ID:???
mysqlといえばphpか
693689:2014/06/24(火) 16:33:27.73 ID:???
たしかに、PHP側の問題でした
mysql_queryで結果がヌルなのでそのエラーになるようです
けどげせないのは、いままで結果がカラでもエラーは出ていなかったんですよ
条件追加したらこうなったのである
694NAME IS NULL:2014/06/24(火) 16:37:17.69 ID:???
>>693
mysql_queryは非推奨だよ

nullを利用する部分を書き間違えてるんでしょ
phpの問題というよりプログラムの問題でしょ
695NAME IS NULL:2014/06/24(火) 16:39:31.06 ID:???
しかも情報小出しとかw
696689:2014/06/24(火) 16:59:08.45 ID:???
まあそう言わんと
697NAME IS NULL:2014/06/24(火) 18:50:58.72 ID:???
マッチ棒専用の託児所じゃねーぞここは
698マッチ棒:2014/06/24(火) 18:58:28.65 ID:???
いえ、気にせず他の方も質問してください。
僕もわかる範囲でアドバイスしてあげます
699NAME IS NULL:2014/06/26(木) 00:21:00.68 ID:???
>>698
あなたの「わかる範囲」を教えて!
700NAME IS NULL:2014/06/26(木) 09:21:06.61 ID:???
>>699
託児ありがとうございます。
701マッチ棒:2014/06/30(月) 14:44:00.58 ID:???
こんにちはいつもありがとうございます
さくらインターネットで、ムーバブルタイプのブログが8年ほど前からやってまして
mySQLを使ってるようですが
さくらインターネットのライト契約なのでmySQLは使えないらしいんですよ
これはどういうことでしたか
702NAME IS NULL:2014/06/30(月) 14:50:29.57 ID:???
>>701
さくらのサポートにでも聞いてくれ
703マッチ棒:2014/06/30(月) 14:54:21.40 ID:???
いまよくみてみたらどうやらSQLiteを使ってるようです
いまいち納得できないけど
704NAME IS NULL:2014/07/01(火) 16:55:46.29 ID:???
そうですか
705ポンプ:2014/07/01(火) 16:59:47.33 ID:???
消してあげよう
706NAME IS NULL:2014/07/01(火) 17:09:00.49 ID:???
movableTypeはインスコ時に、MySQLかSQLiteかを選択できるんだよ
707NAME IS NULL:2014/07/02(水) 21:25:54.09 ID:???
質問させて下さい。mysql5.1を使っています。

dumpファイルの復元を行っているのですが、復元できません。また復元されたことを確認する方法も分かりません。

コマンドプロンプトからmysql5.1に入り、binの下で、「mysql -u ユーザー名 -pパスワード DB名 <dumpファイル名」では復元できないのでしょうか。

ご教示頂ければ幸いです。よろしくお願いします。
708NAME IS NULL:2014/07/02(水) 22:45:43.71 ID:???
外部制約は?
709707:2014/07/02(水) 23:12:30.85 ID:???
外部制約とは何ですか?

初心者なもので…申し訳ありません。
710NAME IS NULL:2014/07/02(水) 23:27:09.34 ID:???
>>709
小さめのdatabaseとtableを作成して、dumpしてみる。
MySQL monitorを起動して、
source dumpfile ってやってみる。
エラーが出たらその原因を調べる。
711707:2014/07/04(金) 22:51:14.89 ID:???
>>710
レスが遅くなりました。解決しました。ありがとうございます!
712NAME IS NULL:2014/07/06(日) 21:16:06.41 ID:59xYQ0EB
質問に対して、複数の回答コメントがつく設計で
回答コメント数順のデータをとりたいのですが
データ数が多いと1秒くらいかかってしまいます。
Using temporary; Using filesort;
が出てしまっているのでこれをどうにかすれば早くなりますか?

CREATE TABLE `question_comment` (
`comment_id` int(11) NOT NULL AUTO_INCREMENT,
`question_id` int(11) NOT NULL,
PRIMARY KEY (`comment_id`),
KEY `book_id` (`question_id`)
)

SELECT question_id,
COUNT(*) AS cnt FROM question_comment
GROUP BY question_id
ORDER BY cnt DESC

explain 結果
1 SIMPLE question_comment index NULL book_id 4 NULL 500537 Using index; Using temporary; Using filesort
713NAME IS NULL:2014/07/06(日) 21:57:34.32 ID:???
>>712
劇的に速くする方法はない。

1時間に1回程度このクエリを実行して、結果を別のテーブルに保存する。
それでユーザにはその集計済みの結果を見せるというのがセオリー。

ニコニコ動画のランキングとかも1時間に1回更新でしょ。
それと同じ。
714NAME IS NULL:2014/07/07(月) 18:35:00.18 ID:???
>>712
book_id インデックスを総なめする必要があるから、どうしても時間がかかってしまう。
Using temporary; Using filesort; はインデックスを走査した結果を集計しているだけだから時間の割合は少ないと思う。
>>713 みたいに定期的に集計するか、カウント用のテーブルを作ってプログラム側でカウンタを回すとかするしかない。
(book_id が楽々全部乗るくらいキャッシュメモリ積めば早いけど)
715NAME IS NULL:2014/07/07(月) 22:09:47.53 ID:abW3QXYB
>>713
>>714
ありがとうございます!参考にします!!

Using temporary; Using filesort; が遅いわけではないんですね。。

楽々全部乗るくらいキャッシュメモリがあればとありますが、
設定値の変更はどこになりますか?
716NAME IS NULL:2014/07/07(月) 22:57:00.39 ID:???
クエリキャッシュについて
機能が有効かどうかの確認

SHOW VARIABLES LIKE 'have_query_cache';
"YES"なら有効

システム変数の設定
query_chache_size 41984以上 単位はbyte 0を設定すると無効に
query_chache_type 1(ON) or 2(DEMAND)
0(OFF)を設定すると無効に
1 SQL_NO_CACHEオプション付きのSELECT文を除く
すべての結果をキャッシュする
2 SQL_CACHEオプション付きのSELECT文のみキャッシュ

SHOW VARIABLES LIKE 'query_cache_%e';
717NAME IS NULL:2014/07/07(月) 23:44:10.56 ID:???
これsort部分のが時間かかってるっしょ
質問1個に平均20とかコメントついてるなら別だけどさ

sort_buffer_size
を増やすことでUsing temporaryを消せれば
改善するかもな
718NAME IS NULL:2014/07/08(火) 21:31:09.45 ID:???
GROUP BY したあと、違うカラムで ORDER BY してるんだから
Using temporary になるんじゃないの?メモリサイズ不足じゃなくて。

>>715
ちなみに最後に LIMIT 0,1 をつけると早くなります?
719NAME IS NULL:2014/07/10(木) 11:19:53.06 ID:UaAE594X
mysqldumpコマンドで、valueリストを1つずつ改行して出力する方法を教えてください

INSERT INTO `tablename` VALUES ('001','name1'),('002','name2'),('003','name3');
ではなく
INSERT INTO `tablename` VALUES
('001','name1'),
('002','name2'),
('003','name3');
のように出力したい
720NAME IS NULL:2014/07/10(木) 12:11:56.75 ID:???
CSVエクスポートしたいってならこういうサイトが見つかったけどな

MySQL mysqldump+αでExcelで読めるCSV出力CommentsAdd Star
http://d.hatena.ne.jp/deeeki/20100720/mysqldump_csv_sjis
721NAME IS NULL:2014/07/10(木) 13:40:40.78 ID:???
>>719
extended-insert=FALSE
つけてみて
722NAME IS NULL:2014/07/10(木) 14:03:22.55 ID:UaAE594X
>>721
--extended-insert=falseとすると
INSERT INTO `tablename` VALUES ('001','name1'),
INSERT INTO `tablename` VALUES ('002','name2'),
INSERT INTO `tablename` VALUES ('003','name3');
となりました
これはこれで意図するものに近いかなという感じです
723NAME IS NULL:2014/07/10(木) 14:18:29.88 ID:???
sed とかエディタの置換併用はだめなんかの?
724NAME IS NULL:2014/07/10(木) 14:45:24.14 ID:UaAE594X
1つのテーブルに結構な量のレコードが格納されていて、
エディタだと開けない場合があるので、mysqldumpオプションで対応できるものが
存在しているかどうかについて知りたいというのがメインでした
sedとか使うのも試してみます
ありがとうございました
725NAME IS NULL:2014/07/10(木) 21:23:07.70 ID:???
インデックスの貼り方がイマイチわからないんです。
createdという作成日を保存するフィールドがあります。
これを元にソートする、ただしwhereによる絞り込みはしない場合はcreatedにもインデックスを貼るべきですか?
726NAME IS NULL:2014/07/10(木) 22:01:49.27 ID:???
クエリの内容と、頻度によるとしか・・・
727NAME IS NULL:2014/07/10(木) 23:18:12.81 ID:fsYbcw2v
>>718
返信遅くなりました!
LIMIT 0,1 つけても変わらずです!
728NAME IS NULL:2014/07/13(日) 01:35:26.14 ID:sEAPG4oI
http://dev.mysql.com/doc/refman/5.1-olh/ja/timestamp.html
上記のサイトに、
TIMESTAMP 型の値は、格納するときに現在のタイムゾーンから UTC に変換され、取り出すときに UTC から現在のタイムゾーンに変換されます。
と書かれているのですが、
TIMESTAMPを取り出す際に、現在のタイムゾーンではなく、UTCとして取得する方法はありませんでしょうか?
SET SESSION time_zone = '+0:00';
を実行しても無理でした。
ご存知の方いらっしゃいましたら教えてください。お願いします。
729NAME IS NULL:2014/07/13(日) 03:08:28.30 ID:???
SET SESSION time_zone = '+0:00';
で、できたんだけど何が違うんだろう
730NAME IS NULL:2014/07/18(金) 00:40:27.14 ID:???
覚悟が違う
731NAME IS NULL:2014/07/20(日) 10:15:01.88 ID:???
732NAME IS NULL:2014/07/20(日) 17:48:38.11 ID:???
>>731
wikipediaを参照して、引用元を読まない奴が多すぎるよな

> The use of MySQL is expected to decline from 82.1% of the 347 respondents today as 78.7% expect to be using it in 2011, declining to 72.3% 2014.

って書いてあるのに
733NAME IS NULL:2014/07/22(火) 20:13:10.72 ID:???
PHPのmysqliクラスを使ってSQLの命令を実行する場合について質問させてください。

ローカル環境ではきちんと動いていたphpが、ロリポップのサーバーにアップロードすると、
SQLをクエリする部分でエラーが出てしまいます。

ロリポップのphpMyAdminを開いたときに表示されるページの「Webサーバ」という欄に、
・PHP 拡張: mysql
と書かれているのですが、これは関係ありますでしょうか?

ロリポップの設定画面から、
「Webツール」→「PHP設定」のところで全で、phpのバージョンを5.2から5.4に変更し、
10分待っても、この「PHP 拡張: mysql」の表示は変わらないままです。

ちなみに、ローカル環境でのphpMyAdminの表示は、
PHP 拡張: mysqli
になっています。

どうすれば、mysqliでクエリできるようになるか、ご存知の方いらっしゃいましたら教えてください。お願いいたします。
734NAME IS NULL:2014/07/22(火) 20:26:38.55 ID:???
>>733
ロリポップにmysqli入ってないんじゃないの?
phpinfo();で調べたら?
入ってない場合、手動でインストールできるかはわからんが。
何せレンタルサーバーだからね。
735733:2014/07/22(火) 22:22:55.31 ID:???
いま、phpinfo();で調べてみたんですが、
「MysqlI Support enabled」と出ます。
やはり、myqliクラスは使えるようになってるんですね。
あと、mysqliのコンストラクタを使用した時にデータベースへのログインも出来てるようです。
でも、サーバーにアップロードすると、ローカル環境で正常に動いていたquery()メソッドで、エラーが出てしまうみたいです。
他に何か問題点として考えられる事はありますでしょうか?
736NAME IS NULL:2014/07/22(火) 22:47:55.35 ID:???
エラーの内容を貼れよ
737NAME IS NULL:2014/07/23(水) 01:34:40.28 ID:???
mysqliで接続できなかったらquery以前、つまりconnectの段階でつまずいていると思うんだけど。
738NAME IS NULL:2014/07/23(水) 02:09:31.71 ID:???
MySQL5.5.33です。
どんなキーワードでググるべきかも分からないので教えて下さい。
以下のテーブルがあるとします。

3,渡辺
2,井上
1,田中

LOAD DATA INFILEで、5と4を記述したcsvファイルをインポートしました。
すると下に追加されて32154となるのですが、
このように上に追加するにはどうしたら良いでしょうか。

5,山田
4,鈴木
3,渡辺
2,井上
1,田中
739738:2014/07/23(水) 02:10:49.80 ID:???
すいませんスレ間違えました。無視して下さい。
740NAME IS NULL:2014/07/23(水) 02:14:42.45 ID:???
>>738
selectするときにorder byで並び替えて取得する。
データ構造的にそうしたいという意味で聞いているのなら無理。というか無意味。
741NAME IS NULL:2014/07/23(水) 10:04:26.76 ID:???
どこのスレ行ったんだろうな。
どこ行っても同じこと言われると思うが。
742NAME IS NULL:2014/07/23(水) 20:23:51.85 ID:???
>>738
既存のテーブルをdumpして、cat 5,4のcsv dump > aaa

load data infile aaa into table XXX

5と4のcsvが
4
5
の順で書かれてるならしらん
743733:2014/07/24(木) 21:19:12.36 ID:???
すみません、原因がわかりました。
データベース名に"-"が含まれていることが原因だったみたいです。
データベース名を"`"で囲むと、正常にクエリすることが出来ました。
質問に答えて下さった方々、ありがとうございます。
744NAME IS NULL:2014/07/24(木) 22:14:40.88 ID:???
もしかしてコボラだったの?
745NAME IS NULL:2014/08/05(火) 18:22:04.34 ID:???
質問なんだが、1テーブル内にずらっと何万何千と記録するのと、
テーブル別に分散させるのとでは速度とかに差は出てくるものなのか?
会員登録系のサイトを作ってるんだが、まとまったグループ内のコンテンツが登録されるのを踏まえると
SQL文で分岐するよりもはなからテーブルで分けたほうがいいのか迷ってるんだが・・・
746NAME IS NULL:2014/08/05(火) 19:03:26.26 ID:???
何万くらいじゃ心配いらん
747NAME IS NULL:2014/08/05(火) 20:09:16.09 ID:???
1行が1KBだとしても、1万行で10MB程度。
ゴミでした。
748NAME IS NULL:2014/08/05(火) 22:07:07.02 ID:???
じゃあ遠慮無く1テーブルで管理するわ。
データベースの種別とかで調べてたら速度云々で色々と描かれてるのを見て不安になってたんでな。
749NAME IS NULL:2014/08/05(火) 23:12:41.07 ID:???
データの入れ物や、データ出し入れする行為を意識しなくてよいのがDBMSのよいところの一つなのに、
それを分割してわざわざプログラム側で入れ物を区別するのも滑稽でしょ。
億・兆オーダーになったら、パーティションを検討してみるのがいいと思う。
750NAME IS NULL:2014/08/06(水) 10:45:23.80 ID:???
上記関連事項について質問させてください。
現在、80万レコードで90MBほどのテーブルがあり、一箇月に10万レコードのペースで増えています。
レンタルサーバー(coreserver-mini)のMySQLを利用しているのですが、
どれくらいのレコード数まで順調に動作するものでしょうか?
300万レコードくらいまで快適に動作すればいいと思うのですが、
それまで問題ないでしょうか?よろしくお願いします。
751NAME IS NULL:2014/08/06(水) 20:17:16.92 ID:???
問題ないよ
って言われたら信じるの?
サポートに聞きなさい
752750:2014/08/06(水) 22:15:27.26 ID:???
>>751
間違いの無いご回答ありがとうございます。
全くおっしゃる通りです。
ありがとうございました。
753NAME IS NULL:2014/08/13(水) 10:36:04.81 ID:???
INSERT INTO `tantousya`(`adress`, `namae_kanji`) VALUE ("Tanaka@", "田中")
WHERE NOT EXISTS ( SELECT * FROM `tantousya` WHERE `tantousya`.`adress` = "Tanaka@");
Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[42000]: Syntax error or access violation: 1064

adressが既に使われている場合に、
データを挿入しないサブクエリを実装したのですが上手くいきません。

INSERT INTO `tantousya`(`adress`, `namae_kanji`) VALUE ("Tanaka@", "田中");
SELECT * FROM `tantousya` WHERE `tantousya`.`adress` = "Tanaka@;

二段階に分けて実行した場合は、まずデータが挿入され、
その後挿入されたデータが表示されます。

エラー内容からサブクエリの書き方に
問題があるように見受けられるのですが、
どこが悪いのか見当もつかない状態です…
754NAME IS NULL:2014/08/13(水) 11:21:11.73 ID:???
`adress`か `namae_kanji`で、重複を許さない指定があれば

INSERT IGNORE INTO `tantousya` (`adress`, `namae_kanji`) VALUE ("Tanaka@", "田中");
755NAME IS NULL:2014/08/13(水) 11:26:49.58 ID:???
adressが気になるw
756753:2014/08/13(水) 11:38:40.04 ID:???
>>754
プライマリ、ユニークキーを指定というのは至極全うな意見だと思いますが
今回はサブクエリで制御を考えています。
サブクエリの勉強中です。

>>755
adress フランス語で書いちゃったわけではなくタダのスペルミスorz
757NAME IS NULL:2014/08/13(水) 11:49:42.87 ID:???
INSERTにNOT EXISTSは直接使えないので、
一旦NOT EXISTSを条件にSELECTし、レコードがない場合に
INSERTすると言うように書かないと無理じゃないかな
758753:2014/08/13(水) 13:05:12.23 ID:???
>>757
なるほど、そういう制限があるんですね。
サブクエリの解説サイト等見直したいと思います。
ありがとうございました。
759NAME IS NULL:2014/08/13(水) 21:39:34.24 ID:???
>>758
こんな感じかw

INSERT INTO `tantousya` SELECT 'Tanaka@' AS `adress`, '田中' AS `namae_kanji` FROM DUAL
WHERE NOT EXISTS (SELECT * FROM `tantousya` WHERE `tantousya`.`adress` = 'Tanaka@');
760NAME IS NULL:2014/08/16(土) 14:46:49.25 ID:CDUM23fr
>>200 >>201
先生たち!それが出来ないんですよ('_;)

がんばって

select name_no,sum(rating_point)as vote,
(select sum(rating_point) from rating_tb WHERE DATE_ADD(date, INTERVAL 5 HOUR) > NOW())as active
from
rating_tb
group by name_no;

上のようにやってみたら、activeが合計値が出て個別にならなくて、初心者で全然ここから打開出来ないです;;
↓こんな風にしか出来ない初心者です。お助けください。お願い致します。
+---------+------+--------+
| name_no | vote | active |
+---------+------+--------+
| 1 | 232 | 47 |
| 2 | 199 | 47 |
| 6 | 107 | 47 |
| 9 | 87 | 47 |
| 10 | 89 | 47 |
| 11 | 95 | 47 |
| 12 | 46 | 47 |
| 13 | 42 | 47 |
| 14 | 27 | 47 |
| 15 | 26 | 47 |
| 16 | 17 | 47 |
| 17 | 19 | 47 |
| 19 | 6 | 47 |
| 20 | 12 | 47 |
| 23 | 6 | 47 |
| 24 | 8 | 47 |
| 25 | 7 | 47 |
| 27 | 9 | 47 |
| 34 | 1 | 47 |
| 35 | 7 | 47 |
| 45 | 3 | 47 |
761NAME IS NULL:2014/08/16(土) 14:47:20.39 ID:???
↑ 間違えて投稿してしまいました。お詫びいたします
762NAME IS NULL:2014/08/18(月) 01:33:19.66 ID:???
サブクエリでなく case when でやればいい
763NAME IS NULL:2014/08/20(水) 10:26:28.50 ID:4cvw8JQq
保守
764NAME IS NULL:2014/08/20(水) 15:36:50.55 ID:???
765NAME IS NULL:2014/08/23(土) 08:23:32.99 ID:???
au氷水ディレクター戦争タイステーキ万国ニューヨークブカ牛肉直輸出制限業者議論病院雇用市議しょうゆダシマクッロスさむらい山雪光金ガンダム風ミックドラ社員あかうんとパズ豚骨のり塩肉マンつばめの巣担々麺野菜炒めラーメン

au氷水ディレクター戦争タイステーキ万国ニューヨークブカ牛肉直輸出制限業者議論病院雇用市議しょうゆダシマクッロスさむらい山雪光金ガンダム風ミックドラ社員あかうんとパズ豚骨のり肉マンつばめの巣塩担々麺野菜炒めラーメン

au氷水ディレクター戦争タイステーキ万国ニューヨークブカ牛肉直輸出制限業者議論病院雇用市議しょうゆダシマクッロスさむらい山雪光金ガンダム風ミックドラ社員あかうんとパズ豚骨のり肉マンつばめの巣塩担々麺野菜炒めラーメン

ニンニクヤーフォー低額土地NHK名古屋遅延電池切れ福岡損保新規駐車近代ゲームフジワイプ転職提案ラーメン
abk公式漏洩安保険王なにあげてんだよ?「わー!ふーう?」↓↓★★↓↓宿題通調印鑑カウントダウン息子議員国会大学生
766NAME IS NULL:2014/08/23(土) 08:29:23.54 ID:???
お大事に
つ お薬
767NAME IS NULL:2014/08/24(日) 11:30:58.34 ID:???
質問させてください。

大したアクセス数もないのに1ページを表示するのに1秒から2秒ほどかかっています。
DBサーバーとアプリケーションサーバーを切り分けると早くなる聞いたので、さくらVPSのローカル接続を利用し試しましたが、やはり遅いままです。

ボトルネックはMySQLサーバーの設定もしくはクエリそのものにあるのかもしれません。。。

さくらVPS SSDプラン
メモリ2GBで、DBはMySQL5.1の場合
以下のmy.cnfの設定は適正だと言えますか?
これを修正することで早く出来るようであれば教えていただけませんか?

[mysqld]
port = 3306
socket = /var/lib/mysql/mysql.sock
skip-external-locking
key_buffer_size = 512M
table_cache = 256
tmp_table_size = 256MB
join_buffer_size = 1M
thread_cache = 8
thread_concurrency = 8
thread_cache_size = 60
query_cache_size = 32M
max_connections = 100
max_allowed_packet = 1M
table_open_cache = 256
sort_buffer_size = 4M
net_buffer_length = 8K
read_buffer_size = 1M
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
character_set-server=utf8
innodb_buffer_pool_size=384M
innodb_log_file_size=128M
slow_query_log=ON
slow_query_log_file=mysql-slow.log
long_query_time=1
768NAME IS NULL:2014/08/24(日) 11:31:36.33 ID:???
続き(長々となってすみません)

[mysqldump]
quick
max_allowed_packet = 16M

[mysql]
no-auto-rehash
default_character_set=utf8

[myisamchk]
key_buffer_size = 20M
sort_buffer_size = 20M
read_buffer = 2M
write_buffer = 2M

[mysqlhotcopy]
interactive-timeout
769NAME IS NULL:2014/08/24(日) 12:00:26.86 ID:???
ワードプレス?
innodb_buffer_pool_sizeは総メモリの7〜8割割り当てろとか言われてる
key_buffer_sizeは64Mぐらいになりそう

sort_buffer_sizeとかが多すぎる
スレッドバッファで調べてみるといい

mysqltuner使ったらだいたい教えてくれる
後エラーログに色々出てるはずだからそれを見る
770NAME IS NULL:2014/08/24(日) 12:05:18.91 ID:???
>>769
いえRuby on Railsというフレームワークを使って自分で1から組んでいます
771NAME IS NULL:2014/08/24(日) 12:10:04.22 ID:???
>>769
ありがとうございます

それとMySQL5.1なんですが5.5に上げておいたほうが利点とかありますか?

MySQLTunerは5.5以降の対応みたいですね
772NAME IS NULL:2014/08/24(日) 12:41:40.88 ID:???
MySQLTunerは5.1で使えるよ
http://mysqltuner.com/

新しいバージョンのほうが当然性能は向上してるし
問題ないなら5.5/6使う方がいいと思う
773NAME IS NULL:2014/08/24(日) 13:19:13.05 ID:???
>>772
ありがとうございます
試してみます
774NAME IS NULL:2014/08/24(日) 13:25:30.23 ID:???
5.5より5.6
5.7はたいした変更ないけど5.5と5.6はクエリによっては大違いだぞ
775NAME IS NULL:2014/08/26(火) 14:31:57.07 ID:???
MySQLで大量のデータ計算させるのに適切なアプリケーションに迷っておりアドバイスあれば教えて下さい。
以前Accessに株価データ入れてVBAで分析みたいなことやってたんですがレコード数が150万ぐらいになるので、MySQL5.6+Access2010に作り直してみたんです。
・ODBC接続してリンクテーブルをAccess内に張り、それに対して操作
・VBAのADOでMySQLテーブルをレコードセットして、それに対して操作
・Accessで計算し、結果をSQL文にしてMySQLに投げる操作
・Accessで計算し、結果をローカルテーブルに書いて最後にテーブルを転送
などやってみたんですが、どれもAccessローカルテーブルに直接操作するよりパフォーマンスが落ちます。
MySQLのクエリ自体は高速なのですがInsert/UpdateをODBC経由やADO接続でやりとりするところがボトルネックみたいで。
PHPとかRubyとかで処理するとそういう問題は少ないのでしょうか。
776NAME IS NULL:2014/08/28(木) 00:15:59.00 ID:???
>>775
すくないよ
エンジニアに金はらって作ってもらいな
777NAME IS NULL:2014/08/28(木) 00:55:32.51 ID:joeF3rjv
結果セットが大量すぎてコピーが遅いならわかるけど
更新処理が遅いのはよくわからんな。
ADOならちゃんとパラメータのバインドとか使えば
そうそう遅くならない
778NAME IS NULL:2014/08/28(木) 01:20:19.39 ID:???
>>775
どこにボトルネックがあるのかそれだけじゃ判断つかないし、
まずはマシン構成と、AccessだけのときとMySQLを使ったときで
どのくらい差があるのか、定量的に示すべき。
779775:2014/08/30(土) 18:45:50.75 ID:???
>>776
自分が素人なのは分かってますが、金出すほど複雑なことじゃないしあとで我流の指標とか色々いじりたいのよね・・・

>>777
それはストアドプロシージャ使ってVBAからはCallするだけって感じでしょうか?

>>778
やっていることを単純化すると下記みたいになります。
下記のプログラムでconnectionをMySQLにして1分43秒、 レコードセットOpenするところのcnnを CurrentProject.Connectionに変えてAccess内のテーブルにすると4秒でした。
銘柄コード1301〜1999の149,257レコードに対する更新です。
PC一台([email protected], 16GB, Win7 64bit)にAccess2010とMySQL5.6インストールしています。
indexやprimary keyは同じAccess内とMySQL内のt_dbに対するUpdateですが、Conndection変えるだけで20倍以上の差になって驚いています。

t_dbテーブルはある銘柄のある日で特定の1レコードを表し、フィールドは[終値]と[id]と[前日終値]があり、[終値]と[id]は既に入力済み。ここでは[前日終値]を埋めていきたい。
idは銘柄コード4桁+営業日コード5桁で、ソートすると銘柄順、営業日順になります。(同一銘柄−例えば1301だと、130100001,130100002,130100003・・・と営業日順に連番になり、銘柄が変わると数字が飛びます)
idでソートしたt_dbを順番にmovenextしながら、前日のレコードにあった終値を[前日終値]フィールドにUpdateしてます。

Sub test()
Dim cnn As New ADODB.Connection
Dim rst As New ADODB.Recordset
Dim preDayID As Long
Dim preClosePrice As Double
Dim sqlStr As String
cnn.Open "Driver={MySQL ODBC 5.3 Unicode Driver};" & _
"Server=hogehoge;" & _
"Database=hogeDB;" & _
"Uid=hoge;" & _
"Pwd=hage"
strSQL = "SELECT 終値, id, 前日終値 FROM t_db where id between 130100000 and 200000000 order by id"
rst.Open strSQL, cnn, adOpenForwardOnly, adLockPessimistic

Do Until rst.EOF
If rst("id") = preDayID + 1 Then
rst.Update "前日終値", preClosePrice
End If
preDayID = rst("id")
preClosePrice = rst("終値")
rst.MoveNext
Loop
rst.Close
cnn.Close
End Sub
780NAME IS NULL:2014/08/30(土) 19:44:19.23 ID:???
ADOでの更新が遅い理由は判らないけど(ODBCの設定、カーソルタイプ、ロックタイプのどれかが影響?)
提示された処理であればSQL一発で大丈夫かと

UPDATE t_db a
INNER JOIN t_db b ON a.id = b.id + 1
SET a.前日終値 = b.終値
WHERE id BETWEEN 130100000 AND 200000000
781780:2014/08/30(土) 19:45:47.62 ID:???
ごめん、最後エイリアスつけ忘れ
WHERE id BETWEEN 130100000 AND 200000000

WHERE a.id BETWEEN 130100000 AND 200000000
782NAME IS NULL:2014/08/30(土) 21:38:04.16 ID:???
>>779
15万件弱のレコードをMySQLからAccessに取り込んで、1件ずつupdateループ回してるってことか。
更新したいだけならMySQL側だけで完結するように >>780 のやり方が良いと思われ。
783NAME IS NULL:2014/08/30(土) 21:45:54.79 ID:???
>>779
ループで毎回updateではなく、抜けたあとでUpdateBatchとかダメだろうか?
http://msdn.microsoft.com/ja-jp/library/cc364237.aspx
784NAME IS NULL:2014/08/30(土) 21:56:05.06 ID:39pGGgY4
SQL1発で済むならそれが一番だが、無理なら
http://blog.livedoor.jp/it_ikiru/archives/50422207.html
みたいなやり方てバインド使った方がいいよ
レコードセットは内部的にコピー持ってSQL発行してるだけだから
785NAME IS NULL:2014/08/31(日) 01:22:59.31 ID:???
ところでコードを貼るならgist使わね?
gistならログイン不要で匿名でスニペット貼り付けられる。
こっちに貼ると行数制限やらタブが消えるやらの問題があるので見づらいし使いづらい。
ちなみに先のコードならこんな感じ。
https://gist.github.com/anonymous/9c2a408bab050f89469d
例示用に勝手に使ってすまぬ >779
786NAME IS NULL:2014/08/31(日) 04:32:01.79 ID:???
質問させてください

phpMyAdminで MySQLのデータベースを管理しています。

yumで新しめのphpMyAdminに入れ替えました。

それ以降というもの
20テーブルほど、それぞれ20MB〜100MBはあり合計270MBとなっています。

しかし、データベースをまるごとエクスポートすると8MBのサイズになりダウンロード完了と出てしまいます。

なぜでしょうか?
787775:2014/09/01(月) 10:29:36.44 ID:???
775,779の件みなさんありがとうございます。
>>780-782
4秒でした。圧倒的に早いですね。これならAccess単独のVBAループ処理に匹敵できます。
>>783
UpdateBatch1分20秒でした。レコードセットアップデートのループより2,3割早かったです。
非接続にしたレコードセットのループ部分は1秒無いぐらいなのにUpdateBatchでほとんどの時間食ってました。
>>784
パラメーターマーカーの方法も1分20秒でした。
>>785
掲示板でコード示すとき便利そうですね。今後使わせていただきます。

他にも色々やったのですが、ループ毎にUpdate文を文字列で組み立ててcnn.Executeするやり方で1分10秒ほどなのがせいぜいでした。
シーケンシャルにカーソル動かしながら処理していくプログラミングに慣れてたのでSQL一発文組み立てるの苦手だったのですが、これだけ圧倒的パフォーマンスだと使わざるを得ないですね。
なんとかその方向でやってみます。
788NAME IS NULL:2014/09/01(月) 12:44:14.79 ID:???
>>786
環境やらバージョンやら、具体的にどういう操作を
したのかやら、書かないと誰もわかんねえよ
789NAME IS NULL:2014/09/01(月) 22:52:44.61 ID:???
mysql 5.5.21
select 〜 into outfile でテーブルの内容をファイルに書き出せはしますが、その時に
カラム名をヘッダとして先頭に出す…なんてことは出来ないんでしょうか
790NAME IS NULL:2014/09/01(月) 23:10:22.91 ID:EfQ/kLTT
791NAME IS NULL:2014/09/01(月) 23:34:35.31 ID:???
>>790
あぁそういう手があったか
ありがとうございます
792NAME IS NULL:2014/09/02(火) 00:51:32.76 ID:???
3
793NAME IS NULL:2014/09/12(金) 22:35:04.80 ID:???
mysql 5.6.20

mysqldumpで個々のデータベースのバックアップを取ろうとしているのですが、

mysqldump performance_schema -u root -p > c:/pf.sql

performance_schemaとinformation_schemaで以下のエラーが出ます

mysqldump : Got error: 1142 SELECT, LOCK TABLES command denied to
user 'root'@'localhost' for table 'accounts' when using LOCK TABLES

回避しつつバックアップを取る方法とかってありますか?
ちなみに出来たファイルの中身はコメントだけでした
794NAME IS NULL:2014/09/12(金) 23:05:15.89 ID:???
ORACLEにはPL/SQLにPACKAGEがありますが、それに相当する機能ってありますか?
ストアド使わないシステムを作ったこと無いんですが、MySQLはストアド使わなくても速いですか
795793:2014/09/14(日) 11:43:43.93 ID:???
自己解決

オプションで -x を付与して出来ました

-x, --lock-all-tables
Locks all tables across all databases. This is achieved
by taking a global read lock for the duration of the
whole dump. Automatically turns --single-transaction and
--lock-tables off.
796NAME IS NULL:2014/09/14(日) 13:25:14.77 ID:???
>>794
> ORACLEにはPL/SQLにPACKAGEがありますが、それに相当する機能ってありますか?
http://dev.mysql.com/doc/refman/5.6/en/faqs-stored-procs.html#qandaitem-A-4-1-8

> ストアド使わないシステムを作ったこと無いんですが、MySQLはストアド使わなくても速いですか
Oracleでもそうだが、ストアドプロシージャ使うと速くなるという幻想をまず捨てるべき。
システム構成やら、やらせたいことやら、SQLの書き方やらで速くも遅くもなる。
797NAME IS NULL:2014/09/14(日) 19:15:21.55 ID:???
フリーの鯖借りてきて、MySQLを使っているのですが、
その鯖には、外部キー制約の機能がありません。

なので、外部キー制約と同じ機能があるフリーの鯖を探してくるか、
「内部リレーション」の機能で、外部キー制約と同じ事をやるか、

と考えています。

よろしければ、「内部リレーション」の機能で、外部キー制約と同じ事をやるための方法について、
教えていただけないでしょうか?
798NAME IS NULL:2014/09/14(日) 20:53:36.54 ID:???
外部制約の機能がないって…エンジンとしてinnodbを使えないってこと?
799NAME IS NULL:2014/09/14(日) 20:55:39.48 ID:???
set foreign_key_checks=0ってことじゃないの?
800NAME IS NULL:2014/09/15(月) 09:22:47.42 ID:9u2jWlPJ
WINDOWS7にMYSQLをインストールする@

http://know-how-tree.com/archives/612
801NAME IS NULL:2014/09/21(日) 10:03:18.93 ID:Lr7dzhif
大量の同時接続数が想定される状況で、採番だけを行うテーブルに
高速に採番させたいのですが、パフォーマンスを上げるためにどの辺りを重点的に考えるべきでしょうか。
・テーブル設計、ストレージエンジン、クエリ
・MySQL設定やリソース

取り急ぎ以下で紹介されている
MyISAMに1レコードINSERTしおいて、リクエストの度UPDATEをかけていく方法
http://engineer.dena.jp/2010/11/mysql-for-socialgame.html
を使用しているのですが、あまりパフォーマンスが上がりませんでした。

リソースの増強をせずとも、ちょっとしたテクニックや設定でパフォーマンスが
上がるのであれば試してみたいのですが、、、
802NAME IS NULL:2014/09/21(日) 10:46:52.34 ID:???
それ複数テーブルにまたがるidだから採用してるんじゃ?
もともとauto_incrementで済むならそっちのがいい
803NAME IS NULL:2014/09/21(日) 14:58:22.28 ID:lk034qCW
wordpressのSQLデータインポートここで質問してもいいですか?
804NAME IS NULL:2014/09/21(日) 15:17:08.51 ID:lk034qCW
データベースはほとんどわからない素人です。
wordpressでデータのインポートをすると下記エラーが出て最後まで完走しません。
解決策をアドバイスいただけないでしょうか。よろしくお願いいたします。


エラー

実行した SQL:

--
-- Table structure for table `wp1_slim_browsers`
--
DROP TABLE IF EXISTS `wp1_slim_browsers` ;

MySQLのメッセージ: ドキュメント
#1217 - Cannot delete or update a parent row: a foreign key constraint fails
805NAME IS NULL:2014/09/21(日) 15:23:49.92 ID:???
まずは、外部制約といった辺りを勉強しませう
この先データベースをいじり続ける気があるなら、それなりの勉強はしてからにね
806NAME IS NULL:2014/09/21(日) 15:51:35.47 ID:lk034qCW
レスありがとうございます。
外部制約ですが・・ちょっと私には難しそうです。。。業者に頼むしかないのかも。
自分のサイトを正常に表示させたいだけなのですが方法はないでしょうか?
807NAME IS NULL:2014/09/21(日) 16:05:38.40 ID:???
どうやってダンプ取ったの?
解説見ながらやり直したほうがいいんじゃ?
外部キー制約があるとインポートするテーブルの順番間違うと入らないから
テーブルごとに分けて順番変えて入れなおしてみては
808NAME IS NULL:2014/09/21(日) 16:18:01.00 ID:???
外部キー制約のチェックを一旦切ればいんじゃね
809NAME IS NULL:2014/09/21(日) 16:18:10.57 ID:lk034qCW
>>807
レスありがとうございます!チカッパサーバーでバックアップオプションで自動でとれるようになっています。
wordpressを誤って上書きインストールしてしまいバックアップから復旧させているところなんです。
上記のエラーで残りのデータが入らないという状況です。そしてどうやらその中に管理画面に関するデータがあるみたいなんです。。

>テーブルごとに分けて順番変えて入れなおしてみては
すいません。やり方がわからないです。。
810NAME IS NULL:2014/09/21(日) 16:27:37.77 ID:lk034qCW
>>808
レスありがとうございます!それはphpmyadminでも出来ますか?メニューにはなかったです。素人過ぎてごめんなさい。
811780:2014/09/21(日) 16:34:44.18 ID:???
phpmysqladminから以下をクエリで実行してみるとか
SET FOREIGN_KEY_CHECKS=0
インポート
SET FOREIGN_KEY_CHECKS=1
812NAME IS NULL:2014/09/21(日) 16:45:46.81 ID:lk034qCW
>>811
ありがとうございます。やってみたらエラーが出て駄目でした。。

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'インポート SET FOREIGN_KEY_CHECKS=1' at line 2
813NAME IS NULL:2014/09/21(日) 16:46:47.44 ID:???
インポート の文字まで入れるなよw
814NAME IS NULL:2014/09/21(日) 16:47:32.52 ID:???
このインポートは文字じゃなくて実際のインポート作業だろ
815NAME IS NULL:2014/09/21(日) 16:49:11.69 ID:lk034qCW
書き方が間違ってました。今度はこうなりましたが駄目っぽい?

SET FOREIGN_KEY_CHECKS = 0;# 返り値が空でした(行数0)


SET FOREIGN_KEY_CHECKS = 1;# 返り値が空でした(行数0)
816NAME IS NULL:2014/09/21(日) 16:53:06.21 ID:???
SET FOREIGN_KEY_CHECKS = 0;
ここで外部キー制約をしなくなる

実際にインポートする(最初の質問の外部キーエラーが出ない)

SET FOREIGN_KEY_CHECKS = 1;
もとの外部キー制約アリに戻す

作業終わり。
わかる?
817NAME IS NULL:2014/09/21(日) 16:59:17.62 ID:lk034qCW
>>816
ありがとうございます。
SQLのところでSET FOREIGN_KEY_CHECKS = 0; を実行して
インポートした後
SQLのところでSET FOREIGN_KEY_CHECKS = 1; ですかね?
818NAME IS NULL:2014/09/21(日) 17:24:44.12 ID:???
恐らく外部キー何かわかってなさそうだけど大丈夫か?
また同じエラー起こしそう
819NAME IS NULL:2014/09/21(日) 17:27:28.61 ID:???
バックアップとるか消えてもいいとこでやるようにな
820NAME IS NULL:2014/09/21(日) 17:27:52.51 ID:???
外部キーわざわざ設定してるんだから理解してるでしょ
821NAME IS NULL:2014/09/21(日) 17:32:08.98 ID:???
>>806見る限り外部制約なにかわかってなさそうやで
822NAME IS NULL:2014/09/21(日) 17:38:50.47 ID:lk034qCW
SET FOREIGN_KEY_CHECKS = 0;してからインポートしましたが同じエラーが出ました。。。

エラー

実行した SQL:

--
-- Table structure for table `wp1_slim_browsers`

--
DROP TABLE IF EXISTS `wp1_slim_browsers` ;

MySQLのメッセージ: ドキュメント
#1217 - Cannot delete or update a parent row: a foreign key constraint fails
823NAME IS NULL:2014/09/21(日) 17:45:36.16 ID:???
ああ、CMSが勝手に設定した外部キーか
824NAME IS NULL:2014/09/21(日) 17:58:34.01 ID:???
業者に泣きついて診てもらえ。俺なら10万くらいでやってやるよ。
825NAME IS NULL:2014/09/21(日) 18:04:59.48 ID:lk034qCW
それしかないでしょうか。業者10万もするんですか泣
826NAME IS NULL:2014/09/21(日) 18:23:37.72 ID:lk034qCW
SSHでやっても同じですか?触ったことはないです
827NAME IS NULL:2014/09/21(日) 18:24:38.23 ID:ysK96J+F
どうせ消せなくてエラー出てんだから
まっさらにしてやってみりゃいい

試しに外部キー制御外したその場でDROP TABLEやってみ
828NAME IS NULL:2014/09/21(日) 18:34:14.22 ID:???
まじでバックアップだけは取れよ
829NAME IS NULL:2014/09/21(日) 18:43:11.26 ID:lk034qCW
>>827
wp1_slim_browsers←エラーになっているこのテーブルを削除でいいですか?

>>828
ありがとうございます。バックアップはファイルとデータベースを両方とってあります。
830NAME IS NULL:2014/09/21(日) 19:12:59.54 ID:lk034qCW
うう。でもテーブル削除してもまたインポートするから意味ないような・・気がします
831NAME IS NULL:2014/09/21(日) 19:35:28.59 ID:ysK96J+F
エラーみりゃ削除できねえって言ってるのがわかるだろ
832NAME IS NULL:2014/09/21(日) 20:19:21.62 ID:lk034qCW
結局無理ってことですねありがとうございました
833NAME IS NULL:2014/09/21(日) 20:26:17.57 ID:???
wordpress スレ探して、そちらで具体的な環境とか操作手順を
晒しながら質問したほうが良いのでは。
834NAME IS NULL:2014/09/22(月) 03:22:39.71 ID:y7/LBMjJ
多分ここが一番詳しいと思います
データ全部削除してSET FOREIGN_KEY_CHECKS = 0;して再度インポートしたけどやっぱり駄目
SSHはうまくいかないしオワタ


エラー

実行した SQL:

CREATE TABLE `wp1_slim_outbound` (
`outbound_id` int( 10 ) unsigned NOT NULL AUTO_INCREMENT ,
`outbound_domain` varchar( 255 ) DEFAULT '',
`outbound_resource` varchar( 2048 ) DEFAULT '',
`type` tinyint( 3 ) unsigned DEFAULT '0',
`notes` varchar( 512 ) DEFAULT '',
`position` varchar( 32 ) DEFAULT '',
`id` int( 10 ) unsigned NOT NULL DEFAULT '0',
`dt` int( 10 ) unsigned DEFAULT '0',
PRIMARY KEY ( `outbound_id` ) ,
KEY `idx_wp1_slim_outbound` ( `dt` ) ,
KEY `fk_wp1_id` ( `id` ) ,
CONSTRAINT `fk_wp1_id` FOREIGN KEY ( `id` ) REFERENCES `wp1_slim_stats` ( `id` ) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE = InnoDB DEFAULT CHARSET = utf8;

MySQLのメッセージ: ドキュメント
#1215 - Cannot add foreign key constraint
835NAME IS NULL:2014/09/22(月) 06:08:50.61 ID:???
元々はインポート時に参照キーのエラーが出ていたのが
今度はCREATE TABLEでエラーが出るようになった、ってこと?
このエラーを見る限り、wp1_slim_statsテーブルのid列にキーが
設定されていない可能性があるけど
836NAME IS NULL:2014/09/22(月) 08:20:09.14 ID:y7/LBMjJ
>>835
最初は途中までデータが入った状態でインポーしていました
837NAME IS NULL:2014/09/22(月) 09:03:57.94 ID:y7/LBMjJ
slim_stats←このプラグインが邪魔してますよね。削除したい…
838NAME IS NULL:2014/09/22(月) 20:11:47.88 ID:y7/LBMjJ
1年前のSQLファイルがありました。これを一旦インポートして、管理画面に関するテーブルだけをエクスポートし、現在に戻して管理画面テーブルだけをインポートしたらどうでしょうか。
今の問題はWordPressの管理画面に入れないことなのでこれで解決するかもしれない。ご意見お願いします。
839NAME IS NULL:2014/09/22(月) 21:40:06.14 ID:???
 あくまでWordPressを復旧するのが目的であってMySQLやRDBMSについて知ろうという
気はない、というスタンスなら>>833の言うようにここは適してないんじゃないかなあ。
840NAME IS NULL:2014/09/23(火) 02:44:41.70 ID:Rn55ID+g
なんとか復旧しました。
>>838の方法でうまくいきました!心配してくれたみなさんありがとう!いま感無量です。管理画面に入れたときは感動しました!

データベースからテーブル削除してもバックアップがあればなんぼでも復旧できることがわかりました。WordPressの復旧作業は初めての経験でしたが自信もつきました。もう少しで業者に泣きつくとこでした。地元のweb屋検索しましたからね。

それにしてもデータベース命ですね。次にファイル。何世代かに分けてバックアップは保存しておくべきですね。始まりはWordPressの上書きインストールでしたがいい経験になりました。明日はいい祝日になりそうです。スレ使いすぎてすいませんでした。さよなら。
841NAME IS NULL:2014/10/01(水) 02:07:33.50 ID:auoeFgeH
AAA1
AAA11
AAA111


これを

AAA001
AAA011
AAA111

としてORDER BYするにはどうすればいいのでしょうか?
842NAME IS NULL:2014/10/01(水) 07:40:26.95 ID:???
>>841
そういうふうに変換かけて order by にかければいい
843NAME IS NULL:2014/10/01(水) 07:44:02.00 ID:???
念じる
844NAME IS NULL:2014/10/01(水) 09:53:38.94 ID:???
そういう変換をするストアドファンクションを定義するなどしてそれでORDER BYかけることはできる。
ただし MySQL は関数ベースのインデックスが張れないから、パフォーマンスは期待できないが、
SQL 処理中の ORDER BY する時点でソート件数が少ないのであれば影響は少ないだろう。
もう一つの代替案は、そのように変換済みの実カラムを追加してそっちで ORDER BY する手もある。
こっちはその分の容量を食う代わりにインデックスは効く。
845NAME IS NULL:2014/10/01(水) 10:07:49.30 ID:???
列がcolAとして

select colA,cast(substring(colA,4) as unsigned)
from tbl
order by cast(substring(colA,4) as unsigned) ;

これでは駄目?
駄目なんだったら
文字列の部分と数値の部分を分け、数値の部分についてLPADで0埋めしてまた連結するとか

そこまでしないといけないもん?
846841:2014/10/01(水) 23:45:26.30 ID:auoeFgeH
ありがとうございました
それほどレコード数も多くなくて、最大で20前後ですので、その方法でorder byします
847NAME IS NULL:2014/10/02(木) 19:59:40.95 ID:YdQdRdW6
column1を含むtable1と
column2を含むtable2をcolumn3でjoinした結果に
(column1, column2)の複合インデックスを張りたいんですけど
テーブルを非正規化する以外の方法はありますか?
848NAME IS NULL:2014/10/02(木) 21:47:14.24 ID:???
祈りなさい
849847:2014/10/03(金) 00:47:55.73 ID:s/6Hsaik
MySQLの神に祈ってます
神様教えてください(´;ω;`)
850NAME IS NULL:2014/10/03(金) 00:54:09.07 ID:???
複合インデックス張るのはあくまで手段であって目的ではないはずだ。
クエリの高速化が目的だろうとは思うけど、本当に他に手はないのか?
何を根拠に複合インデックスという手段が最適だと判断したの?
851847:2014/10/04(土) 13:03:03.45 ID:11JI3KNp
技術的に解決は無理でしたが政治的に解決されました
ありがとうございました
852NAME IS NULL:2014/10/04(土) 22:46:47.32 ID:???
アベノミクス!!
853NAME IS NULL:2014/10/05(日) 01:10:34.48 ID:???
847は政治的に問題はなかったことにしたみたいだけど、
純粋に技術的に解決しようと思ったらどんな手があるかな。

Table1 [id][col1][col3]
Table2 [id][col2][col3]

SELECT Table1.col1, Table2.col2
FROM Table1
INNER JOIN Table2 ON Table1.col3 = Table2.col3

cardinalityが十分に高いという前提であれば、
それぞれのテーブルのcol3への単独インデックスと、
Table1(col3, col1), Table2(col3, col2) という
複合インデックスを張るという手が有効じゃないかと気がするんだけれど、
どうなんだろう?
854NAME IS NULL:2014/10/06(月) 09:54:41.55 ID:???
Sakilaって名前が絶望的に嫌いなんだが
なんとか出来ないものか...
855NAME IS NULL:2014/10/06(月) 23:59:12.42 ID:???
MySQLの memcached インターフェイスって使ってる人?
856NAME IS NULL:2014/10/07(火) 19:03:17.28 ID:???
海外の方ですか?
857NAME IS NULL:2014/10/08(水) 15:58:09.03 ID:???
mariadb-5.5.39-winx64.msiをinstall後
設定を一度終わらせDBとして走らせたのを確認後

PCを再起動して

HeidiSQL起動するとさっき迄問題なかったのに

sql error (2003) in statement #0 can't connect to
mysql server on"127.0.0.1"(10061)

と表示され新規でのDB登録もできなくなってしまうのですが
対処方法教えていただけないでしょうか?
858NAME IS NULL:2014/10/08(水) 16:02:15.47 ID:???
859NAME IS NULL:2014/10/12(日) 15:57:29.11 ID:l4A5A+ct
どなたか教えて頂けないでしょうか?

MySQL外部接続について

CentOS6.5上にMySQLをインストールし外部DBサーバとして開発を行いたいと思っています。

※CentOSはVMware上で構築

MySQLのインストールは上手くいきローカルからは接続が上手くいくのですが、
外部からの接続が上手くいきません。

外部接続のためにやったことは以下です。
・接続ユーザのhostを"%"に設定しどこからも接続できるようにする
・0.0.0.0:3306でLISTENする

いちをいろんな所を参考に外部接続ができるような設定を行ったのですが、
どうやっても上手くいきません。

外部接続はJavaのプログラムから行っており以下のエラーが発生します。

※jdbc:mysql://IPアドレス:3306/DB名 の場合
ConnectException: Connection refused

※jdbc:mysql://ホスト名:3306/DB名 の場合
ConnectException: Operation timed out

そもそもCentOSのネットワークの設定がダメなようなきもするのですが、
ホスト名とIPアドレスでエラーの結果が違うのもよくわかってないです。
860NAME IS NULL:2014/10/12(日) 16:07:20.26 ID:???
iptablesを確認。
初期状態で3306は空いていなかった気がする。
861NAME IS NULL:2014/10/12(日) 16:15:10.60 ID:l4A5A+ct
>860

ありがとうございます
iptablesは他のサイトみて設定しいますがどうやってもうまくいきません。

/etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

iptables --list
ACCEPT tcp -- anywhere anywhere state NEW tcp dpt:mysql
862NAME IS NULL:2014/10/12(日) 16:35:39.03 ID:???
そもそもpingは通るの?
863NAME IS NULL:2014/10/12(日) 16:41:07.67 ID:l4A5A+ct
>862

はいpingは通ることを確認しています。
ただtelnetで3306にアクセスするとすぐにはじかれます。
これは3306のポートを開いてないってことなんでしょうか?
netstatで見てもちゃんと3306はLISTENしているのですが。
864NAME IS NULL:2014/10/12(日) 17:21:32.34 ID:???
ローカルからmysqlの -h オプションで127.0.0.1じゃないほうのアドレス指定で開ける?
iptables を -F でフラッシュしても変わらない?
865NAME IS NULL:2014/10/12(日) 17:41:35.46 ID:???
ちょっと試したけど、やっぱりiptablesぽいけどな
シンプルにこれじで試してみては
iptables -A INPUT -p tcp --dport 3306 -j ACCEPT
866NAME IS NULL:2014/10/12(日) 17:54:35.39 ID:???
切り分けのためにとりあえずiptablesを止めてみれば?
867NAME IS NULL:2014/10/12(日) 19:47:10.01 ID:OVtCluaN
>866

859です。
iptablesを停止したらアクセスできました!
iptablesの設定がダメだったみたいです。
設定を見直したいと思います。
※原因はまだわかっていませんが。。。
アドバイスありがとうございました。
868NAME IS NULL:2014/10/12(日) 20:29:29.90 ID:???
-Aで追加してるんだから
それより前の評価順で弾かれてるんじゃないのか
869866:2014/10/12(日) 20:39:44.07 ID:???
>アドバイスありがとうございました。
アドバイスってほどのものでもないんで
iptablesの問題だと判ったのであれば/etc/sysconfig/iptablesの内容を
変に加工せずに全部晒せばちゃんとしたアドバイス得られるかと
870NAME IS NULL:2014/10/16(木) 00:19:45.83 ID:???
load data infile構文でデータをインサートした際にエラーが出た場合、エラー内容(エラーコードやメッセージ)を別に用意したテーブルに格納したいのですが、
どうやって取得すればいいでしょうか?Show warningsで直前の警告やエラーが取得出来ることは分かりましたが、調べても見つけることが出来ません・・・
バージョンは5.1.3.6です。
871NAME IS NULL:2014/10/16(木) 01:06:55.39 ID:???
テーブルに格納する前にエラーを無くす方が先決だと思うのだが
872NAME IS NULL:2014/10/16(木) 01:23:18.35 ID:???
>>871
すいません、今のところloda data infileで問題無くテーブルへインサート出来ているんです。
ただ、この先何かしらエラーは出てくるだろうから、それらのエラーコードやメッセージを保管しておきたいとなりました。
そのうえでわざと間違いをしてエラーコードがどこから出てくるのか、それは取得可能なのかを知りたいんです。

show warningsの結果もどこに格納されているの変わらない、一時テーブルのような物なのかそれともログファイルか何かに記録されていて、
それらをインサートのたびに読み込んでDBに突っ込むのか分からない。
エラーが出る際に戻り値の様な物が戻ってくるのか、それを取得してエラー内容を引きずり出す必要がありtお思う真sいた

吸いません、酔っ払ってるんで文章めちゃくちゃですがお許しください。
873NAME IS NULL:2014/10/16(木) 16:33:39.97 ID:???
874NAME IS NULL:2014/10/16(木) 19:37:15.49 ID:???
HTML5で業務アプリケーションを作ろうと思っているのですが、文字コードは何を選択するのがベストでしょうか?
全角 = 2バイト、半角 = 1バイトと考えている人が多く、UTF-8を使おうか悩んでいます。
875NAME IS NULL:2014/10/16(木) 19:51:06.84 ID:???
utf8mb4
876NAME IS NULL:2014/10/16(木) 19:58:11.86 ID:???
charなら文字数だけど
877NAME IS NULL:2014/10/16(木) 20:27:43.29 ID:???
一部の人の名前入れられないとか論外だからUTF-8。
MySQLはutf8mb4
878NAME IS NULL:2014/10/18(土) 15:59:52.94 ID:???
別に論外じゃないけどな。

仮に論外ならユニコード定義外の文字でも入力出来なきゃ駄目だろ。
現実的に可能な範囲でベストを尽くすべきという意味においては同意だけど。
879NAME IS NULL:2014/10/21(火) 11:51:05.44 ID:???
全テーブル全カラムを対象に
日本語(というか非アスキー)が含まれているテーブルの
一覧を作りたいんだけど
どうしたらそれなりに高速に調べられるかな
880NAME IS NULL:2014/10/21(火) 13:30:47.94 ID:???
1000件ぐらいまでだったら普通に検索しても速度は変わらないと思うけど
10万件を超えるのなら Mroonga の導入を検討するとか
881NAME IS NULL:2014/11/14(金) 12:19:28.98 ID:???
揚げ
882NAME IS NULL:2014/11/26(水) 14:42:58.16 ID:???
生物の生育範囲のような、例えばpH1.0〜3.3というような、幅のある条件をもつ複数の生物を
条件検索で絞り込ませるDBはどのように作ればいいのでしょうか。
pHの欄に、1.0、1.1、1.2・・・・3.2、3.3などと延々入力しておかなければならないのでしょうか。
これだと幅が広い領域を持つ生物の時はとても手間がかかります。
もっとスマートなやり方があるのでしょうか。
883NAME IS NULL:2014/11/26(水) 14:53:08.29 ID:???
最小と最大入れて範囲指定で検索でいいと思うが
884NAME IS NULL:2014/11/26(水) 15:15:44.54 ID:???
データベースの最小値欄に1.0、最大値欄に3.3と入力しておくだけで、
範囲指定の検索ボックスで、下限が3、上限が5 と指定すれば、>>882であげた
生育条件(pH1.0〜3.3)の生物を結果として出してくれる?
生育pH3.1〜5.7のような生物Pがいた場合、下限3、上限5と条件検索すれば、
これも同時に結果に出してくれるのでしょうか。
885NAME IS NULL:2014/11/26(水) 15:36:40.35 ID:???
http://www.rsch.tuis.ac.jp/~nagai/SYS/SYS22.html
この例のように、1つのアイテムが1つの固有値を持つものは、where文で
範囲指定すればいいとわかるのですが、上記のように
1つのアイテムが、幅のある数値を持つものはどうすればいいのか悩んでいます。
pHというフィールドの中に1.0from3.3と入れたらプログラムは理解してくれますか。
それともminとmaxというフィールドをそれぞれ作って1.0、3.3という値を入れておくのでしょうか。
886NAME IS NULL:2014/11/26(水) 16:09:47.88 ID:???
もちろん情報が2つあるんだから2項目にminとmax入れておくんだよ
もしかして検索条件も範囲なの?
その場合、すこしでも重なってたらひっかかるのか、完全に内包されてる場合だけなのか
とかいろいろ条件あると思うんだけど、必要な要件並べてみてよ
887NAME IS NULL:2014/11/26(水) 17:13:03.66 ID:???
>>886
ありがとうございます。そうです、検索条件も範囲です。
複数の生物についてデータベースを作り、同一の生育条件のものを拾い出すデータベースです。
例えばメダカは絶対に水温25℃ぴったりじゃないと死んでしまうってことはなく、
生きられる水温に幅がありますよね。
そのように、似たような条件で生きられる生物は他にもいろいろいるわけですが、
それらを条件検索で絞って出てくるように作りたいのです。
なので検索条件は、重なる部分を少しでも内包するものを拾う必要があると思います。
888NAME IS NULL:2014/11/26(水) 17:36:26.50 ID:???
カラムが minvalue maxvalue とすると
特定の値が範囲内かは、
値 BETWEEN minvalue AND maxvalue
で探せるから
最小値 BETWEEN minvalue AND maxvalue

最大値 BETWEEN minvalue AND maxvalue
をORでつなげば重なり、ANDでつなげば内包になるんじゃない?

まあいろいろ試してみて
889NAME IS NULL:2014/11/26(水) 17:37:32.12 ID:???
あーあと範囲が検索範囲より両側とも大きい場合を含めるなら別にその比較もいるね
890NAME IS NULL:2014/11/26(水) 18:17:54.58 ID:???
>>888 ありがとう。
andはアレかつコレですよね。
Aの範囲とBの範囲が重なりを内包するものを探せということは、
betweenAの範囲の最小値かつAの範囲の最大値、and
betweenBの範囲の最小値かつBの範囲の最大値 ということで、andでつなげば
でる!と考えました。
>>889
生育条件範囲が検索範囲より両側とも大きい場合も
同じ式でいけるかと思いましたが違うのかな。
891NAME IS NULL:2014/11/28(金) 21:08:37.93 ID:???
>>890
これはとてもポピュラーな問題なんだけど、「不要なもの」以外を取るようにすれば楽。

生物.max < 検索.min → 水槽の最小水温でも熱すぎて死んじゃう生物
か、
生物.min > 検索.max → 水槽の最大水温でも冷たすぎて死んじゃう生物

が、検索結果に「不要なもの」だよね。なので、その逆を出せばいいよ。
892NAME IS NULL:2014/11/28(金) 21:33:08.31 ID:???
pH1.0で生きられる生物なんているの?
例だから別にどうでもいいんだけど
893NAME IS NULL:2014/11/28(金) 21:53:51.31 ID:???
いるW

Ferroplasma(フェロプラズマ属)はテルモプラズマ目フェロプラズマ科に属す古細菌の属である。
非常に強い好酸性と金属耐性、細胞壁を欠くことを特徴とする。
増殖最適条件は30-50℃、pH1.5程度で、pH0での増殖も報告されている。

http://ja.wikipedia.org/wiki/%E3%83%95%E3%82%A7%E3%83%AD%E3%83%97%E3%83%A9%E3%82%BA%E3%83%9E%E5%B1%9E
894NAME IS NULL:2014/11/28(金) 23:02:01.75 ID:???
それアカンやつや
895NAME IS NULL:2014/12/01(月) 15:05:57.41 ID:???
EXPLAINの出力について質問です。
keyがセカンダリインデックスでExtraにUsing whereとUsing indexの両方が出力される場合、
ExtraがUsing indexだけの場合とどういう違いがあるのでしょうか?
896NAME IS NULL:2014/12/02(火) 20:31:44.50 ID:???
>>985
インデックスだけでは該当するレコードを絞り切れない場合に "Using where" が出る。
それが出たとき、結果のレコード数は10なのに、rows が 50 とかになってない?
1レコード取り出したいのに、rows が 1000 とかになってたら見直したほうがいいかも。
897NAME IS NULL:2014/12/04(木) 07:10:54.48 ID:???
>>896
回答ありがとうございます。
Using whereが出た時も出ない時も結果のレコード数・rowsともに複数行でした。

WHERE句で複合インデックスの2つ目以降のキーも使われた場合Using whereが追加されるとかでしょうか?
898NAME IS NULL:2014/12/04(木) 12:45:27.13 ID:???
>>897
> Using whereが出た時も出ない時も結果のレコード数・rowsともに複数行でした。
同じ数字でしたか?
899NAME IS NULL:2014/12/14(日) 02:04:33.90 ID:yOOGWEyF
MYSQLでDBの勉強してるんですけど、

insert into TABLE_B(NO,JIKI,TENSU_A,TEMSU_B,TENSU_C)
VALUES(
(select NO" from TABLE_A),
(select JIKI,AVG(TENSU_A),AVG(TENSU_B),AVG(TENSU_C)
from TABLE_B
group by JIKI)
);

このやり方だとエラーでるんですが
構文で間違ってる所あります?
900NAME IS NULL:2014/12/14(日) 02:14:05.46 ID:???
>>899
TEMSU_B は合ってる?
select NO" も怪しい。

エラーもちゃんと書いてね。
901名無しさん@そうだ選挙に行こう:2014/12/14(日) 02:33:25.87 ID:yOOGWEyF
>>900
すみません、タイプミスです。
正しくはTENSU_Bとselect NOです。

エラーは
ERROR 1136(21S01):Column count doesn't match value count at row 1とでました。
902名無しさん@そうだ選挙に行こう:2014/12/14(日) 02:37:14.52 ID:???
TEMSU_B,
903名無しさん@そうだ選挙に行こう:2014/12/14(日) 02:39:55.61 ID:yOOGWEyF
>>902
すみませんでした。
書き込んだときのタイプミスです。すみません
904名無しさん@そうだ選挙に行こう:2014/12/14(日) 02:44:09.26 ID:yOOGWEyF
http://www.dotup.org/uploda/www.dotup.org51852.png.html


このようなテーブル構成でして、
新しく追加された「NO」3,4のデータをTABLE_BにJIKI毎に各TENSUの平均を
TABLE_Bに追加したいんですが、
いろいろ調べたんですが、よくわかりません。
905名無しさん@そうだ選挙に行こう:2014/12/14(日) 03:03:20.02 ID:???
(select NO" from TABLE_A),
これの結果が4行
(select JIKI,AVG(TENSU_A),AVG(TENSU_B),AVG(TENSU_C)
from TABLE_B
group by JIKI)
これの結果が2行
行数が違うのでエラーになる。

テーブルの作りが悪いから、
(select 3, JIKI,AVG(TENSU_A),AVG(TENSU_B),AVG(TENSU_C)
from TABLE_B
group by JIKI)
こんな感じで、NOはプログラム(もしくは手動)で入れたほうがいい。
906名無しさん@そうだ選挙に行こう:2014/12/14(日) 03:18:26.30 ID:yOOGWEyF
>>905

INSERTできました!ありがとうございます!
907名無しさん@そうだ選挙に行こう:2014/12/14(日) 10:39:23.68 ID:???
神様がいるスレ (^ 人 ^) ありがたや
908名無しさん@そうだ選挙に行こう:2014/12/14(日) 17:53:22.12 ID:???
太郎と次郎の平均点を三郎に入れてどうするんだろうか
909NAME IS NULL:2014/12/15(月) 09:04:57.68 ID:???
三郎 : アッー!
910NAME IS NULL:2014/12/15(月) 10:13:41.64 ID:???
一郎:うっ
911NAME IS NULL:2014/12/16(火) 02:32:54.31 ID:GtMu71uM
みなさんはどうやってMySQL勉強しました?
912NAME IS NULL:2014/12/16(火) 09:16:10.40 ID:???
漢のブログ見た
913NAME IS NULL:2014/12/16(火) 11:26:11.58 ID:???
あれこれ図書館でその手の本を借りまくって
914NAME IS NULL:2014/12/16(火) 11:47:36.02 ID:???
データベースで図書館というとあれですね?
915NAME IS NULL:2014/12/16(火) 11:58:05.89 ID:???
タイーホ
916NAME IS NULL:2014/12/17(水) 18:45:50.54 ID:aelyae1c
複合インデックスについて質問です
主キーとユニークキーと、作成日時とフラグを収めるテーブルがあり、
検索で、ユニークキーが一致して作成日時が1日以内でフラグが立っていない ものを検索する場合
複合インデックスはどのように作成すればよいでしょうか?


(例)
CREATE TABLE IF NOT EXISTS `test` (
`primary_id` int(1) unsigned NOT NULL AUTO_INCREMENT,
`unique_key` char(200) COLLATE utf8_bin NOT NULL,
`created` datetime NOT NULL,
`deleted` tinyint(1) NOT NULL,
PRIMARY KEY (`primary_id`),
UNIQUE KEY `unique_key` (`unique_key`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

というテーブルで

WHERE `unique_key` = 'ユニークキー'
AND `deleted` = 0
AND `created` <= '1日前'

という条件で検索したいと考えてます
この際、
UNIQUE KEY `index` (`unique_key`,`deleted`,`created`) とすればいいのか、
KEY `index` (`unique_key`,`deleted`,`created`) とすればいいのか、
そもそも`UNIQUE KEY `unique_key` (`unique_key`) が既にあるから複合インデックスに`unique_key`を含める必要はないのか、
またはもっと他に良い方法があるのか、、、
初心者で見辛い点や意図が伝わりにくい点があるかもしれませんが、ご教授ご指摘の程よろしくお願いしますm(_ _)m
917NAME IS NULL:2014/12/17(水) 18:47:23.54 ID:aelyae1c
訂正
`created` >= '1日前'
でした
918NAME IS NULL:2014/12/17(水) 19:04:33.08 ID:???
インデックス追加する必要がない
919NAME IS NULL:2014/12/17(水) 19:07:10.61 ID:aelyae1c
>>918
それは意外でした
後学の為にぜひ理由を教えてください
920NAME IS NULL:2014/12/17(水) 21:19:23.25 ID:???
>>918じゃないが、unique_key 1件あたりのレコード数はどのくらいなの
921NAME IS NULL:2014/12/17(水) 21:28:21.95 ID:aelyae1c
>>920
unique_key 対するデータは1つになっているので・・・
もしかしてunique_keyを条件にした時点で他のレコードを探す必要がないので要らないってことですか?
だとしたら、理解できました
皆さん、ありがとうございました
922NAME IS NULL:2014/12/18(木) 04:01:52.73 ID:???
はい
923NAME IS NULL:2014/12/18(木) 11:45:52.70 ID:???
レコード長(サイズ)で教えて欲しいのですが、
InnoDBで、大きいvarchar型をいくつか利用するとレコード長がオーバーしてしまう状況です。
varchar型をtext型にすれば、回避できるのでしょうか。
924NAME IS NULL:2014/12/24(水) 06:10:41.16 ID:???
MySQL初心者です。
NULL不可のDATE型のカラムに不正な日付をINSERTした際、0000-00-00という値でINSERTが完了してしまいますね。
これをエラーを返してROLLBACKさせたいのですが、DB側の機能では不可能でしょうか?
925NAME IS NULL:2014/12/24(水) 07:06:36.42 ID:???
>>924
日付判定はアプリ側の仕事ってのがMySQLのスタンスだから
INSERT、UPDATEトリガで例外を発生させるぐらいしかないかも。

IF DAYOFYEAR(NEW.datecolumn) IS NULL THEN
 SIGNAL SQLSTATE '23000' SET MESSAGE_TEXT = 'invalid date'
END IF;
926NAME IS NULL:2014/12/24(水) 08:26:39.03 ID:???
>>924
sql_modeでNO_ZERO_DATEを my.iniだかmy.cnfだかに設定する

mysql sql_mode あたりでぐぐれば出てる
927NAME IS NULL:2014/12/24(水) 20:49:58.54 ID:???
>>925
>>926
ありがとうございました。
sql_mode = STRICT_ALL_TABLESでうまくいきました。
928NAME IS NULL:2014/12/25(木) 12:22:49.85 ID:???
>>923
innodb_file_format = Barracuda
innodb_file_per_table = 1
で、
ROW_FORMAT=DYNAMIC
929:2014/12/25(木) 19:43:04.66 ID:???
/:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::ヽ
    /:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::://ヽ:::::::::::::::|
    l:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::// ヽ::::::::::::::l
    l:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::/:::「'ヽ::::::::::://   ヽ:::::::::::|
    |::::::::::::::::::::::::::::::::::::::::::::::::::::::::::ノl:::ノ l:::::::/      ヽ::::::::|
   ノ:::::::::::::::::::::::::::::::::::::::::::::::::::::/ ゙゙  ノ:::/ ,,;;;;;;,,    ,,,,ヽ:::::l
   ):::::::::::::::::::::::::::::::::::::::::::::::/    ノ/ __,'''i: ('''__):::l  
  )::::::::::::::::::::::::::::::::::::::::::::::::::/         ̄ ̄ン:. :「 ̄`ヾ   
 1:::::::::::::::::::::::「 `┤l:::::::::::::::::l          ̄   ,  ヽ ̄ l   
  `l:::::::::::::::::::::ヽ  :l li:::::::::::::/        ヽ  /´   `l  |
  ヽ::::::::::::::::::::::\_」 lヽ::::/         .l  !:-●,__ ノ  /      
  ノ:::::::::::::::::::::::::::ノ | l `゙゙           i ,,;;;;;;;;;;;;;;;;;;;;,  /ヽ       
,/ ヽ::::::::::::::::::::::(  l l::::::::..         /.:''/´ ̄_ソ  /  `ヽ
     ヽ:::::::::::::::ヽ | l:::::::::::...      /::// ̄ ̄_ソ  /    \   ヴッ!!
        ヽ:::::::\| l::::::::::::::::...    / :::.ゝ` ̄ ̄/ /       ヽ
           ヽ:::l l:::::::::::::::::::..      ̄ ̄;;'' /         ヽ
              l l;;;;;;:::::::::::::::.....;;;;............;;;;;;''ノ            l
              l l '''''''''''''''''''''''''''''''''''''' ̄l |             |

http://www.youtube.com/watch?v=z2qK2lhk9O0
930NAME IS NULL:2014/12/28(日) 13:06:20.99 ID:???
■質問です
MySQLを初めて使うのですが、
phpMyadminから設定を行ったのですが、
データをいくつ登録しても、
出力するページ側では1つしか出力されません。(phpMyadmin側ではデータは登録されている)

phpMyadminにて一度設定した後に下記を後から修正したのですが
それが原因てことはありますでしょうか?

主キー
ユニークインデックス
インデックス
全文インデックス

また、上記のそれぞれの意味を初心者向けに解説しているサイトなどあれば教えていただけますと幸いです
931930:2014/12/28(日) 14:35:41.77 ID:???
すみません自己解決しました。
接続側のphpの記述に問題がありました。
失礼しました
932NAME IS NULL:2014/12/28(日) 14:50:22.62 ID:???
ガンバ
933NAME IS NULL:2014/12/28(日) 18:53:41.52 ID:???
Barracuda で ROW_FORMAT=ROW_FORMAT=COMPRESSEDにしたら
900MB弱あったテーブルが500MB以下になった。すごっw
934NAME IS NULL:2014/12/30(火) 05:24:23.22 ID:ZOTTcmcS
MySQLを利用してWebサイトを作っています
ユーザーが入力した文字(名前や自己紹介文)をDBへ登録する際、
HTML特殊文字(&や<>等)は予めエスケープしてからDBへ登録するのと、
DBへの登録はそのままで、表示する際にエスケープするのは
どちらが一般的なのでしょうか?

エスケープして登録した方が、表示の度に毎回エスケープしなくていいので良いと思うのですが、
値を検索する際に困りそうな気がして悩んでます
935NAME IS NULL:2014/12/30(火) 09:51:16.46 ID:???
そのデータは絶対にHTMLに流すことしかしないの?
HTML前提じゃないのに格納時にエスケープするのはおかしいよね?
ま、前提だとしても基本的には生データで入れるけどね。
936NAME IS NULL:2014/12/30(火) 12:12:51.08 ID:???
保存のためなのか表示のためなのか切り分けろ
937NAME IS NULL:2014/12/30(火) 12:18:12.23 ID:???
どこかに
ページ送りの部分のソース(他の機能は一切不要)を初心者向けに解説しているサイトないでしょうか?

なんですぐ解説サイトって検索機能とか余計な事まで一緒にやろうとするんだろう
938NAME IS NULL:2014/12/30(火) 13:38:01.43 ID:???
ページ送りってなんやねん。ここはDBの板なんだからPHPとかWebのことならそういう板で聞けよ
939NAME IS NULL:2014/12/30(火) 13:56:35.36 ID:???
多分、limit offset と order by で順番に取ってくるやつのことだと思うけど
そのままググれば見つかりそうなもんだけどな。
940NAME IS NULL:2014/12/30(火) 14:11:44.09 ID:???
>>934
エスケープして格納したいのなら、検索キーワードもエスケープすりゃええ。
941NAME IS NULL:2014/12/30(火) 14:22:13.82 ID:???
インジェクションとか大丈夫か?
942937:2014/12/30(火) 14:31:25.63 ID:???
>>939
その通りでございます。
エスパーですね
943NAME IS NULL:2014/12/30(火) 18:00:06.82 ID:ZOTTcmcS
>>935
ありがとうございます
生データで入れるのが一般的なんですね。参考になりました

>>940
ありがとうございます
そういうやり方もあるんですね

>>941
SQLインジェクションは処理しますので大丈夫です
お気遣いありがとうございます
944NAME IS NULL:2014/12/31(水) 03:07:24.54 ID:sJ8tBVVY
やるんだったら、一応、カラムにBINARY属性を付ける方がいいよな。
945NAME IS NULL:2015/01/04(日) 14:48:03.69 ID:???
ブログの様なシステムを制作しており、そのブログの設定はMySQLではなく静的ファイルに保存するようにしています。

他のシステムを見ると設定自体もMySQLに保存しているようなのですが、設定は1レコードのみのテーブルを用意して保存しているのでしょうか?
設定をRDBに保存するとどうしても無駄が多いように感じてしまうのですが、何か特殊な設定があるのでしょうか?

よろしくお願いします。
946NAME IS NULL:2015/01/04(日) 14:51:38.89 ID:???
なんで1レコード?
nameとvalueのテーブル作って
(1ページあたりの記事数,5),
(背景の色,#f00),
(タイトル,mYbloG),
って放り込めばいいんじゃないの?
947945:2015/01/04(日) 15:06:56.96 ID:???
ありがとうございます。
たしかにそうですね。設定毎のフィールドを用意することを勝手にイメージしてました。

その方法でも設定が少量であればRDBとして無駄に思えるのですが、その方法が一般的になるでしょうか?
設定を参照する度にnameを検索することが少々無駄に感じてしまいます。
948NAME IS NULL:2015/01/04(日) 15:17:59.03 ID:???
まあ何回かやってみれば
テキスト使うのが馬鹿らしくなるのでわかると思う
使い方慣れるまでは面倒かもしれないけど
949NAME IS NULL:2015/01/04(日) 15:18:06.53 ID:???
>>947
製作者がそういう風にしたほうが便利だと思ったからやってるだけ。
あなたは静的ファイルのほうが無駄がないと思っているからそうしているだけ。
よそはよそ、うちはうち。
だから別に気にしなくていいよ。
950NAME IS NULL:2015/01/04(日) 15:18:45.52 ID:???
DBに持たせているとBLOG記事と一緒にバックアップを取ることもできて
便利のような気がするけど。
後はloginid,name,valueとしてユーザー毎に設定を保持できるように
するのも楽だし(もちろん静的ファイルでも可能だけど)。

>設定を参照する度にnameを検索することが少々無駄に感じてしまいます。
静的ファイルから読みだすのと対して変わらないような。
951NAME IS NULL:2015/01/04(日) 15:36:05.90 ID:???
>>947
ユニークIDを付けて、運用時はそれをキーに検索したらどうかな。
952945:2015/01/04(日) 17:33:53.17 ID:???
皆様有難うございます。

15年来設定をテキストファイルで保存していたため、どうもRDBをRDBとして使う以外のことに抵抗があるだけなのかも知れません。
現在はテキストファイルに固定長で保存しているためにポインタをシークするだけで検索などは不要のため、どうも一々RDBに問合せを出すということが無駄に感じていました。

いくつかのWebシステムを読んでみたのですが、MovableTypeは少し特殊な方法かも知れませんが、多くの場合>>946さんの方法で行っているようです。

私もバックアップの事を考えている中でMySQLに入れることを考えたのですが、OpenPNEは画像ファイルもアクセス制限のためにDBに入れるなど、システム毎にいろいろな方法があるんですね。

ありがとうございました。
953NAME IS NULL:2015/01/04(日) 18:50:40.78 ID:???
>>952
俺も>>946のような持たせ方は気持ち悪くてしょうがないけどねぇ。
954945:2015/01/04(日) 22:38:47.41 ID:???
気持ち悪いというか、valueフィールドはchar型にしなければならないので、ブール値や数値を一々変換するのが少々手間がかかる上に無駄に感じていますね。

そのために設定テーブルを作ると考えたのですが、それであれば設定を追加する度にテーブルを変更する必要が有り、1レコードしか無いテーブルを持つことになるのでそれも無駄に感じてしまいます。

私のシステムを変更してみたので、しばらく使ってみようと思います。
955NAME IS NULL:2015/01/04(日) 23:35:20.24 ID:???
何故世界中の多くのシステムでDBが使われているのか
それを考えたら答えは出るよな
無駄だと思うのは設計が間違っているか、DBを必要としないか
今作っているシステムがテキストファイル保存で事足りるならそれでええと思うよ
956NAME IS NULL:2015/01/05(月) 19:39:05.10 ID:ECYaSO8s
テキストファイルだとブール値や数値は
いちいち変換しないのかな
957NAME IS NULL:2015/01/15(木) 13:51:06.34 ID:GI4jYeFb
tinyintやsmallintについて質問です
予め最大値が決まっている小さな数を扱う場合、
現在はすべてint(1)で取り扱っていますが、
tinyint(tinyint(1)はBool型なので、それ以外)やsmaillintを使うべきなのでしょうか?

例えば0〜100までの数しか入らないデータを扱う場合は
int(1)ではなくtinyint(4)にした方がいいのでしょうか?
大は小を兼ねるともいいますが、tinyintにすることによって処理速度が上がったりしますか?
958NAME IS NULL:2015/01/15(木) 18:30:28.61 ID:???
【質問】
double型の項目に、「71.4」という値をセットして、レコードを新規登録
登録データを読み出して、更新しようとすると、エラーが発生する
原因や解決策が分かる方がいたら教えていただけると嬉しいです。

【問題の詳細】
VB6.0 SP5で作ったアプリケーションからMySQLのDBに対して更新を実行すると、下記のエラーが発生。
err=-2147217864
行が見つからなかったため、更新できません。
列の値は最後に読み込まれた後で変更された可能性があります。

【エラーが発生する条件】
1.レコードの登録でdouble型の項目に「71.4」という値を登録
2.登録したレコードを読み出し、更新をすると上記のエラー発生
***注意点***
「71.4」という値以外を新規で登録した場合は、登録したレコードを読み出して更新しても、エラーは発生しない。
その際に、「71.4」という値で更新も可能
更新で「71.4」になったレコードを読み出して、再度更新しても上記のエラーは発生しない。

【環境】
○サーバ側
OS:Linux RedHat Enterprise 6.5
DBサーバ:MySQL 5.1.71(x86_64)

○クライアント側
OS:
 Windows 7(32bit)
 Windows 2k Pro
ODBC:(それぞれのOSで共にエラーを確認)
 odbc3.51.04
 odbc5.01.08

【DBの構成】
DB名:「*****」
テーブル名:「***_***」
問題の項目:
 項目名「******」
 データ型 double ※デフォルト(桁指定無し)
 Null:Yes
※「*」は半角アルファベtット
959NAME IS NULL:2015/01/15(木) 18:39:16.95 ID:???
>>957
tinyintにすれば処理速度はあがります

個人的には、tinyintが好きではないのでsmallintを使います
データの大きさにもの凄くシビアであれば、tinyintを使った方がいいのだと思います。

mysqlのバージョンが変われば、データ型の取り扱いが変わる。(MySQL3.23の頃とchar型が違う)
こんなこともあるので、あまり多くのデータ型を使いたくないのが本音ではあります。
ただ、smallintとintegerでは、違いがかなりあるので、ある程度の使い分けは仕方なし。と考えています。
960NAME IS NULL:2015/01/15(木) 20:19:02.05 ID:???
>>959
処理速度は上がるんですね!
解説も参考になります
ありがとうございました
961NAME IS NULL:2015/01/15(木) 23:08:24.17 ID:???
intやtinyintの()の中の数字は、表示幅だからあんまり関係ない
962NAME IS NULL:2015/01/16(金) 03:44:11.94 ID:???
速度が上がるということについて信頼の置けるソースがなかな見つからず。
963958:2015/01/16(金) 09:02:38.93 ID:???
カーソルロケーションを見失っている感じではあるんですよね。

INSERT INTOでExcuteしてレコードを追加するのをやめてみました。
VB6なので、カーソルロケーションをadUseClientに指定した上で、レコードをオープン
addNewでレコードを追加して、Updateすると
double型項目に71.4をセットしても、更新可能になりました。

SQL文で、Excuteするときに、カーソルロケーションを指定することって可能ですか?
964NAME IS NULL:2015/01/16(金) 13:34:34.83 ID:???
>>963
MySQLの話だと思ってる?
965958:2015/01/16(金) 14:02:53.59 ID:???
>>964
思っています。

あと、わざわざこういう言い方するのは悪意を感じて好きではないです。
指摘したいことがあるなら、指摘してください。
966NAME IS NULL:2015/01/16(金) 14:17:51.50 ID:???
>>965
MySQL以外のDBだと発生しないという事を確認すること
その上で、他の人が再現する上で必要な情報を書くこと
例えばテーブルの定義、インサートするサンプルデータ
VBでやらないといけないなら、その部分のソースも

最低限、ここまでは書かないと誰もコメントくれないと思う。
967958:2015/01/16(金) 14:19:03.87 ID:???
ついでなので。

サーバのコマンドラインから、MySQLに入り
INSERT INTOで、double型に71.4という値をセットしてレコード登録
INSERT INTO ***_*** set seqno = 1, **** = 71.4;

端末(Win 2K)からAccess2000で、該当のテーブルのリンクを表示(ODBC5.1)
ACCESS上から登録した71.4の値を変更しようとすると、「このレコードは他のユーザーによって変更されています」
カーソルロケーションを見失った時のような動きになります。
968958:2015/01/16(金) 14:44:35.77 ID:???
>>966

サンプルですか。
では、現象が発生するデータを作ります。

環境は>>958の前提で。
DB作成
create database bcd;
テーブル作成
create table xyz_table (seqno integer not null default 0, gaikei double default null, PRIMARY KEY (seqno) );
レコード登録
insert into xyz_table set seqno = 1 , gaikei = 71.4;

このデータを、PC側の端末(Win2k Pro)からAccess2000でリンク(ODBC5.1)
ACCESS上からgaikei項目の71.4を変更しようとすると、
「このレコードは他のユーザーによって変更されています」
となり、自分の環境では958で起こった現象が再現できます
969NAME IS NULL:2015/01/16(金) 16:52:24.90 ID:???
「err=-2147217864」でググってみた?
970958:2015/01/16(金) 17:24:07.00 ID:???
>>969
調べてはみました。

INSERT INTO で、double型に「71.4」をセットしてレコードを登録したときのみ発生するのかは分かりませんでした。
自分には見つけられそうに無いので、申し訳ないですが原因を教えてください。
971NAME IS NULL:2015/01/16(金) 20:10:24.21 ID:???
>>970
なんでも人に頼るのはよくないよ。googleったら俺もすぐ見つけられたし。

http://bugs.mysql.com/bug.php?id=38147
これに載ってるところだとODBCドライバを更新するといいんじゃないのかな。
972958:2015/01/19(月) 08:28:20.33 ID:???
>>971
>なんでも人に頼るのはよくないよ。googleったら俺もすぐ見つけられたし。
調べた上で、分からなかったので質問しています。

ありがとう御座いました。
973958:2015/01/19(月) 09:43:24.47 ID:???
>>971
ODBCを更新してみました。

紹介していただいたサイトでは ODBC 5.1.9で正常動作すると書かれています。
ODBC5.1.9、5.1.12、51.1.13ドライバにアップグレードしたところ、
新規にDSNを作成しようとするとサーバのDBを取得できなかったため、接続はやめました。
最新のODBC 5.3.4では、DSNの作成に失敗するため、接続はやめました。
ODBC5.1.8に戻しています。
端末環境 Win2k Pro

教えていただきありがとう御座いました。
974NAME IS NULL:2015/01/20(火) 04:40:23.64 ID:???
ODBC最近使ってないけど、そんな頻繁にまともに接続できない事態に陥るかね。
>>973が事実なら相当ひどいが。
975NAME IS NULL:2015/01/21(水) 19:26:12.66 ID:???
Win2kとか化石使ってることのほうがひどい。
976NAME IS NULL:2015/01/26(月) 13:21:58.44 ID:???
MySQL+PHPのPDOで内部結合した後のfetchなんですが
表に内容が違うカラムがあった場合に、変数的に同じ名前になってしまいます。

テーブルA、テーブルBに果物というカラムがあって
それぞれ、りんご、みかんだった場合
$result = $stmt->fetch(PDO::FETCH_ASSOC);
$result["果物"]はみかんになってしまいます。

foreachで回してみても、りんごはどこにも居ないわけですが
これはテーブル設計が駄目で
対応はテーブルAにテーブルBを内部結合、またはテーブルBにテーブルAを内部結合といった
対策をとるしかないのでしょうか。
977NAME IS NULL:2015/01/26(月) 14:10:59.34 ID:???
AS で名前つけるとかViewを作るとか
978NAME IS NULL:2015/01/26(月) 14:12:00.55 ID:???
select A.果物 as A_果物, B.果物as B_果物 from 〜
979976:2015/01/26(月) 14:20:07.04 ID:???
>>977,978
なるほどこういう機能があったんですね
素早いご回答ありがとうございます。
980NAME IS NULL:2015/02/05(木) 01:49:01.97 ID:???
MySQL 3.23.58 を使用しているのですが、そろそろヤバいので
5.5 にアップデートしようと思っています。

1つのメジャーバージョンの間であれば、データベースファイルが
自動的にアップグレードできるようですが、そのバージョンは
4.0.30、4.1.25、5.0.96、5.1.73、5.5.42
で最適ですか? 間に挟むべきバージョンはありますか?

mysqldump を使う方法も検討していますが、文字コードがまちまちで
sjis を無理矢理バイナリとして格納している古いデータベースとかが
あるので、できれば避けたいです。

環境は Windows 2000 SP4 で、サーバー、クライアントは同じマシン、
主に使用しているクライアントは PHP 5.3.29、Perl 5.12.5 です。
用途は Web の開発用で、ODBC は使用していません。

もっとこうした方がいいとか、助言があればよろしくお願いします。
981NAME IS NULL:2015/02/05(木) 06:46:52.04 ID:???
>>980
どんなパッケージでもいえることだけど、こういうのを順に追っかけるのが一番の近道だと思う。
互換性のない変更もあるから、アップグレードするたびにチェックすること。
http://dev.mysql.com/doc/refman/5.5/en/upgrading-from-previous-series.html

windowsならこれも。
やったことはないけど細かく手順を書いてくれててやさしさを感じた。
http://dev.mysql.com/doc/refman/5.5/en/windows-upgrading.html

あとWindows2000なんてすっかりサポート対象外だろうから、いろいろ覚悟したほうがいいかと。
982NAME IS NULL:2015/02/05(木) 10:54:14.89 ID:???
>>980
> 文字コードがまちまちで
> sjis を無理矢理バイナリとして格納している

4.1以上へのアップグレードはこういうの直さないとうまくいかないから
アプリ修正も視野に入れた方がいいです
983NAME IS NULL:2015/02/05(木) 12:47:30.50 ID:???
>>975
そう?
Win2kは、まだ10台くらいある
Xpは30台くらい
うちは全部で200台くらいだけど、そのくらいの規模で一々MSのご都合に合わせてPC全部買い換えるとこがどれくらいあるんだろ。
984NAME IS NULL:2015/02/05(木) 12:52:30.24 ID:???
200台ってクライアントじゃないの?MySQL入れるの?
まあそれでもクライアントならパフォーマンスやハードのサポート切れたりするから
Win2kはないなあさすがに
985NAME IS NULL:2015/02/05(木) 12:58:34.59 ID:???
>>984
975の話しの流れは、クライアントの話しだよ
クライアントがWin2kで、ODBC接続する話しの流れからだから。
986NAME IS NULL:2015/02/05(木) 15:27:18.93 ID:???
>>983
いろいろ言いたいけど、ピンポイントでいうなら、なぜ買い換えるという発想になるの?
987NAME IS NULL:2015/02/05(木) 17:12:45.31 ID:???
>>986
なんでこんな関係ない話しを広げようとするのか分からないけど・・・
買い換えるという発想にならないから、Win2kやXPも残っているという話しなんですが。
どうして、これに食いつくのか理解出来ない。
988NAME IS NULL:2015/02/05(木) 18:32:48.73 ID:???
>>987
食いついたとか、広げようとか、そんな豪勢なもんじゃないよ。
何でPCを買い換えるんだろうなって思っただけで。
管理者じゃないんだろうし、どうでもいい話でした。
989NAME IS NULL:2015/02/06(金) 00:14:36.22 ID:???
普通OS入れ替えだよね
990980:2015/02/06(金) 01:55:35.44 ID:???
>>981 >>982
どうもありがとうございます。

今日確認したところ、Windows 2000 は安定してますが CRT がそろそろ
逝ってしまいそうな感じでしたので、当初予定していたアップデートを
あきらめて、現行のサイトを保管しているマシンにデータベース単位で
同居させることにしました。

移転先は Windows 7 に MySQL 4.1.25 がインストール済みです。

ここは慎重に data ディレクトリ丸ごとのコピーはせずに mysqldump を
使うやり方を採用することにしました。

いざダンプした取り込もうとしたところ sjis のテーブルの取り込みで
いきなりエラーが出てうまくいきませんでした。

エラーが出る箇所を見ると '十' とか2バイト目が 0x5C になる文字の
後ろに \ が入って '十\' になってるんですよね。

確か 3.23.58 のころは INSERT INTO t VALUES ('十\') にするのが
正解だった気がするので、これが入らないとなるとコードの方もかなり
直す必要が出てきそうです。

最近は 4.1.25 で utf8 しか使ってないので、こういう不自然な処理を
普通にしてたのを久しぶりに思い出しました。

まあ、とりあえず叩けば映るので、必要に迫られるかさくっと挿入できる
いい案が浮かぶまで温存させておくことにします。
991958:2015/02/06(金) 08:25:23.01 ID:???
>>990
CSVに落して、CSVファイルをインポートするっていう形はどうですか?
テーブル名が日本語の場合、エンコードが違うことでSQL文の実行で失敗することもありますが、半角英数のテーブル名であれば、これで移行できるかもしれません。

CSVにエクスポート
str = "select * from " & TableName(cnt) & " "
str = str & "into outfile 'C:\" & TableName(icnt) & ".csv' "
str = str & "fields terminated by '\,' "
str = str & "enclosed by '\'' ;"
''SQL実行
ado.Execute str, result

CSVからインポート
str = "load data "
str = str & "infile 'C:\" & TableName(cnt) & ".csv' "
str = str & "into table " & TableName(cnt) & " "
str = str & "fields terminated by '\,' "
str = str & "enclosed by '\'' ;"
''SQL実行
v_ado_conn.Execute str, result
992958:2015/02/06(金) 18:15:22.05 ID:???
ごめんなさい。
手持ちのソースからコード抜粋したので余計な部分も載ってます。
SQL文だけ参考にしてみてください
993NAME IS NULL:2015/02/07(土) 04:42:09.46 ID:???
日本語の表示で、枠線の位置がずれるのは何が原因かな?
文字コードはmysqlもphpもsshも全部utf8なんだけど。。。
http://i.imgur.com/DEvIins.jpg
994NAME IS NULL:2015/02/07(土) 04:57:35.88 ID:???
ターミナルの設定の問題。CJKの文字幅設定がどっかにあるじゃろ。
995NAME IS NULL:2015/02/07(土) 22:44:08.84 ID:???
Cjkにチェックを入れても変わらないですね。。
996NAME IS NULL:2015/02/07(土) 22:46:56.41 ID:???
あ、ぱっと見でCJKの問題だろうとは思ったんだけど、それってmysqlが作ってる表自体がずれてるって話かな。
ならmysqlの出力設定になんかあるんでないの
997NAME IS NULL
>>996
そうなんですよ。mysqlの出力の表が日本語が含まれてるとずれるんです
この設定であってますよね?
http://i.imgur.com/SzMcSA5.jpg