>>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文書かないとダメだからちょっと工数かかる、その代りスケールしやすいって感じなんですかね。
>>221 まず基本として
USE INDEXをつけてインデックスを使うものは
データやプランナの問題か、根本的に必要がない。
USE INDEXをつけてインデックスを使わないものは
DBの仕様の問題か、インデックスの貼りかたの問題
これPostgreSQLでも常識だろうが
で、USE INDEXをつけたときとつけないときの、応答速度はどうなんだい?
>>221 >小さい規模はPostgreSQLで、大規模はMySQL
それは気のせいだ
>>222 USE INDEXをつけてインデックスが使われた場合は0.03秒、使われなかった場合は1.2秒といった結果でした。
PostgreSQLは適当にSQL文書いても、割とインデックス使ってくれます・・・。
>>223 インデックスを使わないシークの数の上限設定ができたはず。
PostgreSQLを触っててMySQL触りだすと
昔と違って今だと、シビアにチューニングできなければつらいだけ
ポテンシャルはMySQLのがまだ高いけど、大体はPostgreSQLに負ける
でもなんとなくgoogleとかfacebookが使ってるMySQLを使ってしまう。
そりゃシビアにチューニングできる会社だからな
同じく出来るなら使えばいいんじゃね
ホスティングとか自社サービスじゃない系はPostgreSQLかそれベースのものが増えてるからな
大規模はMySQLて何を根拠にしてんだろ?
google mysql やめるって
MariaDBにするってだけでしょ?
自力で実装しなきゃなんないシャーディンクを
標準機能とでも思ってるのでは
233 :
NAME IS NULL:2013/11/18(月) 23:41:16.44 ID:WRQu7dQ3
というか、オラクルがスキあらば金取ろうとして超うざい。
わざわざ会社にまで電話かけてくんなマンカス>日本オラクルの馬鹿女
今となっての大きな違いはマルチスレッドかマルチコアかぐらいの違いぐらいか。
クラスタリングに関してはMySQLだろう
大規模ってそういう事じゃないの?
>>236 枯れきってるって意味ではな
サポート頼るならpostgresのがいい
>>234 読んできた。結構知識が偏ってるようで
2004年で日本は既にMySQL > PostgreSQLだったような
今は逆に、世界の方がPostgreSQLの比率が多い
postgresもamazon rdsでもサポート始まったしな
MySQLはオワコン
かといって素直にみんなMariaいくかと言えば
「まてよ」と一度考察が入るのでそうでもない。
オラクルのMySQLつぶしはほとんど成功だな
>>239 FaceBookが利用してるやり方やDeNAがやってることとか考えると
MySQLじゃないとだめな用途はちゃんとある
PostgreSQLもビッグデータ系で多々使われるようになってるし
クラウドと実は相性が良いということもあるし
どっちもこれからまだまだいける
>>240 >FaceBookが利用してるやり方やDeNAがやってることとか考えると
>MySQLじゃないとだめな用途はちゃんとある
例えばどんな? 否定でなく、単純に知りたい。
>>238 > 読んできた。結構知識が偏ってるようで
俺もそう思う。大規模の定義がFBとGoogle。この2社以外はコスト的にAWSに敵わないみたいに読める。
実際はそんな簡単じゃないんだけども。
データを自社に置くか置かないをコストだけで判断しない業種がたくさんあるわけだが、
そういう視点がすっぽり抜けてる。
>>242 いや、2010年ころの話をされても。。。。って思った訳っす。
上のスライドの趣旨としては、2000年−2005年くらいの状況として
大規模はMySQLを選んだみたいに言ってるようにみえるから。
>>242 ついでにいうとFBやGoogleみたいに中身をぐちゃぐちゃに改造して
大規模対応って言われてもなぁみたいな。
中を改変しちまえば、そりゃなんでもできるじゃないという。
MySQLは大規模に向いているという理由が理解できない。
スレッドベースだとなんでLLと相性いいの?
>>243 どこにもそんな古い話ではかかれてないよ
今の話だよ
>>244 それは作者に聞いてください
MySQLがPostgreSQLより大規模に向いてるとは僕は思ってない
>>241 知識は偏ってるね。
まぁ、元 MySQL のサポートエンジニアでその後は WEB系でしか働いてない人だししゃーないかな。
>> 俺もそう思う。大規模の定義がFBとGoogle。この2社以外はコスト的にAWSに敵わないみたいに読める。
>> 実際はそんな簡単じゃないんだけども。
>> データを自社に置くか置かないをコストだけで判断しない業種がたくさんあるわけだが、
>> そういう視点がすっぽり抜けてる。
俺もそう思うが、そういう人は相手にしてない資料なんじゃないかな。
正直、人事系とか外に出すなんてって思っちゃうけど、
今後 AWS 使うのは普通になる世の中が来るのかね。
昔は業務系、今は WEB系で働いてるが、WEB系に関しては、
よっぽどのことがない限りコストでは AWS の RDS のほうが有利だね。
細かなチューニングとか、トラブル時の調査とかしにくいけど、
チューニング出来る人雇うぐらいならスケールアップしたほうが安いっていう。
>>248 一通り見た。
コネクションプールを使わない場合は
MySQLのがコネクションを貼るコストがスレッドだから安いから速いってことか
複数台構成の場合コネクションプール使うし
1台の場合貼りっぱなしで問題ないから理解が出来なかった
>>249 コストの話も極論だよな。つうか、DBAなんてコスト部門でしかないわけでさ。
効率化すればするほど自分たちのクビを締めることになるんだよ。
だからMySQL使ってると、
バージョンアップ毎に膨大な作業が発生してDBAのクビが繋がる、
マッチポンプ ウマーって思うときもある。
>>250 そう。そのレベルでMySQL大規模有利っておかしい。
JAVAならプーリング使えばいいし、LLでもpgpool使えばよかったわけだし。
>>249 > まぁ、元 MySQL のサポートエンジニアでその後は WEB系でしか働いてない人だししゃーないかな。
キャリア戦略で「ダメな技術は誰もダメといわない。自分で見分けろ。」って書いてるけど、
これってMySQLのことかと思ったw
pgpool使っても接続数減るわけじゃないからな。
あれはポスグレへの接続コスト削減とロードバランシングか主なメリット。
それとも今のバージョンでは1コネクションで同時にクエリー発行できたりするの?
よくわからんが接続コスト低けりゃそれでいいんじゃないの?
スライドの主張についての話なら。
接続数はMySQLもポスグレも変わらないだろ。カネ払ってスレッドプール入れるなら別だけど。
接続数が多い場合、昔はポスグレもMySQLも遅かったよ。
そんでポスグレのほうが並列実行性能がはやく向上した。
InnoDBはずっと遅いままだった。
255 :
249:2013/11/20(水) 00:27:28.94 ID:???
昔に関して言えば、ポスグレはレプがなかったのと
VACUUMのせいで避けるようになってしまってたな。
レプがないのは、Web系では結構つらい印象(参照系がおおいので)
大規模、小規模関係なく、プール(≠永続化)しない場合は
スレッドベースである MySQL のほうが性能は稼げるかな。
プールをはさむと管理、トラブル対応めんどいとかもあるし。
>>255 レプとVACUUMの問題が解決してから世界で一気に利用者増えたし
そういうことなんだろうな
台数が多いとプールはさんだ方が管理、トラブル対応は楽よ
257 :
249:2013/11/20(水) 00:41:29.88 ID:???
>>251 > コストの話も極論だよな。つうか、DBAなんてコスト部門でしかないわけでさ。
> 効率化すればするほど自分たちのクビを締めることになるんだよ。
> だからMySQL使ってると、
> バージョンアップ毎に膨大な作業が発生してDBAのクビが繋がる、
> マッチポンプ ウマーって思うときもある
要は、AWS で RDS(マネージドDB)使うのが当たり前になると、
そういう仕事が少なくなるから、フルスタックエンジニアに成るか、
スペシャリストになって AWS では満足しないような大規模なところで
働くかしかなくなってくるよって書いてあるんだよね。
AWS(RDS) なんてって思うっちゃうけど、利便性とか対障害性とか
本当にローコストで使えてしまって、エンジニアとしてあれに対抗するの
きちいって最近いつも思ってる。
.
>>256 オラクルに問題があるだけじゃないの?
259 :
249:2013/11/20(水) 00:51:08.95 ID:???
>>256 > レプとVACUUMの問題が解決してから世界で一気に利用者増えたし
> そういうことなんだろうな
多分最大の問題は Oracle だ。
あのニュースが流れた時、ポスグレに移行するかほんとうに悩んだ。
> 台数が多いとプールはさんだ方が管理、トラブル対応は楽よ
プールがある方が性能は上がると思うんだけど、
管理とかトラブルはどうなんだろ。
接続先を増やすときとか、アプリのコードだけじゃなくて、
プールの設定も追加しないとだめだよね?
別のものを挟むとやっぱり面倒くさくない?
同時接続数を制御下におけるのはでかいと思うよ
基本アプリにはコネクションプールが接続先
なので、DB台数が増えたときはコネクションプールの設定だけ
>>255 Linuxなら今やスレッド起動もプロセス起動もコストはほとんど変わりないけどね。
2000年頃は確かに違ったけど、2005年頃には(カーネルバージョン忘れたけど)
プロセス起動も軽快になったんだけどね。
レプリケーションは確かにWEB系では必須だわな。
ただし、非同期レプリケーションで参照分散つうのが大規模といわれてもなぁと思うわけだ。
>>257 >要は、AWS で RDS(マネージドDB)使うのが当たり前になると、
>そういう仕事が少なくなるから、フルスタックエンジニアに成るか、
>スペシャリストになって AWS では満足しないような大規模なところで
>働くかしかなくなってくるよって書いてあるんだよね。
それは一理あるんだけど、コスト+利便性でいえば集中型が最もよいけど
世の中、かならず集中と分散を繰り返すじゃない?RDSの先に何がくるか考えてるよ、俺。
スライド書いた人、ソニー、MySQL、DeNA、顔本らしいね。いく先々クラッシュしてるのが面白いと思った。
そういう価値観で会社選んで、キャリア戦略なんつうスライド書いたんだなって。
ポスグレはDBの機能として、
ファイルシステムレベルでオンラインバックアップの取得が可能
レプリカも全く止めずに作成可能
これがいい
263 :
NAME 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
何で急にストレージ側の機能が出てくるんだ。
要するに出来ないんだろ。
こいつの突っかかり方キモイな。
TechCrunchにこんな事書かれちゃうのは仕方ないよね
> PostgreSQLは、OracleがSun Microsystemsを買収してMySQLを手中にして以降、人気が増大している。
> OracleはMySQLのオープンソースな側面に関心を示さなくなったため、メンテ放棄を恐れたユーザはPostgreSQLへの引越しを開始したのだ。
これから日本は
>>234に書いてあるような日本市場の特殊性が起きるわけだ
>>264 >こいつの突っかかり方キモイな
こいつだなんて、自称ギーグの日本男児様をしらないのかw
日本男児様のブログさえ読んでればトランザクションも知らないWEB野郎たちは幸せに暮らせるんだ。
なにせ日本男児様はMySQLを完全無欠にみせてくれるからw
postgresにhandlersocket的なものがあれば移るわ。
>>267 FDWのエクステンションつくればいいんでね?
269 :
NAME IS NULL:2013/11/20(水) 21:29:52.99 ID:kMGPfKTL
mysqlってwindowで使用するよりlinuxで使われること多いのか?
windowsで使われることが多いRDBMSなんてAccessとSQL Serverくらいだから
>>269 LAMP
俺はWin+MySQL+Excelですけどw
>>265 > これから日本は
>>234に書いてあるような日本市場の特殊性が起きるわけだ
どうだろうねえ。
新規プロダクトはポスグレも増えるだろうけど、
すでにMySQL方言でガチガチにつくりこんだプロダクトはマリア一択だね。
オープンソースのデファクトプロダクトの多くはMySQL依存が強烈だから。
逆だろ、世界はpostgresにいくのに日本はmysqlのままってことよ
mariaってinnodb使えなくて大丈夫なの?
>>273 いやいや、世界がポスグレに流れるのかって。
もともとビジネスユースはOracle->ポスグレの流れはあった。ビジネスユースでMySQLなんて使いものにならないじゃない。
まともにジョインもできない、コロコロ仕様がかわるし。
WEB系はMySQLが強くて、オープンソースのプロダクトもMySQL依存が強い。
MySQL独自SQLを使いまくってるプロダクトが多いから、いまさらポスグレに移植できないものも多いのが実情。
どのプロダクトだってのは書かないけど、かなり多いよ。
移植が失敗したプロダクトもいくつか知ってる。どれもその分野のデファクトでポスグレ未対応。
DB詳しくない人たちが開発するから、MySQL独自機能をつかいまくって移植不可能なくらい
複雑なコードになってたり、
「PHPのDBO使ってるから移植できるっしょ」くらい軽いノリの開発者ばかりなんで
移植の問題自体を認識されてないとか。
DB屋とアプリ屋の溝はとても深いよ。
>>274 > mariaってinnodb使えなくて大丈夫なの?
MariaDBはInnoDBバンドルされてるよ。
InnoDBは一応オープンソースだし、Oracleが改造した機能をMariaDBも独自に取り込んでる。
それとInnoDB互換のXtraDBもバンドルされてるし。
Oracleに潰された
>>276 それでライセンスとかオラクルの存在とか大丈夫なの?
mysqlから世界が逃げ出したのって、INNODBが買収されたとき始まったんよね
xtradb作ったのは別の会社なんだよな。
使ってみたいけどサーバースペックある程度無いとinnodbと性能変わらないんだっけ?
>>279 性能がどういういう奴にかぎって、ろくでもない馬鹿SQL走らせてるよなあ。
ベンチマークばっかやってる奴とか。
>>278 だからオープンソースっていってるじゃん。
マリアだってMySQLのフォークなんだし。
自分たちでなんとかするのがオープンソース。
>>281 ライセンスやオラクルに対する見方が違うのがよくわかった
>>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。
>>283 maria5.5.32にstorage/innobaseとstorage/xtradbがあるんだけど、
それでもCREATE TABLE .. Engine=InnoDBってやるとXtraDBになるの?
だとすると、なんでソースがバンドルされてんだろ。
>>284 なんでか知らないけど昔から両方ある。
Percona ServerのXtraDBはstorage/innobaseの下にしかないんだけどね。
SHOW ENGINESをよく見ると、InnoDBの説明にXtraDBって書いてあって、どっちやねんてかんじだけど。
286 :
NAME IS NULL:2013/11/23(土) 07:16:12.52 ID:qVAyetp/
mysqlを勉強してる
タブレットにインストールすることは
可能?
まったく的外れだったら申し訳ない
タブレットにもいろいろあってだな・・・
windowsのタブレットなら出来るんじゃない
windows8がそのまま入ってるんでしょ?あれ
タブレットに入れる意味はないと思うけどな
289 :
NAME IS NULL:2013/11/23(土) 08:55:54.32 ID:qVAyetp/
286
プラットホームを書き忘れてました
Android4.2.2 Snapdragon
タブです
Windowsタブだったら問題なかったんですが
いかんせんandroidなんで、
外出先での勉強用としてと思ってます
NotePC持ってるんですが
タブレットの軽さに慣れてしまって。
ネットにつながるならVPSなりを借りて使うのが無難
どう入れるのか知らんがarmでもmysqlは動くようなので入れようと思えば入れらるんじゃないか
足りないパッケージは多そうだけど
sqliteの勉強だったら出来るけどな
android標準dbだし
>>289 Androidスマホだけど、Bit Web Serverってのを使ってる。200円くらいだったはず。
こっちで聞けと言われたので質問させてください
mysql5系の質問です
DBを作る時の「MyISAM」と「InnoDB」の違いがよくわかりません。
ゴミでもわかりやすいように教えて頂けないでしょうか?
_, ._
( ゚ Д゚)
( つ旦O
と_)_)
_, ._
( ゚ Д゚) ガシャ
( つ O. __
と_)_) (__()、;.o:。
゚*・:.。
以上ゴミがお伝えしました
297 :
NAME 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
みたいな風に列を作らないといけませんか・・・?
しないといけないってことはないけど、それでも実装はできるんじゃない?
逆に値の列だけでどうにかしようとすると、先頭に"!!"をつけているものは非公開と判定するとか
ユーザーが入力したものかどうかを確実に判断できるように実装しないとバグるけど
作らないといけないっていうか、普通そう作るよね
何が嫌なんだ?
それか公開情報カラムを1つで作ることも出来るけどね
そのカラムの数字が
2の倍数なら名前公開
3の倍数なら年齢公開
5の倍数なら住所公開
7の倍数ならプロフィール公開
11の倍数なら出身校公開
みたいに
いや、普通はやらんが
301 :
NAME IS NULL:2013/11/29(金) 20:48:03.33 ID:ld8Q8jAS
>>298-300 普通はこうするんですね
列の数が増えてしまうのが嫌だったのですが正攻法なのであればこれでいきます
>>301 あんまりお勧めしないけど、どうしても嫌なら公開情報テーブルを別に作る
ユーザーID
該当テーブル名
公表フラグ
あとは公表フラグを元にプログラムで判定させる。
もしくはmemberテーブル自体を、
ユーザーID
該当項目(該当テーブル名)
値
公表フラグ
にしてしまう。これなら横に追加しなくても良い。
MySQLのスレでポスグレでもオラクルでもできるテーブル設計の話
ドヤ顔で始めるチンカスってなんなの?
304 :
NAME IS NULL:2013/12/01(日) 14:48:22.43 ID:u1FkK0X5
答えは
1:g, 2:g, 3:r, 4:k, 5:s
ですね!ありがとうございます!
wwww
まるち、ていわないんだ
310 :
NAME IS NULL:2013/12/09(月) 17:10:32.62 ID:KDrt2ZmL
予約語を避けるにはどうしたらいいかな
適当な接頭語をつけるのが一番楽かな
311 :
NAME IS NULL:2013/12/13(金) 15:44:13.33 ID:UakRrOee
本気環境で使うのにRedhat標準のものをずっと使い続けることがありえない。
特にMariaの方はVersionUpも頻繁に行われるだろうし。
RHELにはいったのはMariaDB5.5。安定版だよ。
それにディストリ固有のパッケージ使いたい人たちが多数。
普通はパッケージ管理なんてやりたくないんだよ。
そもそもMySQLのバージョンアップのほうがキツいだろ。
ボロボロの状態でGAリリース、何年たっても不安定。
>>313 出たばっかの頃はいいが、そっから3年くらいはずっとそのままのバージョンで行くんだぜ。。。
そなるといずれは自分で入れることになるんだから。
>>315 >そなるといずれは自分で入れることになるんだから。
MariaDBをだろ
だからMySQL終了だっつうのw
>出たばっかの頃はいいが、そっから3年くらいはずっとそのままのバージョンで行くんだぜ。。。
まじめな話、Maria10.0なんてまだαだし、5.5で数年行くのは正しいだろ。
Maria5.5とMySQL5.5はほとんど同じだし。
RHELなど主要ディストリビューションがMySQLからMaria5.5から切り替えたのはデカイよ。
よほどの物好きか、最新版大好きの素人しかMySQL5.6に移行しないだろう。
もうずいぶん前から予想できたことだろ
このスレでも何回もMySQLはオワコン、Oracle完全犯罪的な話出てきたろ
既定路線
インデックス張ってももう無理だ
レコードが7億いった・・・
すっごw
320 :
249:2013/12/14(土) 15:52:25.95 ID:???
>>318 十分なメモリと、最適なインデックスの追加、利用さえしておけば、
レコード数だけが問題になることはない気がするが...
(1レコードのサイズが大きいテーブルのレコード数が増えるのは問題
メモリが足りないんだったら、SSD にするかメモリつむ以外ないんじゃないかな。
経験上は下手なインデックスの利用、下手なテーブル定義が問題となることが多い。
メモリ 72G で 20億レコード、インデックス含めて64Gのテーブルとか運用してるけど
レコード数がどうこうより、データサイズどうにかしたい。
7億レコードなんて別に大したことじゃ無いと思うが。
インデックスがメモリに乗らなくなったって言いたいんだろうけど。
日本レコード大賞
一度にひとつのキーでしか検索しない設計なんですが
どのキーで検索するかは状況によってバラバラです
検索に使われる予定のキーに かたっぱしからインデックスを
張っといた方がいいですかね?
>>324 そりゃするけどさ、念のために聞いておきたかっただけじゃん?
あと、これも実測しろと言われるの間違いなしなんだけど、
結果がひとつだけだと確信できるクエリのときも、あえて
LIMIT 1をつけたほうが速いのかな。 速そうな印象はある
テーブルスキャンのときは LIMIT 1 で早くなるはず
>>318 四の五の言わずにioDrive入れちまえ。あのコスパの良さは明らかに異常。
インストールするときにChoosing a Setup Typeのとこで
Developper Default, Server only, Client only, Full, Customから選びますがどのような違いがあるのでしょうか?
その質問をする人は、Defaultで問題ない
簡単に言うとインストールされるファイルの組み合わせを選ぶ
具体的な違いを教えろって?ggr
試しにインストールしてみたのですが、Developper DefaultとFullは同じな気がします。
331 :
NAME IS NULL:2013/12/27(金) 11:01:17.77 ID:RABYehPe
InnoDB三ヶ月に1回ぶっ壊れるようにわざとしてるだろ?
不満なら有料のもの買えってことか。
タダより高いものはないな。
壊れねぇよ
どういう使い方してんだ
333 :
NAME IS NULL:2013/12/27(金) 15:24:27.52 ID:9aKIae9M
練習用としてXAMPPを使用しています
バックアップとして
mysqldumpを使います
mysql>mysqldump -u root -p9999 c_9>c_9dump.sqlで
あってるのでしょうか。
mysql>(コマンドプロンプロが間違ってる?)
--password=9999
335 :
NAME IS NULL:2013/12/28(土) 18:29:01.47 ID:ZNxoVZ7w
WIN7のこまんどぷろんぷとから実行したいのですがstartしてるのを確認してmysql -u root -pを実行しても
バッチファイルとして認識してませんで出来ないです 助けて
336 :
NAME IS NULL:2013/12/28(土) 18:43:08.57 ID:ZNxoVZ7w
自己解決
環境変数だった
337 :
NAME IS NULL:2014/01/10(金) 11:05:07.42 ID:oqp795AA
在日の親は、子供を朝鮮幼稚園・朝鮮学校に入れたいっていうのが多いのよ。
日本人からすると、なんでだろうって思うけど、日本人の学校では、民族の誇りを持った教育がしてもらえないんだそうだ。
よく分からないけど、流刑者の白丁が密入国して住み着いたじゃ誇りが持てないけど、日本人に強制連行された被害者なら誇りが持てる、とかそういう事かな??
市原市の能満は昔から市街化調整区域で、新規の建物は造れないことになっている。
そのため土地が安く、日本の法律を無視した在日が、次々と移り住んできた。
そこで問題になったのが、朝鮮学校だ。なかなか許可が下りず、一番近くても千葉市にしかない。
そこで在日居住区の能満内にあった、能満幼稚園・市原小・市原中・緑高の保育士や教師を、朝鮮化する事を考えた。
今では通称在日幼稚園の保育士は全て朝鮮帰化人で、在日の父兄からの絶大な支持を受けている。
遠くからでも、わざわざ通称在日幼稚園に入園させたいという在日の親は、後を絶たない。
この在日幼稚園卒園者はほぼ朝鮮系の帰化人と在日で、現在各所でクレーマーとなり問題を起こしている。
338 :
NAME IS NULL:2014/01/13(月) 11:07:38.33 ID:JNIvUl1u
MySQL5.5でInnoDBでロックのためにSELECT FOR UPDATEを使ってるんだけど
運用したら、ユーザー2名に同時に参照される不具合が起きてしまった
ユーザーAのトランザクション中は、ユーザーBはその行を読み出せないと思ってたけど違うの?
>>338 〜〜 FOR UPDATE で排他ロックをかけてるときは、理解の通りロックかけたトランザクションが
コミットかロールバックするまで、ほかのトランザクションはいかなるアクセスもできないはず。
読みだしはできる
341 :
NAME IS NULL:2014/01/13(月) 16:15:38.53 ID:JNIvUl1u
ユーザーBのSQL次第
343 :
NAME IS NULL:2014/01/13(月) 16:31:32.26 ID:JNIvUl1u
なるほど、やることはAB両方共同じで
トランザクション開始
SELECT FOR UPDATEでレコード取得
有効レコードなら無効(売約済み)にUPDATE
トランザクションコミット
というコードになっています。
ところがAB共同じレコードを取得してしまった、という問題です。
この場合どこがおかしいのか、悩んでしまって…。
両方 UPDATE 付いてたら待たされるはず。
ロックかかってるとSELECT失敗するわけじゃなくて、終わるまで待つだけよ?
試しに手入力でやってみては
345 :
NAME 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を発行しているので、そこが何か悪さしてるのかな。だとしたら調査に時間がかかりそうだ。
>>345 実はSQLでデータ取っていなくて、サーバのキャッシュを取得していたとかいうオチでは?
347 :
NAME IS NULL:2014/01/13(月) 19:10:51.42 ID:JNIvUl1u
>>346 CakeのSQL発行関数にcache=falseの指定はしているんだが
そのくらいしか考えられないな…もう一度確認してみますわ
クエリーログ取るんじゃダメ?
349 :
NAME IS NULL:2014/01/13(月) 19:31:35.69 ID:JNIvUl1u
うーん、何度見てもキャッシュはしっかりfalse指定されてた
実は滅多に再現しないから、ログ取るようにして気長に再発を待つしかないかな
どこかに FOR UPDATE 抜けたやつが紛れ込んでるな
351 :
NAME IS NULL:2014/01/14(火) 12:19:47.09 ID:5XYg85D5
それがなさそうなんだよねえ…。コード中1個所しかないし。
引き続き調べ中ですが、再現が難しい感じです。
データベースサーバは1台だよな
353 :
NAME IS NULL:2014/01/14(火) 16:19:13.50 ID:k7q4QSRl
トランザクションレベルはどうなってんすか?
実はInnoDBじゃない
分離モードがREAD UNCOMITTED
FOR UPDATEついてないSQLで取得したデータ見てる
横やり失礼。
先発のトランザクションが SELECT ~ FOR UPDATE している間、
後発のトランザクションの読み込みを待たせたい場合は、
後発のクエリに「LOCK IN SHARE MODE」をつければOKって認識であってますか?
356 :
NAME IS NULL:2014/01/14(火) 17:11:53.87 ID:5XYg85D5
DBはマスターとスレーブの2台。今回の処理はすべてマスターに対して行っている。
テーブルは全てInnoDB。
分離モードはREPEATABLE-READ。
FOR UPDATEついてないSQLが万が一にも発行されていないか調べているが、アクセスするコードは1ヵ所しかないので考えにくい。
てな状況です。
ありがとうございます。
>>356 SQL文のログは取って調べたのかな?
アプリ側のコードとにらめっこしていてもしょうがないよ。
[mysqld]
log=ログファイル
359 :
NAME 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実行時間オーバーというエラーが表示されます。
どのようにすればタイムアウト(もしくはテーブルロックを検知)できるのでしょうか?
363 :
NAME IS NULL:2014/01/19(日) 12:16:32.40 ID:hD4Sosha
>>362 5.5.2やったわ。
試してみます。ありがとう!
364 :
NAME IS NULL:2014/01/19(日) 20:10:06.21 ID:yCiVwpc9
Linuxに入ってるMySQLを外部PCからリモートで操作して
ユーザ作成する場合、ホスト名はLinuxのホスト名で大丈夫ですか?
>>364 そのLinuxのプログラムでデータを取り扱うのならlocalhostでいいんじゃね。
>>364 それMySQLの話ちゃうやろと思いつつ、 hostsとかその手のファイル、DNS次第。
MySQLチームで募集中のプリセールスエンジニアは技術が重視されるので営業関連の経験は無くてもかまいません。ご興味のある方はDM下さい。 #mysql_jp
We Are Hiring!! 業務急拡大中につきMySQLチームでは日本でプリセールスエンジニアを募集しています。
ttps
t.co / xUXSf2pO3C
お前らの出番だぞw
転職めんどい
業務拡大じゃなくて
人が逃げたから集めるようにみえて仕方がない
Oracleの奴隷(プゲラ
あるテーブルの主キーになってるserial型columnを他のテーブルで外部キーに指定しようとしてもできません。助けてください。
そんなはずがない
「他のテーブル」でインデックスも何も張ってないとかいうオチでは?
374 :
371:2014/01/30(木) 23:41:25.25 ID:???
たぶん
>>373これでした。ありがとうございましたm(_ _ )m
たぶん ってw
おいおい大丈夫かよ・・・本職じゃないよな
5.6で高スペックサーバでの性能が飛躍的に向上したな
PostgreSQL抜き返したかな?
innodbにphpmyadminで33000件のデータをインポートしたのですが、なせか表示は31000件です。移動ボタンで最後のページまで飛ぶと33000件目を含むデータが表示されます。これは仕様なのでしょうか?それともどこかを修正すれば表示を改善出来ますか?
>>378 今DBに登録されてるデータをinto outfile してインポートしたデータと比べてみてはどうでしょう。
dbに 「33000件のデータをインポートし」てselect count(*)で33000件って出たらmysql側には問題なし
php側の方がおかしいんでしょ
phpがおかしい
>>378 phpMyAdmin で表示されるレコード数は、INFORMATION_SCHEMA というメタデータから引っ張ってきてるのですが、
InnoDB では概算値となるため、実際のレコード数と phpMyAdmin 上で表示させる値に誤差が生じます。
正確なレコード数を取得するには SELECT COUNT(1) FROM **** クエリを発行してください。
>>378 です。
皆さんありごとうこざいます。
innodbの仕様だったんですね。
安心しました。
はじめまして、相談です。
現在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分前後かかっています。またこの先テーブルはますます大きくなります。
インデックスを貼って見ましたが、あまり早くなりません。これぐらいが普通なのでしょうか。
また、他に少しでも早くする方法はありますか?
このテーブルの用途は、趣味で作っている人工無能です。
>>384 インデックスは、first, prev1, prev2, prev3 の複合インデックス張ってる?
いまの主キー、インデックスも教えてくれないとわからん。
あと1万行くらいのダンプデータがあると検証ができてなおよし。
386 :
384:2014/02/12(水) 21:48:45.80 ID:RkkOXYbS
WHERE条件で大量のデータが返るのならORDER BY RAND()ではなく
対象件数を取得、その範囲の乱数を生成、LIMIT <乱数値>, 1とした方が早いかも。
EXPLAINでインデックスが使用されているか調べることが先だけど。
>>384 可能であればdescの結果か、show create table の結果を貼ってください。
>>386 388です。すいません、更新してませんでした。
ちょっとあっぷして頂いたデータでやってみます。
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)
どう見てもインデックスがないんですが。
391 :
384: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
ちょっと勉強してきます。。。
なるほど、確かにインデックスを設定すれば15倍はやくなりそう
>>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を設定するだけでも改善すると思います。
394 :
384:2014/02/12(水) 23:22:10.38 ID:RkkOXYbS
「同時に1つのインデックスしか使えない」って仕様に引っかかりやすいよね。
複合インデックスは頭からしか使えないからカラムの順序に注意。
あとインデックスには指定したカラムに加え、主キーが入るってことも知っておくと役立つ。
64bit版のRHEL6.4にバンドルされてる5.1.66で
got signal 11
のエラーがでてmysqlが再起動します。
mysqlのバグで5.1.59以降では治ってるって書いてある
サイトがあったんだけど、再発したんでしょうか?
回避する方法ってなんかあります?
ちょっとヒントがほしいです
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)に貼っていて、ちゃんとに使われている。
>>397 FIND_IN_SETのカラムにインデックスを張っても効率化されないと思う。
関係者にごめんなさいして第一正規化するか、
とりあえず妥協して複合インデックスを(user, date)に張ってみる。
それからSELECT article_dateなのにGROUP BY dateとなっているが、
転記ミスでなければこれはGROUP BYのよくない使い方。
SET sql_mode = ONLY_FULL_GROUP_BY;
で動くSQLに直してからチューニングを考えたほうがよいかも。
>>397 別になんの不思議もないと思いますが?
インデックスを使ってレコードを絞り込めるが、
それの集計やソートにテンポラリテーブルやクイックソートが必要ってことかと。
urlを保存する時って
1つのカラムに「http」削って
://〜
って保存するのと、「0=
http://、1=
https://、2=
http://www」とかって定義して2つのカラムに
1(int) 2
0 yahoo.co.jp
って保存するのでは後者の方がいいよね?みんなの保存方法を聞きたいです。
この後どう使いたいかにもよるんだろうけど
加工せず丸ごと保存ではだめなのか?
>>400 区切らない
それで節約できるのはURL読み出し時の数バイト
とんでもなく大量にhttp〜で始まるなら別だが、普通に要らない
この後はただそのurlを表示するだけの用途で検索対象にはなりません。
少しでも容量を減らしとけばいいんじゃないかな、と思ったのでそういう工夫をしている人がいたならと思い聞きました。
TEXT型で丸ごと保存が一般的なんでしょうか?
>>402 ありがとうございます。
ググってもそういう話題がなかったので、普通はそういう必要はないってことなんですね。
データは千万以上はいきそうです。
>>404 はい。インデックスさえ貼れば割となんとでも
>>404 ありがとうございます。
innoDBで5.514なんですが先輩にTEXT型はなるべく使うなと言われてまして、varchara(255)で
日本語文字urlの場合、decodeしたりして保存したりしようと試行錯誤してます。
TEXT型で保存が一般的なんですね。参考にさせていただきます。
先輩がTEXT型使うなと言っているのは分かるけど、
URLのような長い文字列を扱うなら仕方ない。
1億レコードを超えたあたりからキツくなってくる感じかな。
便乗質問で悪いんだが
>>397のケースの場合ってmy.cnfの設定がダメってことなんかな?
FLOAT型の列column_aに対して以下のSQLを発行したのですが、データが取得できませんでした。
column_aの値が15.55のレコードは存在しています。
SELECT * FROM table_a WHERE column_a = 15.55;
基本的なことで申し訳ないのですが、どこがおかしいのか教えていただけないでしょうか。
MySQLのバージョンは5.6.14です。よろしくお願いいたします。
>>410 ありがとうございます!まさにこの通りでした。
レンタルサーバー借りる基準にMySQLのバージョンって重要視する?
エックスサーバーが5.5.xって書いてたから借りたら金払った後に5.0.xだとわかった。
なんか腹立たしい気がするけど5.5と5.0って速度違うの?
>>412 もしかして5のDBサーバー2台あるんじゃない?
接続先確かめてみたら?
>>413 >>414 エックスサーバーに問い合わせたら、今アカウントを取り直したら5.5.x使えるよ、今使ってるアカウントじゃ使えないよって答えられた。
先月アカウント買ったばかりなのに。
>>415 >エックスサーバーが5.5.xって書いてたから借りた
この辺を強く出してみたら?
>>416 うーん、まだサイトは作成中だし初期費用と3ヶ月しか支払ってないからアカウント取り直そうかな。
たぶん言ってもどうにもならないと思うし。
>>418 余計お金掛かりそう…。
さくらは5.5が提供されたら同じアカウント内で変更できるみたいだね。
失敗したかなあ。
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の中身を打つと正常に更新はされるんですけど…
なんで??
421 :
420: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
422 :
NAME 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件ずつ表示させていきたいと思っています。
どなたか解る方がいれば、ご教授お願い致します。
>>422 やりたいようにやればいいんじゃないかな。不具合が無くて問題無く動くなら邪道も何もないよ。
つか処理に問題があるかどうかを聞きたいならここで質問する内容ではない。
424 :
249:2014/02/27(木) 13:56:12.28 ID:???
>>420 改行コードとかじゃないのかね。
手元の 5.6.16(Ubuntu 12.04) だと LF でも CRLF でも大丈夫だったが、
Windows だとか Version によってダメなのかな。
それぐらいしか思いつかない。
mysql自体のクエリキャッシュ機能と
javaのehcacheみたいなアプリ側でのキャッシュライブラリは
どういう基準で使い分けるんですか?
426 :
249:2014/03/01(土) 22:31:26.99 ID:???
>>425 Webサーバが2台(A,B)あったとして、
AのキャッシュにMySQLのデータの一部が乗っている場合、
Bが MySQL を更新した場合どうする?
DBに入ってるデータとしては
ほとんど更新されないけどDBなどに入れておきたい
なにかのマスターデータとかは、アプリ起動時にDBから
とってきてローカルにキャッシュ。更新されたらアプリを再起動。
それ以外はクエリキャッシュとかが多いんじゃないかね。
まぁ、クエリキャッシュはアプリによっては切ったほうが
性能がいいけどな
クエリキャッシュ、最近は非推奨って言ってる人が多いね。
近年の数十〜数百コアのCPUで並列処理させると逆にパフォーマンスが落ちるとかで。
428 :
426: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
Linuxで5.6入れたら今までの方法でエラーでまくりワロタw
このデフォルトでエラー吐きまくる糞仕様のmy.cnfなんとかならんかな
しかもエラーコードも全然役に立たないし。
重要な調整項目についても全然解説ねーし、
1つバージョン違うだけでオプション変更されすぎ。
ただでさえクソ長い英語のドキュメント読みなら作業してんのに報われなさすぎ。
ポスグレは日本語のドキュメントが充実してるのに
MySQLはなんでないんだろう?
金にならないから?
>>429 仕事で5.6の構築手順書作ったけど、5.5からはだいぶ変わったよ。
英語のドキュメントを読んでも情報不足なんだよなー
>>429 いれて3分でデータベース とかってうたい文句はどうしたんだろうなw
mysql本体のバージョンはすぐ判るんですけど、PCに入っているodbcドライバのバージョンは
どうやったら確認出来るんでしょうか?
つーか、パッケージ名もコロコロ変えすぎ。
なにがどれに対応してるのか一覧書けや
あーイライラするー!
435 :
433:2014/03/08(土) 18:49:43.83 ID:???
管理ツール→データソース(odbc)→ドライバー
で確認
以上
XADataSourceにXAリカバリ失敗のバグがあるの?
ORACLEはゆっくりとMySQLを殺そうとしてるんだろ。
Win版のセットアッププログラムとかどんどんクソになってるよ。
公式のMySQLインストールした場合って、
phpmyadminってどこの入れたらいいの?
いつもどおりyumでremiの入れようとすると、
remi版のMySQLインスコしようとしてバッティングするんだけど。
教えてエロい人。
何言ってんのかわからん
phpmyadminって普通にディレクトリに置いてブラウザからアクセスするだけでしょ?
ていうか、そんなphpで作ったやつじゃなくて普通のSQLクライアントだったらHeidiSQLとかOracleのMySQL Workbenchがオススメだけど
>>739 ホントだ。解凍して置いて設定したら動いたわー。
これってそんな簡単な構造だったんだね。
MySQL公式のリポジトリでインストールしたMySQLってyumで依存関係めちゃくちゃになるんだね。
元々サードパティのライブラリなんかは共存するように設計されていないんだろうけど、
悩んだ悩んだ。
ありがとうエロイ人
442 :
NAME IS NULL:2014/03/10(月) 20:55:48.40 ID:TC9gqAVZ
739はどんなことを書くんだろう
今年中に739までいくのかね
呼んだか、139
mysqlの全文検索とelasticsearch
どっちがいいですか?
>>441 おま、yumってことは、redhatかcentかfedoraか
ディストリビューション使うなら外のrpmとかソースからコンパイルとかダメだぞ
何のためのディストリビューションなのかわからん
自由にやるならfreebsdかなんかにすべし
451 :
NAME 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
どこか間違ってるかわからんのだが。。
AUTO_INCREMENT
アンダースコアがない
auto_increment
AUTO INCREMENTと見せかけて
> use near '-> id
いやAUTOも間違ってるんだけど
455 :
NAME 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
456 :
NAME 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さんが意図していたことと齟齬があると思います。
よければ教えて頂けないでしょうか
>>456 書き方が悪かったね
AUTO INCREMENT だけじゃなくて -> も間違ってると示したかっただけだよ
なるほど mysql> も打ち込んじゃうタイプか。
新人研修のときそういう同期いたなあ
459 :
NAME IS NULL:2014/03/18(火) 01:02:40.19 ID:YYxIyd7p
ありがとう御座います!
プログラミングの入門書で本のサンプルを行番号込で打ち込むようなもんか
461 :
NAME IS NULL:2014/03/18(火) 13:05:32.96 ID:We3J6S8O
【社会】厚労省の中で男が刃物取り出す 銃刀法違反の現行犯で逮捕
ttp://genzo.org/read/uni.2ch.net/newsplus/1389346716/ 今後の犯罪傾向の予測と考察
事前面接(偽装請負)の犯罪に憤りをもつ派遣社員、非正規労働者、失業者が
比較的警備の薄い厚労省、労働局、 労基署にいく可能性がある。しかし他の可能性
を考えてみた。
事前面接中(指揮命令中)に派遣先と派遣元の担当者をターゲットにしたテロである。 派遣社員の事前面接(指揮命令)は違法であり、事前面接中(指揮命令中)に派遣社員(請負労働者)が暴れだした場合は
警察に通報できない状況となる。つまり通報すれば労基法6条違反、
職安法44条違反などの犯罪事実が報道で日本中に周知され、グッドウィル事件の再現となる可能性 が出てくる。そのため被害者である派遣先・派遣元が加害者に高額の口止め料
(影響を考慮すれば3000万円以上が妥当)を支払い隠蔽しようとする奇妙なテロがおきうるのだ。
※グッドウィル摘発のきっかけとなった事故は、現場の派遣スタッフの意図的な自傷事故だったとする説がある。
仮に、怒りに我を忘れた派遣社員が、派遣営業や面接官の小指を切り落とすような
凶行がおきた場合、小指を失った社員は転職や社会活動が難しいため、現在の会社で
は降格・減給などの奴隷的待遇を一生耐えるしかない。会社は隠蔽を優先し
派遣社員への高額の口止め料で手を打ち、被害社員はひたすら耐えるだけだ。
※非力な女性でも防犯スプレーとスタンガンで社員の抵抗を事前に抑止して小指の切断ができる可能性がある。
非正規の奴隷的待遇は、共産・民主党を支援してきた労働組合が
構成員である大企業の正社員の雇用や、給与水準をまもるための正社員保護主義の結果である。非正規や下請け正社員はその犠牲であり受給調整弁として中間搾取等をされたり労働者の権利を剥奪された。正社員の解雇ルールが立法化されれば、大企業も正社員
を増員し、違法な中間搾取、雇用・契約止めの脅し、理不尽な待遇、差別をする要因が排除されるが、これを労働組合は派遣・非正規を
犠牲にし正社員の給与水準を高くするため徹底して反対している。このため非正規
労働者が労働組合、民主党や「連合」の襲撃をする余地がある。
あ、レスきてたw
CentOSでやってました。アドバイスありがとう。
既にコンパイルはあきらめてyumでインストールしましたw
最新のものに食いつくにはCentOSは向かないね。
安定ヽ(´ー`)ノマンセー
mysql 5.6.17
464 :
NAME 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
やはり何かファイルが足りないのでしょうか?
465 :
464:2014/04/02(水) 05:13:46.30 ID:???
ごめんなさい
すいません投稿スレ間違えました・・・
レプリケーションの設定をしたいのですが、
レプリケーション先のデータベース名を違ったものにすることはできますか?
こんな感じです。
SRC:TESTDB
DST:TESTDB_REPLICA
マニュアル見てみたのですが、該当する項目がありませんでした。
バージョンは、5.6です。
>>466 statement-based の場合なら、
slave 側で trigger 使えば出来そうな気がする
# 一時的には同名テーブルにデータが存在してしまうが
mix/row-based の場合は厳しいんじゃないかな
通常の方法では難しいと思う
>>467 クエリの中で、UUID()関数を使用しているため、SBRでは難しそうですね。
諦めて同名レプリケート運用にしたいと思います。
貴重なアドバイスありがとうございました。
MySQL 初心者で、アドバイスお願いいたします。
ID(1〜)にインデックスが張ってあり数万件あるとします。
一番大きなIDから(降順)10件取り出したい場合
SELECT * FROM `テーブル` ORDER BY `id` DESC limit 0,10
で取り出せるのですが、インデックスがあっても全文検索?になり
今後件数が増えると時間がかかりそうです。
高速に取得する一般的な方法はどうやるのでしょうか?
別のカラムを使ったり、複数のSQLになってもかまいません。
MySQLのバージョンは5.5で、言語はPHPを使ってやりとりしております。
>>471 idが「1から連番で抜けがない」という都合のいい前提が許されるなら
where句に`id` between 1 and 10でいいと思うけど、まずダメよね。
元のクエリはインデックスを頭からスキャンしていく(末端にいくほ
ど遅くなる)けど、テーブルのフルスキャンほど遅くはない(と思う)
ので、実際に想定される最大数のレコードを作ってみて許容できる速度
かどうか見てみるのがいいんじゃないかな。
ちなみにうちはMariaDBだけど、10万レコード作ってlimit 99990,10で
クエリ走らせてみたら0.06秒だった。
limitはlimit 1000,10とか、offsetの値が多くなればなるほど重くなる。
だからできるだけ避けた方が良い。
>>471 limit 10000,10みたいに真ん中取り出してもインデックス使われませんか?
offsetがでかいとかなら分かるが、
SELECT * FROM `テーブル` ORDER BY `id` DESC limit 0,10
が遅いというのがわかんない
どうやって「全文検索」って判断したんだろ
476 :
471:2014/04/04(金) 21:02:06.33 ID:???
みなさまアドバイスどうもです。
インデックスが使われているかどうかもよくわからないんですよね。
EXPLAIN で type が index だと全文検索?ですよね。
471 のSQLだとでちゃいます。
このSQLで0.1秒、今後10万件とか増えてきてもこの時間で処理されるんだろうか
心配になってお聞きしました。
>>475 「ORDER BY 使うとインデックスが使われない時がある」?みたいな記事を読んでです。
>>476 explainでrowsの数が検索数だと思
>>476 typeがALLになってたらフルスキャン。
>>476 typeが"ALL"ならテーブルのフルスキャン、"index"ならインデックスの
フルスキャン。ということでインデックスは一応使われてる。
>>471のクエリの場合、「インデックスの頭」からoffset+limitレコード
をなめる(limit 10000,10なら10010レコード)けど、これでインデックス
を張ってなかったらテーブルスキャンになって全レコードをなめに行く。
それにしても先頭10件で0.1秒は遅すぎじゃないかな。
>>476 type=indexは通常、インデックスフルスキャンなので一般的に重いが、
order by `index_column` limit ?の場合は例外で、
インデックスの先頭もしくは後ろから数件読むだけなんで高速。
(offsetが大きくなるなら別)
> 「ORDER BY 使うとインデックスが使われない時がある」?
というのは、
select * from where `index_column` = ? order by `primary_key`
みたいなクエリのとき、通常はindex_columnのインデックスが使われるはずだが、
オプティマイザが主キーインデックスを使ってしまうケースがあって、
その場合にフルテーブルスキャンを引き起こして、洒落にならないくらいにクソ重くなることはある
481 :
471:2014/04/04(金) 21:57:11.63 ID:???
>>477-479 type 'index' は インデックスのフルスキャンでしたか!
インデックスが使われていることに一安心しましたw
>それにしても先頭10件で0.1秒は遅すぎじゃないかな。
phpMyAdmin上で実行しているので
実際はもっと高速なのかもしれません。
アドバイスどうもでした
clustered?
助けてください。
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ファイル]で開く)
どれも毎回アンインストールして、再起動してから入れなおしました。
わかる人がいましたら是非回答をお願いします。
なんか同様の報告は海外フォーラムで結構あがってるようなんだけど、
ざっと見た感じパスがおかしいとかそういうのが多いな。
C:\Program Files\MYSQL\/(Dataのインスコ先)C:\Program Files\MYSQL\Data\MYSQL_x.xxx\
ところでこれは何で2回ドライブレターが出てるの?こぴぺみす?
486 :
483: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
ああああ・・・・やっぱりあかん。
>>484 レスありがとうございます。
手法は違いますがレジストリからは情報を消して挑んでました。
サービスからMYSQLを起動させると1067エラーが出ますね。
>>485さんの言われている通りパスのエラーのようですが・・・。
>>485 Installation Path/Data Pathを分けて書いたんですが、余計にわかりにくくなってますね。
ごめんなさい。
確かにご指摘の通りパスがおかしそうなんですが、iniファイルとかを見直して見ます。
489 :
483:2014/04/08(火) 00:13:20.36 ID:???
490 :
483:2014/04/08(火) 19:59:30.84 ID:???
導入できました。
あの後も色々試しましたが結局の所msiファイルからのインストールはできませんでした。
その代わり
>>488さんから教えて頂いたzipからの導入方法で無事動く事を確認できました。
benchもzipで導入してMySQLエディタが動作する事を確認できました。
ありがとうございます。
491 :
NAME IS NULL:2014/04/09(水) 16:36:51.01 ID:UnA+HtrF
mysql-connector-cでプログラムを書いているのですが、mysql_queryでUPDATEのSQLを実行したときに
WHEREで該当するレコードがなかった場合にはエラーになるのでしょうか
実行した時にエラーが返ってくるのですが
以前図書館から借りた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
5.6のGTIDってバグりまくりで使いものにならないってほんと?
5.6.17まででだいたい直ったと思う
質問です。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)
といったエラー文が出て、そこから何をしたら良いか全然わからず困っています。
上記メッセージで検索すると出てくる解決法は前提条件が違ったり、
書いてある解決法が省略されすぎていて理解できません。
何をどうすればよいのか教えていただきたく。
レスありがとうございます。
しかしおっしゃっている意味がわかりません。
具体的にどうすればよいのでしょうか。
ちなみにログインはrootユーザで行っています。
pmaユーザでログインはしていません。
MySQLのクエリくらい簡単だから直打ちしやがれ。
PHPなんだから、自分でPMAだけ入れなおせばいいじゃん
セッティングスクリプトはちゃんと消しておけよ
質問ですがFacebookとかのいいね!ボタンの設計ってどうなってるんでしょうか?
・webページ毎のカウントtable(url、カウント
・誰がドコにいいね!したのか記録table(ユーザー、url
を作ったとしても1兆レコードぐらい簡単に行ってしまいそうな気がするんですがmysqlは大丈夫なんですか?
それとももっと良い設計とかあるんでしょうか?
webサイト毎にtable作るってのも考えたんですが
以前ココで1000万テーブル作ったりするのは設計ミスとか言われたんで
>>502 どんな質問をして設計ミスって言われたのか知らん。
ただ言えることは、規模とか用途とかによってテーブル設計が変わる。
まあそれでも1000万テーブル作るってことは無いと思うけど。
>>502 テーブルパーティショニングとかそこらへんの話だろ
やっとでたか
SQLインジェクション対策したいんですが、
$test = $_GET['data'];
//エスケープ
$test = mysql_real_escape_string($test);
$result = mysql_query("select * from aaa where name = '{$test}'");
このようにmysql_real_escape_stringでエスケープしてれば、SQLインジェクションって防げますよね?
防げない場合どういうパターンがあるのか教えてください
508 :
NAME IS NULL:2014/04/15(火) 17:40:11.51 ID:+eHKgKM6
レプリケーション時に マスターに障害発生したら
スレーブ⇒マスター切り替え はよく目にするんだけど
その後元マスターが復旧したときに
マスター⇒スレーブ を安全におこなう方法がよくわからない
DB起動する前にマスターがいたら云々というバッチを作るの?
一度死んだ奴をマスタに戻す必要があるのか?
俺が見てるスレだけでも3つのスレでマルチしてるなコイツ
PHPスレで回答もらったっぽいけど
普通にchange masterすればいいんじゃね
posがずれていないかとか、そもそもパラメータがACID特性を満たす設定になっているとか確認すべき項目はあるが
インデックスがかかっているカラムに対してIN句を使って
データを抽出したいと思っています。
WHERE id IN (id1, id2, id3……)
ソースが雑なのと条件が増えた時に遅くなりそうなのでもう少しスマートな
方法はないものかと思っているのですが、いい処理方法はないでしょうか?
id1,2,3はどうやって出してるの?
>>514 それは前画面にチェックボックスがあって、そこでチェックした時にidを仕込んで
次画面でREQUESTから取得して、配列からカンマ区切りにしてid1,id2,id3…としています。
前画面というものが条件に合致したデータを全て表示して、
そこからチェックボックスで選択したものだけに対して、次画面でデータを
再度引っ張ってきてデータ内容の詳細表示をするというような画面になっています。
IN句を使えばできてはいるのですが、何かちょっと…と思いまして。
idを出す手段に規則性が無いならそうやるしかないと思うけど。
>>516 やっぱりそうですかー
このままやることにします。ありがとうございました。
集計のクエリーについて質問です
例えば都道府県の名前をユニークキーとしたマスターテーブルがあり
そのキーを使用したログテーブルがあるとします 訪れた場所[北海道、千葉、東京、千葉、大阪]
それを
北海道 1
千葉 2
東京 1
大阪 1
のように複数レコードで集計したいのですが下記のように書くと
SELECT 県名, count( 県名, ) FROM ログ WHERE ログ.県名 IN ( SELECT マスター.県名 FROM 都道府県 マスター )
最初の県名[北海道]と全ての合計数[5]と1レコードで終了してしまいます
各合計を求めるにはどのようにすればよいでしょうか?
よろしくお願いします
ああ・・・こういう時にGROUP BY を使うのですね
失礼しました
520 :
NAME IS NULL:2014/04/19(土) 14:30:09.16 ID:tdLBPxz0
デフォルトストレージエンジンがMyISAMのままなんだけど
デフォルトストレージエンジンをInnoDBに変更することに
なにかメリットはありますか?
MyISAMは使ってませんがテーブル作るときはちゃんと
InnoDB指定してるから今まで気づかなかったわ
指定しなくてもInnoDBになる
それだけ
最近のバージョンだと、システムのデータベースもInnoDBになるとかなかったっけ
>>521 おうサンキュウ
それくらいしかメリットないなら面倒くさいし放置しとくわ
InnoDBってバックアップ取りにくくていやなんだよな
みんなテーブル名は大文字小文字混ぜてる?
大文字固定? 小文字限定?
何も考えずにSELECTしたときのソート順が
なぜか主キー順になってるんだけど、そういうもの?
以前は適当というか、順保証なんてなかった気がするけど
いつのまにかデフォルトソート順が仕様で決まったとかある?
主キーが連番で、UPDATEしたことが無いテーブルなんだろ
InnoDBでフルテーブルスキャンしたら、主キー順番になるはず
それはInnoDBが行データをクラスタ化インデックスで保持しているから。
MyISAMなら、ばらばらになるんじゃないかな
>>528 そういうことね
InnoDB使うようになって日が浅いから気づかなかったわ
ありがとう
InnoDBの構造上きれいなテーブルなら、上からなめれば主キー順になるだろうけど
それはたまたまたで「主キー順になることは保証しません」ってことでしょ。
まぁ、実務でSELECTする時にORDER BYを付けない
シチュエーションなんてほとんどないからどうでもいい話しだ
事情があり、サーバーマシンのホスト名を変更しました
mysqlでエラーが出ているので調べたところ、
pidファイルにサーバー名が使われていました。
mysql運用中にサーバーマシンのホスト名を変更したため、ファイルが壊れたようです
バッチバックアップでは修復処理も走らせているのですが、それでも修復できていませんでした
こういう壊れ方をしたファイルを修復することはできないのでしょうか?
古いプロセスをkillしてから
myisamchk --safe-recover
したら、エラーなく起動しました
思わぬトラブルで青ざめました
535 :
NAME IS NULL:2014/04/28(月) 13:41:34.40 ID:yPNR6/Ul
InnoDBでファイルコピーのみでバックアップ取りたいけど
どのファイルをコピーしたらいいかな?
/
MySQLモニタ上で
mysql> ほにゃららこまんど
'>
ってなるんですが '> ってどういう時に表示されますか?
またネットで検索するときに「mysql '>」とか検索しても '> が無視されているような感じで
今後自力で検索するときにはどうやって検索すればいいでしょうか?
ほにゃららこまんどの末尾に;を付けてないから
;ついてます(´・ω;;;;;;;;`)
->じゃなくて
'>
select 'ほにゃららこまんど
だな
主キー って「しゅきー」って読みでいいんでしょうか
あるじキー
ぬしキー
だいしゅきぃ
だいちらい
どうしても分からないorz
社内で、情報参照のためにMySQL+PEAR+PHP+Apacheでデータベース作ったんだけど、
これが好評で社外に公表してはどうか、という話があるんだけど、これってどっかに
ライセンス料収めないとあかんの? PostgresSQLなら問題ないという話もあるけど。
WEBブラウドで使うPHPで作ったデータベースのUIが「プログラム」にあたるとすると
GPL汚染されてアウトなんだろうか。こんなんでデータ公開みたいなことになると
正直やってけませんが。別に無料で普通に使い続けていいよね?
MySQL関連だと下記のことをやっていたら、すべてのプログラムのソースコードを公開する必要がある
・MySQLのプログラム自体を改造
・PHPからMySQLに接続する際、libmysqlclientを使用している場合(これは可能性があるって話だったかも)
一つ目は多分していないだろうし、二つ目はPHP5.3以降に組み込まれているmysqlndを使用すれば問題ない。
普通に使う分には問題無いと思うけど、それでも気になるならMariaDBを検討すればいいんじゃね?
え、libmysql 叩いただけでGPL感染するの?
インタプリタによるリンクはNG
動的リンクのみOK
PHP自体もGPLにしなければいけなくなって
Mysqlに除外条項が作られたんだよ
551 :
NAME IS NULL:2014/05/14(水) 12:27:31.73 ID:3pPFWZhr
alter tableで特定のテーブルのcharacter_set_clientを変更することはできますか?
553 :
NAME IS NULL:2014/05/15(木) 10:38:18.02 ID:7rqME05r
>>552 ぐぐっても見つけられないのですが
やり方を教えてもらえますか
ちょっと特殊な要件でinsertやupdateは自動変換してほしくて、selectは変換しないでほしいと言った
使い方をしたいのですが
>>553 要件はしらんが、やり方はぐぐってすぐわかるんだが。
ググり方下手なんじゃないの?
>>553 > ちょっと特殊な要件でinsertやupdateは自動変換してほしくて、selectは変換しないでほしいと言った
> 使い方をしたいのですが
そもそもalter tableで解決するの?
保存している文字列自体の文字コードを、character_set_clientを変更することにより自動で変換したいように見える。
もちろんそんなことは出来ないけど。
具体的に言うと、テレビのEPGデータがshift_jisと思われるのですが
海外のソフトを使うとテーブルがUTF8なんで文字化けしちゃうので
EPGテーブルをテーブルにinsertするときに変換して
検索するときにはUTF8で使いたいという内容です
>>556 character_set_clientを変更しても解決しない。
アプリ側で文字列をUTF-8にエンコードするしかないね。
ものすごい初歩的なこと聞いていい?
日付データ的なもので、年と月までのデータがあるんだけど、
これってどうするの? 今はとりあえずテキストで1999年12月
とか入れてあるけど、期間で検索できないから困ってる。
日付に1を入れておく、とか?
昔の文献のデータベースを作ってるんだけど、
昔の文献には作成年月日が詳細に書かれていないものが多くて、
月までしかわからないものは月までにしておかないと、
詳細に作成年月日がわかっているものと区別がつかなくなる。
それに下手に1日とか15日とか入れちゃうと、期間検索したときに
不都合多そうで。
mysqlだと日付に0入れることが出来るけどね
こんな感じで
insert into dd values ('2014-05-00');
>>561 昔、悩んだことがある。
日だけ別のフィールドを作れば理論的には区別できるけど面倒。
実用的には日まで気にして検索することは少ないので、日が不明なのは15日と仮定し、オリジナルのデータを別フィールドで持つことにした。
>>562 それって言語によって2014-04-30と認識しちゃうとか?
ポスグレ移行も考えてるのでなるべく標準に近いデータにしたい。
どうすりゃいいんだろ。普通に年・月のデータってあると思うんだけど
ググってもわからないし。
え、6桁の数字とか文字にするのはだめなの
うちの音楽DBは不明は1日にしちゃってる
>>565 日付の足し算、引き算の必要がないなら、ストリングでよいですね。
期間指定して検索もできます。
INTEGER でいいじゃんか。
計算も工夫すりゃそのままできるし
>>565 >>568 いやそれだと日付が詳細まで入力してあるのが、、、、、と思ったけど、
10桁の数字にして月までのデータは末尾0000にすればいいのか?
期間検索できるし。日数計算できないけど、それは考えようか。
、、、、、、、とすると、今まで入力した日付データを変換するには、、、、
5000くらいデータあるけど、手修正かorz? 質問してよかったぁ。
数万になってからでは目もあてられんかったorz
数字10桁の期間検索用フィールド入力→日付データに日付型に
変換して入力(月までのデータは適当に)とかかなあ。あー面倒orz。
俺なら精度のカラム作るな
>>569 まあどれがいいかは今後の運用方法によるけど
変換はUPDATE文工夫すれば数十万件なら一瞬だよ
>>572 文字型では難しくて、日付型だと簡単なのは、日付の足し算、引き算だけでは?
>>561 の文献データベースなら、日付の足し算とか引き算は
文字型でも期間指定で検索ができるよ。
PubDate >= "1853年07月08日" AND PubDate <= "1854年06月01日"
少し話は違うけど、「嘉永6年」ではなくて「癸丑」と干支だけ書かれた文献もあるよ。
>>573 ×
>>561 の文献データベースなら、日付の足し算とか引き算は
○
>>561 の文献データベースなら、日付の足し算とか引き算は不要では
(´・ω・`)バックアップ取るとき、default-character-setにbinaryを指定するのって変?
バイナリーが文字コード依存じゃないからよいのでわー
Mariaさまがみてる
会社でmysql使ってるんだけど
Dumpしたデータをリストアしようとしたら、途中から急にメモリが跳ね上がってサービスが強制終了するんだけどなんで?
どこ調べても解決しない
入門本というか基礎本一冊終わらしたんですが次に買うのにオススメの本はありますか?
本読むのも良いし止めろとは言わないけど、自分で実際にデータ入れて作業してみたら?
そこで、外部制約かけたりとかストアドプロシジャ作ってみるとか
それから自分で出来る言語でDBアプリ作ってみるとか
phpMyAdminでインポートタブのなかのフォーマットの中にCSV load dataみたいな名前のやつがあったのに無くなってしまった
元に戻すにはどうしたらよいですか?
584 :
NAME 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
>>584 下のが早いならそれでいいじゃん。
count(*)してるからじゃないの?
>>584 books.book_idには主キーかインデックスを作ってあると思うけど、
それを大前提として、それでも遅いならディスクI/Oかなあ。
Linuxならiostat -xm 1 で r/s と %util を見て。Windowsは知らん
>>584 2つのクエリのEXPLAINの結果を張ってくれ
588 :
NAME 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テーブルがつくられてしまってなど原因があるのでしょうか
数えたりしてるために遅いのでしょうか?
>>588 プラン同じだね。
下は結果がが50万行出てくるけど、50万行垂れ流すのが0.0027秒で終わるわけがない。
何らかのGUIツールを使っていて、1画面だけ表示、暗黙的にLIMIT 100とかしてない?
つまり上が遅いのではなく、下がインチキしている(最後まで処理をしていない)と言いたい。
プラン見る限り一時テーブルは作ってない。
それで個人的な感想ですけど、50万行の集計が2.2秒というのは「十分に速い」です。
明らかにI/Oはしていない。I/Oしてたら数分かかる。
もっと速くしたいなら前段にmemcachedなどを入れて結果をキャッシュしよう。
あと、メンテナンスがつらくなるのでおすすめはしないけど
テーブルを非正規化してcommentsテーブルにdeletedカラムを入れてもいいと思う。
それで1秒は切れると予想。
>>584 なぜcountなのにgroup byがないのですか?
left join使わず、出力も1行でいいですよね?
>>588 booksにdeleted,book_idの複合インデックスってないのかな?
あとはleftでなくinnerかな。こっちのが普通かと
>>588 ちなみに、count(comments.comment_id)だとどう?
つまり*は重いので、取得は1列。
他は内部結合、インデックスと。
こんなんんで2秒かかってたらPostgreSQLにボロ負けなんで許せません
あっちはハッシュを使ってくるのでどう戦いますかな
596 :
NAME 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以外のとこで速度をあげるようにすべきでしょうか。
>>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
600 :
NAME IS NULL:2014/06/01(日) 17:38:21.57 ID:otWRvot4
Mysql + HeidiSQLを使って社内でデータ管理をしようと考えています。
データベースを作成し、データを数千件インポートしたところまではよかったのですが
数人で編集した場合に HeidiSQL では排他制御が掛らずに上書きされてしまいます。
HeidiSQL でロックすることは可能でしょうか?
その前に当然のことながらInnodbにしていて、トランザクションはかけていると。だよね?
んでその分離レベルは?
こういうツールは複数人で同時に編集するものじゃないでしょ。
トランザクション使って排他制御したとしても、古いデータを上書きする確率は減らないと思うよ。
selectしてから右クリックして編集押して編集完了して…までずーーーーっとロックしとくの?
アホかよ
DBをweb化して社内でどう活用する予定ですか?
いつ誰がどのくらい処理を発生させるんですか?
phpなどを使わないなら、accessだけで十分では?
601です。皆様ありがとうございます。
まだ勉強不足で質問するのが早かったように思います。
申し訳ありません。
>>602 データタイプはInnodbです。トランザクションに関してはわかりませんので調べてみます。
分離レベルの答えになっていないかもしれませんが、テーブル単位でロック出来ればと考えていました。
>>603 phpMyAdminよりも使いやすいツールを探してHeidiSQLを選びました。
複数人で同時編集には向いていないのですね。
>>605 DBは顧客管理になるのですが、複数の営業所で情報を一元管理するのが狙いです。
更新作業は5〜6人が日に数件ほどかと思います。
accessでは排他制御と矛盾していますが、同時編集が出来ないと聞いていましたので
除外していました、再検討してみます。
管理ツールをみんなでクライアント代わりに使うなんて
共有フォルダにエクセルのファイルおいてみんなで使うようなもんか
ACCESSだと今誰が編集中とか分かるし、時間ずらせば問題はない
ただ負荷がかかるとしょっちゅうファイルぶっ壊れるから正直嫌い
でもすぐ修復できるしバックアップも簡単で使いこなせば便利で安い
もしぶっ壊れるなら、PHPとかで外注がいい、その程度なら多分安いよ
もしくはGUI内製、簡単だよ、プログラム多少分かる人いればすぐ作れる
そういやinnodbで「where句なしcountがクソ遅い」問題どうなったかな?
本来WHERE句省けるところ、GROUP BYさせてWHERE句つけても結局遅いのかな
みんなで編集はGoogleDocsまじおすすめ
612 :
白バラ十字軍:2014/06/10(火) 15:47:48.99 ID:gr7v9uKn
今では殺人事件凶悪事件が起こると創価員かというぐらい
ネットではささやかれる時代になりました。刑務所受刑者の33%は創価員という事実は有名な話ですが、以下を見れば納得ができます
創価員が裁かれる 判決の際 法廷にこだまする「 池 田 先 生 万 歳 !」
◎以下これ以外にまだまだ創価員の犯罪多数あり、書類送検されていないだけであなたの街でも多数すさまじい事件の数が
発生しましたし、まだまだ毎日のように創価員による凶悪事件は発生しているのです!
しかもこれ以外にもTVでも報道された凶悪事件多数あり!。あなたの周りにも潜んでいる。
危険です。危機的状況です。酒鬼薔薇だけではありません。実にたくさんいるのです
あなたの街でも善良な人間のように取り繕い潜んでいるのです。
●宅間守(在日)→大阪 附属池田小学校児童殺傷 創価学会員。大量殺人犯 。8人殺害 15人が重軽傷。悪徳 朝鮮人部落出身。
(悪徳カルト)両親も創価学会員。獄中結婚したが相手の女も創価員。さすが創価員は悪徳な者を好む。あえて結婚する
とは殺人破壊者を賛美、美化、擁護する行為 2004年死刑執行 獄中結婚した女は慰謝料損害賠償払ったのか?被害者に詫びたのか?
宅間は被害者に詫びていない。つまり・・・判決の際 法廷にこだまする「 池 田 先 生 万 歳 !」ということ
日本の犯罪史上、稀に見る大事件
●畠山鈴香 (在日)→秋田県児童連続殺害事件 創価学会員。悪徳。(悪徳カルト)
●斉藤勇太 →JR取手駅前バス無差別殺傷事件 創価学会員。悪徳。(悪徳カルト)
●酒鬼薔薇聖斗→ 東慎一郎(在日)神戸の首切り魔で酒鬼薔薇聖斗 創価学会員。神戸の首切り魔。生首を校門に飾る。悪徳2人殺害。
元在日朝鮮人。両親も創価学会員(悪徳カルト)
●福田孝行(在日)→山口県母子殺害 殺害後屍姦、乳児も殺害 創価学会員。悪徳(悪徳カルト)
●阿部隆 →長野母子バラバラ殺人事件(平成元年)船橋市幼児バラバラ殺人事件 千葉県船橋市の熱心な創価学会員・A・A子さんと長男
のHちゃんが、同じく学会員である夫のA・Tに殺された。動機は生活苦。バラバラにされた死体が聖教新聞に包まれ、長野県の山中に捨
てられていた 悪徳(悪徳カルト)
おまえさんはどこのカルトだい
cakephpからDBへの値の送り方がわからない
まずマルチやめろや
すごい前のレスだけど
直接物理バックアップ取るなら隠しフォルダのprogramData内にMysqlのフォルダがあるのでその中のdataフォルダをコピーすればいい。ただし、MySQL止めた状態で。
ぐぐれば詳細出てくるはず。
ENUM型を使う場合、予め明確に列挙された許容値リストを作ってテーブルを
作るみたいだけど(これはSET型も同じみたいだけど)、リストを拡張したい
時ってどうするんですか?
alterでその都度追加(出来るんですか)?
618 :
617: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画面に表示するときにそのつど計算させると重くなるので、テーブルに持たせたいのです。
君日本語怪しいけど大丈夫?
621 :
マッチ棒:2014/06/18(水) 17:21:35.37 ID:???
まあそう言わんと
>>619 INSERT/UPDATE時に計算結果を書き込むのではダメ?
いや普通に演算子使えるだろ
SELECT 売上-原価 AS 粗利 FROM 商品 WHERE 商品id=1;
ってことだろ?
この程度の計算で重くなるとか何を考えてるのかわからない
実際に測ったの???
重くなるのが嫌なら全パターンのhtml用意するしかないね
Excelのイメージでやりたいなら、計算式付きのSELECT文をVIEWにすることだろうな。
計算のタイミングは取得時でかわらんけどな。
どうしても格納時にやりたいけど、INSERTやUPDATE文に入れられないならトリガという手もある。
626 :
マッチ棒:2014/06/18(水) 18:27:40.01 ID:???
こんばんは。
表示するときに動的にクリエーするのが一般的なんでしょうか
ご意見ありがとうございます
まず日本語マスターしてきてくれ
628 :
マッチ棒:2014/06/18(水) 19:26:59.35 ID:???
まあそう言わんと
>>627 クライアント(プログラム)側でやるという手もあるにはある。
たとえば、クライアントがブラウザならJavaScriptで。
ただし、クライアントで計算させることの危険性については、考えないといかんけど。
2つ値を送信するコストと
ただ引き算するだけのコストと
どっちのほうが大きいか
まあ、どっちも何の支障もないレベルだけど
そんな小さい小さい事考えるよりお前の汚いソース最適化しろ
libmysqlclient.soを利用したアプリのライセンスは
オープンソースのライセンスにしなければいけないと聞いたのですが本当ですか?
633 :
マッチ棒:2014/06/21(土) 12:30:35.37 ID:???
>>619の件ですけど
結局mysql側ではそういう機能ないのですかね
要は、売上額が変わっても、外注額が変わっても、自動で粗利額が変わりたいです。
レコード編集時にアップデート計算するのが普通ですけ
select 単価 , 数量 , 単価 x 数量 as 売上金額 from 〜
で何がダメなのか教えて
636 :
634:2014/06/21(土) 14:06:55.80 ID:???
真面目に読んで無かったんで取り消し w
>>632 ありがとうございます
LGPLなら利用するだけならライセンスを縛られないのですね
mysqlのapiと互換性があるmariadbのクライアントライブラリを
利用する方法があるとはしりませんでした
mysqlの昔のLGPLの頃のコードと
phpのmysqlクライアントのソースから作ってるんですね
あとはlibmysqlclient.soの変わりにうまく使わせられればいい感じですね
ありがとうございます
(´・ω・`)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:???
案件の締め切り管理と、外注費の管理をしたいのですけど、
カスタマイズが簡単なフリースクリプトはありませんか?
Excelでやれ
日付でSELECTしたいんだが下記まではうまくいくが
SELECT * FROM test WHERE uriDay BETWEEN "2014-05-01" AND "2014-05-31";
この日付指定2カ所を変数で渡したいんだよ
フォームの値を入れたいわけ
けどどうしてもうまくいかん
日付が数値として処理されてるのかな
誰かサンプルを提示してくれないけ
>>644 よくやる間違いだが、sql文には日付の引用符が必要だぞ
引用符つきでストリングを渡すか、sql側に引用符をつけておく
646 :
645:2014/06/21(土) 20:46:21.75 ID:???
>>644 つまりこんな感じ
'SELECT * FROM test WHERE uriDay BETWEEN "'.$fromDate.'" AND "'.$toDate.'"';
>>644 該当の言語スレで聞いたほうがいいな。
内容はもっと詳細に書いた方がいい。
最低限いるのは言語名(該当言語スレに行くならいらない)と処理に失敗するコードの内容。
あと>>645-
>>646のことは忘れろ。
649 :
644:2014/06/21(土) 22:39:55.15 ID:???
PHPがなぜクソと言われるのか、その一端が分かる流れだと思いました(小並感)
PHPのdate関数で、3/31の1ヶ月前が3/3になってブチ切れた事あるわ
mysqlのdate_add、date_subはちゃんと2/28を返すのに
date関数はそういう用途で使うものじゃないから。
別にそういう風にできる関数や、日付を取り扱うクラスが用意されている。
スレチだから詳細は書かないけど。
全世界で、秒針がゼロを指すのは同時なんでしょ
どういうことなの
>>649 SQLインジェクションはちゃんと対策してくれよ
>>652 DateTime::addとかがそういう仕様だよ
SELECT t1.案件,COLLAPSE(SUM(t2.金額),0) FROM 案件 AS t1 LEFT OUTER JOIN コスト AS t2 ON t1.ID=t2.引当ID GROUP BY 引当ID
テストはしてない
格納か
適宜INSERTなりUPDATEなり書き換えてくれ
658 :
655:2014/06/22(日) 17:20:28.74 ID:???
>>657 格納じゃなくていいです
目的のテーブルがえらるれば
>>656 うーん、なぜかエラーが出てしまう。
僕が意味を理解できていないので、エラー内容もわけがわからない
>>659 俺らは理解できるから、ちょっとエラー内容教えてみ
661 :
655:2014/06/22(日) 19:05:00.96 ID:???
FUNCTION db.COLLAPSE does not exist
とかいろいろエラーが出ます
662 :
655:2014/06/22(日) 19:05:50.85 ID:???
なおphpMyadminのクエリ欄で試している状況です
collapse() って何ですか?
ごめん656だけど
COALESCEだったわ
全然違うわ
一から出直す…
ごじょういって、攘夷のこと?
書き込むスレ間違えてた……
667 :
655: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
ただし、金額がゼロの案件が表示されないです
ひきつづきアドバイスよろしくおねがいします
COALESCEでNULLを0に変換するのも必要だけど
まず
>>656が外部結合で例を示してるのにそれ自分で外しちゃってるから
670 :
655:2014/06/23(月) 12:53:17.95 ID:???
いまさら聞きにくいことなんですけど、
SELECTで合成されたテーブルは、実体はあるんですか?
そのテーブルに対しさらにクエリできますか
またそのテーブルはいつまで存在してるのでしょうけ?
671 :
655:2014/06/23(月) 14:17:08.66 ID:???
たびたびお世話になります
あらためて整理して見ました
この画像のように2つのテーブルを合成したいです。
ご指導もらったコレラセでやると、コストの登録のないものが表示されません。
コストテーブルにないものは0と表示したいです。案件テーブルにある件数すべてが表示されたいということです。
よろしくご指導おねがいします
672 :
655:2014/06/23(月) 14:17:48.52 ID:???
>>670 SQL view でググって勉強されたらいかが?
674 :
NAME IS NULL:2014/06/23(月) 15:53:27.51 ID:Na+XSE7A
>>656の関数名の間違いだけなおしたらいけるんじゃねーの?
なんで無視してるの?
>>671 仕事か学校の課題か知らないが、
一度データデースの入門書でも読んだ方がいい。
677 :
655:2014/06/23(月) 17:26:10.97 ID:???
>>674 すみません
>>671で報告したように、コスト一覧に対応がないものつまりコスト0の案件がリストアップされないのである
678 :
655:2014/06/23(月) 17:27:12.90 ID:???
なんだかんだ言って、誰もやれないのかな?
お前が勝手にLEFT JOIN外したからじゃん
680 :
655:2014/06/23(月) 17:36:42.58 ID:???
681 :
655: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
ちみらほんとに使えないインターネッツやな
何がしたかったんだコイツ
>>681 答えが殆ど出ていたにもかかわらず正答に辿り着くまで時間がかかったとはいえなんとか解決できてよかったね。
おめでとう。
マッチ棒wwww
クリエーってその場だけのタイプミスじゃなかったのか、、、w
688 :
NAME 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ブラウザ併用推奨
セレクトの結果、何もヒットしなかった場合、フェッチアソック時にエラーが出てしまうのをなんとかしたい。
よろしくお願いします
ここはMySQLのスレ。判ってますか?
そんなもん結果行数数えて0ならFetchしないようにしろよ
そもそも何?その欠陥ラッパ
mysqlといえばphpか
693 :
689:2014/06/24(火) 16:33:27.73 ID:???
たしかに、PHP側の問題でした
mysql_queryで結果がヌルなのでそのエラーになるようです
けどげせないのは、いままで結果がカラでもエラーは出ていなかったんですよ
条件追加したらこうなったのである
>>693 mysql_queryは非推奨だよ
nullを利用する部分を書き間違えてるんでしょ
phpの問題というよりプログラムの問題でしょ
しかも情報小出しとかw
696 :
689:2014/06/24(火) 16:59:08.45 ID:???
まあそう言わんと
マッチ棒専用の託児所じゃねーぞここは
698 :
マッチ棒:2014/06/24(火) 18:58:28.65 ID:???
いえ、気にせず他の方も質問してください。
僕もわかる範囲でアドバイスしてあげます
701 :
マッチ棒:2014/06/30(月) 14:44:00.58 ID:???
こんにちはいつもありがとうございます
さくらインターネットで、ムーバブルタイプのブログが8年ほど前からやってまして
mySQLを使ってるようですが
さくらインターネットのライト契約なのでmySQLは使えないらしいんですよ
これはどういうことでしたか
703 :
マッチ棒:2014/06/30(月) 14:54:21.40 ID:???
いまよくみてみたらどうやらSQLiteを使ってるようです
いまいち納得できないけど
そうですか
705 :
ポンプ:2014/07/01(火) 16:59:47.33 ID:???
消してあげよう
movableTypeはインスコ時に、MySQLかSQLiteかを選択できるんだよ
質問させて下さい。mysql5.1を使っています。
dumpファイルの復元を行っているのですが、復元できません。また復元されたことを確認する方法も分かりません。
コマンドプロンプトからmysql5.1に入り、binの下で、「mysql -u ユーザー名 -pパスワード DB名 <dumpファイル名」では復元できないのでしょうか。
ご教示頂ければ幸いです。よろしくお願いします。
外部制約は?
709 :
707:2014/07/02(水) 23:12:30.85 ID:???
外部制約とは何ですか?
初心者なもので…申し訳ありません。
>>709 小さめのdatabaseとtableを作成して、dumpしてみる。
MySQL monitorを起動して、
source dumpfile ってやってみる。
エラーが出たらその原因を調べる。
711 :
707:2014/07/04(金) 22:51:14.89 ID:???
>>710 レスが遅くなりました。解決しました。ありがとうございます!
712 :
NAME 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
>>712 劇的に速くする方法はない。
1時間に1回程度このクエリを実行して、結果を別のテーブルに保存する。
それでユーザにはその集計済みの結果を見せるというのがセオリー。
ニコニコ動画のランキングとかも1時間に1回更新でしょ。
それと同じ。
>>712 book_id インデックスを総なめする必要があるから、どうしても時間がかかってしまう。
Using temporary; Using filesort; はインデックスを走査した結果を集計しているだけだから時間の割合は少ないと思う。
>>713 みたいに定期的に集計するか、カウント用のテーブルを作ってプログラム側でカウンタを回すとかするしかない。
(book_id が楽々全部乗るくらいキャッシュメモリ積めば早いけど)
715 :
NAME IS NULL:2014/07/07(月) 22:09:47.53 ID:abW3QXYB
>>713 >>714 ありがとうございます!参考にします!!
Using temporary; Using filesort; が遅いわけではないんですね。。
楽々全部乗るくらいキャッシュメモリがあればとありますが、
設定値の変更はどこになりますか?
クエリキャッシュについて
機能が有効かどうかの確認
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';
これsort部分のが時間かかってるっしょ
質問1個に平均20とかコメントついてるなら別だけどさ
sort_buffer_size
を増やすことでUsing temporaryを消せれば
改善するかもな
GROUP BY したあと、違うカラムで ORDER BY してるんだから
Using temporary になるんじゃないの?メモリサイズ不足じゃなくて。
>>715 ちなみに最後に LIMIT 0,1 をつけると早くなります?
719 :
NAME 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');
のように出力したい
>>719 extended-insert=FALSE
つけてみて
722 :
NAME 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');
となりました
これはこれで意図するものに近いかなという感じです
sed とかエディタの置換併用はだめなんかの?
724 :
NAME IS NULL:2014/07/10(木) 14:45:24.14 ID:UaAE594X
1つのテーブルに結構な量のレコードが格納されていて、
エディタだと開けない場合があるので、mysqldumpオプションで対応できるものが
存在しているかどうかについて知りたいというのがメインでした
sedとか使うのも試してみます
ありがとうございました
インデックスの貼り方がイマイチわからないんです。
createdという作成日を保存するフィールドがあります。
これを元にソートする、ただしwhereによる絞り込みはしない場合はcreatedにもインデックスを貼るべきですか?
クエリの内容と、頻度によるとしか・・・
727 :
NAME IS NULL:2014/07/10(木) 23:18:12.81 ID:fsYbcw2v
>>718 返信遅くなりました!
LIMIT 0,1 つけても変わらずです!
728 :
NAME 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';
を実行しても無理でした。
ご存知の方いらっしゃいましたら教えてください。お願いします。
SET SESSION time_zone = '+0:00';
で、できたんだけど何が違うんだろう
覚悟が違う
>>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.
って書いてあるのに
PHPのmysqliクラスを使ってSQLの命令を実行する場合について質問させてください。
ローカル環境ではきちんと動いていたphpが、ロリポップのサーバーにアップロードすると、
SQLをクエリする部分でエラーが出てしまいます。
ロリポップのphpMyAdminを開いたときに表示されるページの「Webサーバ」という欄に、
・PHP 拡張: mysql
と書かれているのですが、これは関係ありますでしょうか?
ロリポップの設定画面から、
「Webツール」→「PHP設定」のところで全で、phpのバージョンを5.2から5.4に変更し、
10分待っても、この「PHP 拡張: mysql」の表示は変わらないままです。
ちなみに、ローカル環境でのphpMyAdminの表示は、
PHP 拡張: mysqli
になっています。
どうすれば、mysqliでクエリできるようになるか、ご存知の方いらっしゃいましたら教えてください。お願いいたします。
>>733 ロリポップにmysqli入ってないんじゃないの?
phpinfo();で調べたら?
入ってない場合、手動でインストールできるかはわからんが。
何せレンタルサーバーだからね。
735 :
733:2014/07/22(火) 22:22:55.31 ID:???
いま、phpinfo();で調べてみたんですが、
「MysqlI Support enabled」と出ます。
やはり、myqliクラスは使えるようになってるんですね。
あと、mysqliのコンストラクタを使用した時にデータベースへのログインも出来てるようです。
でも、サーバーにアップロードすると、ローカル環境で正常に動いていたquery()メソッドで、エラーが出てしまうみたいです。
他に何か問題点として考えられる事はありますでしょうか?
エラーの内容を貼れよ
mysqliで接続できなかったらquery以前、つまりconnectの段階でつまずいていると思うんだけど。
MySQL5.5.33です。
どんなキーワードでググるべきかも分からないので教えて下さい。
以下のテーブルがあるとします。
3,渡辺
2,井上
1,田中
LOAD DATA INFILEで、5と4を記述したcsvファイルをインポートしました。
すると下に追加されて32154となるのですが、
このように上に追加するにはどうしたら良いでしょうか。
5,山田
4,鈴木
3,渡辺
2,井上
1,田中
739 :
738:2014/07/23(水) 02:10:49.80 ID:???
すいませんスレ間違えました。無視して下さい。
>>738 selectするときにorder byで並び替えて取得する。
データ構造的にそうしたいという意味で聞いているのなら無理。というか無意味。
どこのスレ行ったんだろうな。
どこ行っても同じこと言われると思うが。
>>738 既存のテーブルをdumpして、cat 5,4のcsv dump > aaa
load data infile aaa into table XXX
5と4のcsvが
4
5
の順で書かれてるならしらん
743 :
733:2014/07/24(木) 21:19:12.36 ID:???
すみません、原因がわかりました。
データベース名に"-"が含まれていることが原因だったみたいです。
データベース名を"`"で囲むと、正常にクエリすることが出来ました。
質問に答えて下さった方々、ありがとうございます。
もしかしてコボラだったの?
質問なんだが、1テーブル内にずらっと何万何千と記録するのと、
テーブル別に分散させるのとでは速度とかに差は出てくるものなのか?
会員登録系のサイトを作ってるんだが、まとまったグループ内のコンテンツが登録されるのを踏まえると
SQL文で分岐するよりもはなからテーブルで分けたほうがいいのか迷ってるんだが・・・
何万くらいじゃ心配いらん
1行が1KBだとしても、1万行で10MB程度。
ゴミでした。
じゃあ遠慮無く1テーブルで管理するわ。
データベースの種別とかで調べてたら速度云々で色々と描かれてるのを見て不安になってたんでな。
データの入れ物や、データ出し入れする行為を意識しなくてよいのがDBMSのよいところの一つなのに、
それを分割してわざわざプログラム側で入れ物を区別するのも滑稽でしょ。
億・兆オーダーになったら、パーティションを検討してみるのがいいと思う。
上記関連事項について質問させてください。
現在、80万レコードで90MBほどのテーブルがあり、一箇月に10万レコードのペースで増えています。
レンタルサーバー(coreserver-mini)のMySQLを利用しているのですが、
どれくらいのレコード数まで順調に動作するものでしょうか?
300万レコードくらいまで快適に動作すればいいと思うのですが、
それまで問題ないでしょうか?よろしくお願いします。
問題ないよ
って言われたら信じるの?
サポートに聞きなさい
752 :
750:2014/08/06(水) 22:15:27.26 ID:???
>>751 間違いの無いご回答ありがとうございます。
全くおっしゃる通りです。
ありがとうございました。
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@;
二段階に分けて実行した場合は、まずデータが挿入され、
その後挿入されたデータが表示されます。
エラー内容からサブクエリの書き方に
問題があるように見受けられるのですが、
どこが悪いのか見当もつかない状態です…
`adress`か `namae_kanji`で、重複を許さない指定があれば
INSERT IGNORE INTO `tantousya` (`adress`, `namae_kanji`) VALUE ("Tanaka@", "田中");
adressが気になるw
756 :
753:2014/08/13(水) 11:38:40.04 ID:???
>>754 プライマリ、ユニークキーを指定というのは至極全うな意見だと思いますが
今回はサブクエリで制御を考えています。
サブクエリの勉強中です。
>>755 adress フランス語で書いちゃったわけではなくタダのスペルミスorz
INSERTにNOT EXISTSは直接使えないので、
一旦NOT EXISTSを条件にSELECTし、レコードがない場合に
INSERTすると言うように書かないと無理じゃないかな
758 :
753:2014/08/13(水) 13:05:12.23 ID:???
>>757 なるほど、そういう制限があるんですね。
サブクエリの解説サイト等見直したいと思います。
ありがとうございました。
>>758 こんな感じかw
INSERT INTO `tantousya` SELECT 'Tanaka@' AS `adress`, '田中' AS `namae_kanji` FROM DUAL
WHERE NOT EXISTS (SELECT * FROM `tantousya` WHERE `tantousya`.`adress` = 'Tanaka@');
760 :
NAME 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 |
↑ 間違えて投稿してしまいました。お詫びいたします
サブクエリでなく case when でやればいい
763 :
NAME IS NULL:2014/08/20(水) 10:26:28.50 ID:4cvw8JQq
保守
au氷水ディレクター戦争タイステーキ万国ニューヨークブカ牛肉直輸出制限業者議論病院雇用市議しょうゆダシマクッロスさむらい山雪光金ガンダム風ミックドラ社員あかうんとパズ豚骨のり塩肉マンつばめの巣担々麺野菜炒めラーメン
au氷水ディレクター戦争タイステーキ万国ニューヨークブカ牛肉直輸出制限業者議論病院雇用市議しょうゆダシマクッロスさむらい山雪光金ガンダム風ミックドラ社員あかうんとパズ豚骨のり肉マンつばめの巣塩担々麺野菜炒めラーメン
au氷水ディレクター戦争タイステーキ万国ニューヨークブカ牛肉直輸出制限業者議論病院雇用市議しょうゆダシマクッロスさむらい山雪光金ガンダム風ミックドラ社員あかうんとパズ豚骨のり肉マンつばめの巣塩担々麺野菜炒めラーメン
ニンニクヤーフォー低額土地NHK名古屋遅延電池切れ福岡損保新規駐車近代ゲームフジワイプ転職提案ラーメン
abk公式漏洩安保険王なにあげてんだよ?「わー!ふーう?」↓↓★★↓↓宿題通調印鑑カウントダウン息子議員国会大学生
お大事に
つ お薬
質問させてください。
大したアクセス数もないのに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
続き(長々となってすみません)
[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
ワードプレス?
innodb_buffer_pool_sizeは総メモリの7〜8割割り当てろとか言われてる
key_buffer_sizeは64Mぐらいになりそう
sort_buffer_sizeとかが多すぎる
スレッドバッファで調べてみるといい
mysqltuner使ったらだいたい教えてくれる
後エラーログに色々出てるはずだからそれを見る
>>769 いえRuby on Railsというフレームワークを使って自分で1から組んでいます
>>769 ありがとうございます
それとMySQL5.1なんですが5.5に上げておいたほうが利点とかありますか?
MySQLTunerは5.5以降の対応みたいですね
5.5より5.6
5.7はたいした変更ないけど5.5と5.6はクエリによっては大違いだぞ
MySQLで大量のデータ計算させるのに適切なアプリケーションに迷っておりアドバイスあれば教えて下さい。
以前Accessに株価データ入れてVBAで分析みたいなことやってたんですがレコード数が150万ぐらいになるので、MySQL5.6+Access2010に作り直してみたんです。
・ODBC接続してリンクテーブルをAccess内に張り、それに対して操作
・VBAのADOでMySQLテーブルをレコードセットして、それに対して操作
・Accessで計算し、結果をSQL文にしてMySQLに投げる操作
・Accessで計算し、結果をローカルテーブルに書いて最後にテーブルを転送
などやってみたんですが、どれもAccessローカルテーブルに直接操作するよりパフォーマンスが落ちます。
MySQLのクエリ自体は高速なのですがInsert/UpdateをODBC経由やADO接続でやりとりするところがボトルネックみたいで。
PHPとかRubyとかで処理するとそういう問題は少ないのでしょうか。
>>775 すくないよ
エンジニアに金はらって作ってもらいな
777 :
NAME IS NULL:2014/08/28(木) 00:55:32.51 ID:joeF3rjv
結果セットが大量すぎてコピーが遅いならわかるけど
更新処理が遅いのはよくわからんな。
ADOならちゃんとパラメータのバインドとか使えば
そうそう遅くならない
>>775 どこにボトルネックがあるのかそれだけじゃ判断つかないし、
まずはマシン構成と、AccessだけのときとMySQLを使ったときで
どのくらい差があるのか、定量的に示すべき。
779 :
775: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
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
781 :
780:2014/08/30(土) 19:45:47.62 ID:???
ごめん、最後エイリアスつけ忘れ
WHERE id BETWEEN 130100000 AND 200000000
↓
WHERE a.id BETWEEN 130100000 AND 200000000
>>779 15万件弱のレコードをMySQLからAccessに取り込んで、1件ずつupdateループ回してるってことか。
更新したいだけならMySQL側だけで完結するように
>>780 のやり方が良いと思われ。
784 :
NAME IS NULL:2014/08/30(土) 21:56:05.06 ID:39pGGgY4
質問させてください
phpMyAdminで MySQLのデータベースを管理しています。
yumで新しめのphpMyAdminに入れ替えました。
それ以降というもの
20テーブルほど、それぞれ20MB〜100MBはあり合計270MBとなっています。
しかし、データベースをまるごとエクスポートすると8MBのサイズになりダウンロード完了と出てしまいます。
なぜでしょうか?
787 :
775: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一発文組み立てるの苦手だったのですが、これだけ圧倒的パフォーマンスだと使わざるを得ないですね。
なんとかその方向でやってみます。
>>786 環境やらバージョンやら、具体的にどういう操作を
したのかやら、書かないと誰もわかんねえよ
mysql 5.5.21
select 〜 into outfile でテーブルの内容をファイルに書き出せはしますが、その時に
カラム名をヘッダとして先頭に出す…なんてことは出来ないんでしょうか
790 :
NAME IS NULL:2014/09/01(月) 23:10:22.91 ID:EfQ/kLTT
>>790 あぁそういう手があったか
ありがとうございます
3
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
回避しつつバックアップを取る方法とかってありますか?
ちなみに出来たファイルの中身はコメントだけでした
ORACLEにはPL/SQLにPACKAGEがありますが、それに相当する機能ってありますか?
ストアド使わないシステムを作ったこと無いんですが、MySQLはストアド使わなくても速いですか
795 :
793: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.
フリーの鯖借りてきて、MySQLを使っているのですが、
その鯖には、外部キー制約の機能がありません。
なので、外部キー制約と同じ機能があるフリーの鯖を探してくるか、
「内部リレーション」の機能で、外部キー制約と同じ事をやるか、
と考えています。
よろしければ、「内部リレーション」の機能で、外部キー制約と同じ事をやるための方法について、
教えていただけないでしょうか?
外部制約の機能がないって…エンジンとしてinnodbを使えないってこと?
set foreign_key_checks=0ってことじゃないの?
800 :
NAME IS NULL:2014/09/15(月) 09:22:47.42 ID:9u2jWlPJ
801 :
NAME 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 を使用しているのですが、あまりパフォーマンスが上がりませんでした。
リソースの増強をせずとも、ちょっとしたテクニックや設定でパフォーマンスが
上がるのであれば試してみたいのですが、、、
それ複数テーブルにまたがるidだから採用してるんじゃ?
もともとauto_incrementで済むならそっちのがいい
803 :
NAME IS NULL:2014/09/21(日) 14:58:22.28 ID:lk034qCW
wordpressのSQLデータインポートここで質問してもいいですか?
804 :
NAME 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
まずは、外部制約といった辺りを勉強しませう
この先データベースをいじり続ける気があるなら、それなりの勉強はしてからにね
806 :
NAME IS NULL:2014/09/21(日) 15:51:35.47 ID:lk034qCW
レスありがとうございます。
外部制約ですが・・ちょっと私には難しそうです。。。業者に頼むしかないのかも。
自分のサイトを正常に表示させたいだけなのですが方法はないでしょうか?
どうやってダンプ取ったの?
解説見ながらやり直したほうがいいんじゃ?
外部キー制約があるとインポートするテーブルの順番間違うと入らないから
テーブルごとに分けて順番変えて入れなおしてみては
外部キー制約のチェックを一旦切ればいんじゃね
809 :
NAME IS NULL:2014/09/21(日) 16:18:10.57 ID:lk034qCW
>>807 レスありがとうございます!チカッパサーバーでバックアップオプションで自動でとれるようになっています。
wordpressを誤って上書きインストールしてしまいバックアップから復旧させているところなんです。
上記のエラーで残りのデータが入らないという状況です。そしてどうやらその中に管理画面に関するデータがあるみたいなんです。。
>テーブルごとに分けて順番変えて入れなおしてみては
すいません。やり方がわからないです。。
810 :
NAME IS NULL:2014/09/21(日) 16:27:37.77 ID:lk034qCW
>>808 レスありがとうございます!それはphpmyadminでも出来ますか?メニューにはなかったです。素人過ぎてごめんなさい。
811 :
780:2014/09/21(日) 16:34:44.18 ID:???
phpmysqladminから以下をクエリで実行してみるとか
SET FOREIGN_KEY_CHECKS=0
インポート
SET FOREIGN_KEY_CHECKS=1
812 :
NAME 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
インポート の文字まで入れるなよw
このインポートは文字じゃなくて実際のインポート作業だろ
815 :
NAME IS NULL:2014/09/21(日) 16:49:11.69 ID:lk034qCW
書き方が間違ってました。今度はこうなりましたが駄目っぽい?
SET FOREIGN_KEY_CHECKS = 0;# 返り値が空でした(行数0)
SET FOREIGN_KEY_CHECKS = 1;# 返り値が空でした(行数0)
SET FOREIGN_KEY_CHECKS = 0;
ここで外部キー制約をしなくなる
実際にインポートする(最初の質問の外部キーエラーが出ない)
SET FOREIGN_KEY_CHECKS = 1;
もとの外部キー制約アリに戻す
作業終わり。
わかる?
817 :
NAME IS NULL:2014/09/21(日) 16:59:17.62 ID:lk034qCW
>>816 ありがとうございます。
SQLのところでSET FOREIGN_KEY_CHECKS = 0; を実行して
インポートした後
SQLのところでSET FOREIGN_KEY_CHECKS = 1; ですかね?
恐らく外部キー何かわかってなさそうだけど大丈夫か?
また同じエラー起こしそう
バックアップとるか消えてもいいとこでやるようにな
外部キーわざわざ設定してるんだから理解してるでしょ
>>806見る限り外部制約なにかわかってなさそうやで
822 :
NAME 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
ああ、CMSが勝手に設定した外部キーか
業者に泣きついて診てもらえ。俺なら10万くらいでやってやるよ。
825 :
NAME IS NULL:2014/09/21(日) 18:04:59.48 ID:lk034qCW
それしかないでしょうか。業者10万もするんですか泣
826 :
NAME IS NULL:2014/09/21(日) 18:23:37.72 ID:lk034qCW
SSHでやっても同じですか?触ったことはないです
827 :
NAME IS NULL:2014/09/21(日) 18:24:38.23 ID:ysK96J+F
どうせ消せなくてエラー出てんだから
まっさらにしてやってみりゃいい
試しに外部キー制御外したその場でDROP TABLEやってみ
まじでバックアップだけは取れよ
829 :
NAME IS NULL:2014/09/21(日) 18:43:11.26 ID:lk034qCW
>>827 wp1_slim_browsers←エラーになっているこのテーブルを削除でいいですか?
>>828 ありがとうございます。バックアップはファイルとデータベースを両方とってあります。
830 :
NAME IS NULL:2014/09/21(日) 19:12:59.54 ID:lk034qCW
うう。でもテーブル削除してもまたインポートするから意味ないような・・気がします
831 :
NAME IS NULL:2014/09/21(日) 19:35:28.59 ID:ysK96J+F
エラーみりゃ削除できねえって言ってるのがわかるだろ
832 :
NAME IS NULL:2014/09/21(日) 20:19:21.62 ID:lk034qCW
結局無理ってことですねありがとうございました
wordpress スレ探して、そちらで具体的な環境とか操作手順を
晒しながら質問したほうが良いのでは。
834 :
NAME 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
元々はインポート時に参照キーのエラーが出ていたのが
今度はCREATE TABLEでエラーが出るようになった、ってこと?
このエラーを見る限り、wp1_slim_statsテーブルのid列にキーが
設定されていない可能性があるけど
836 :
NAME IS NULL:2014/09/22(月) 08:20:09.14 ID:y7/LBMjJ
>>835 最初は途中までデータが入った状態でインポーしていました
837 :
NAME IS NULL:2014/09/22(月) 09:03:57.94 ID:y7/LBMjJ
slim_stats←このプラグインが邪魔してますよね。削除したい…
838 :
NAME IS NULL:2014/09/22(月) 20:11:47.88 ID:y7/LBMjJ
1年前のSQLファイルがありました。これを一旦インポートして、管理画面に関するテーブルだけをエクスポートし、現在に戻して管理画面テーブルだけをインポートしたらどうでしょうか。
今の問題はWordPressの管理画面に入れないことなのでこれで解決するかもしれない。ご意見お願いします。
あくまでWordPressを復旧するのが目的であってMySQLやRDBMSについて知ろうという
気はない、というスタンスなら
>>833の言うようにここは適してないんじゃないかなあ。
840 :
NAME IS NULL:2014/09/23(火) 02:44:41.70 ID:Rn55ID+g
なんとか復旧しました。
>>838の方法でうまくいきました!心配してくれたみなさんありがとう!いま感無量です。管理画面に入れたときは感動しました!
データベースからテーブル削除してもバックアップがあればなんぼでも復旧できることがわかりました。WordPressの復旧作業は初めての経験でしたが自信もつきました。もう少しで業者に泣きつくとこでした。地元のweb屋検索しましたからね。
それにしてもデータベース命ですね。次にファイル。何世代かに分けてバックアップは保存しておくべきですね。始まりはWordPressの上書きインストールでしたがいい経験になりました。明日はいい祝日になりそうです。スレ使いすぎてすいませんでした。さよなら。
841 :
NAME IS NULL:2014/10/01(水) 02:07:33.50 ID:auoeFgeH
AAA1
AAA11
AAA111
これを
AAA001
AAA011
AAA111
としてORDER BYするにはどうすればいいのでしょうか?
>>841 そういうふうに変換かけて order by にかければいい
念じる
そういう変換をするストアドファンクションを定義するなどしてそれでORDER BYかけることはできる。
ただし MySQL は関数ベースのインデックスが張れないから、パフォーマンスは期待できないが、
SQL 処理中の ORDER BY する時点でソート件数が少ないのであれば影響は少ないだろう。
もう一つの代替案は、そのように変換済みの実カラムを追加してそっちで ORDER BY する手もある。
こっちはその分の容量を食う代わりにインデックスは効く。
列がcolAとして
select colA,cast(substring(colA,4) as unsigned)
from tbl
order by cast(substring(colA,4) as unsigned) ;
これでは駄目?
駄目なんだったら
文字列の部分と数値の部分を分け、数値の部分についてLPADで0埋めしてまた連結するとか
そこまでしないといけないもん?
846 :
841:2014/10/01(水) 23:45:26.30 ID:auoeFgeH
ありがとうございました
それほどレコード数も多くなくて、最大で20前後ですので、その方法でorder byします
847 :
NAME IS NULL:2014/10/02(木) 19:59:40.95 ID:YdQdRdW6
column1を含むtable1と
column2を含むtable2をcolumn3でjoinした結果に
(column1, column2)の複合インデックスを張りたいんですけど
テーブルを非正規化する以外の方法はありますか?
祈りなさい
849 :
847:2014/10/03(金) 00:47:55.73 ID:s/6Hsaik
MySQLの神に祈ってます
神様教えてください(´;ω;`)
複合インデックス張るのはあくまで手段であって目的ではないはずだ。
クエリの高速化が目的だろうとは思うけど、本当に他に手はないのか?
何を根拠に複合インデックスという手段が最適だと判断したの?
851 :
847:2014/10/04(土) 13:03:03.45 ID:11JI3KNp
技術的に解決は無理でしたが政治的に解決されました
ありがとうございました
アベノミクス!!
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) という
複合インデックスを張るという手が有効じゃないかと気がするんだけれど、
どうなんだろう?
Sakilaって名前が絶望的に嫌いなんだが
なんとか出来ないものか...
MySQLの memcached インターフェイスって使ってる人?
海外の方ですか?
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登録もできなくなってしまうのですが
対処方法教えていただけないでしょうか?
859 :
NAME 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アドレスでエラーの結果が違うのもよくわかってないです。
iptablesを確認。
初期状態で3306は空いていなかった気がする。
861 :
NAME 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
そもそもpingは通るの?
863 :
NAME IS NULL:2014/10/12(日) 16:41:07.67 ID:l4A5A+ct
>862
はいpingは通ることを確認しています。
ただtelnetで3306にアクセスするとすぐにはじかれます。
これは3306のポートを開いてないってことなんでしょうか?
netstatで見てもちゃんと3306はLISTENしているのですが。
ローカルからmysqlの -h オプションで127.0.0.1じゃないほうのアドレス指定で開ける?
iptables を -F でフラッシュしても変わらない?
ちょっと試したけど、やっぱりiptablesぽいけどな
シンプルにこれじで試してみては
iptables -A INPUT -p tcp --dport 3306 -j ACCEPT
切り分けのためにとりあえずiptablesを止めてみれば?
867 :
NAME IS NULL:2014/10/12(日) 19:47:10.01 ID:OVtCluaN
>866
859です。
iptablesを停止したらアクセスできました!
iptablesの設定がダメだったみたいです。
設定を見直したいと思います。
※原因はまだわかっていませんが。。。
アドバイスありがとうございました。
-Aで追加してるんだから
それより前の評価順で弾かれてるんじゃないのか
869 :
866:2014/10/12(日) 20:39:44.07 ID:???
>アドバイスありがとうございました。
アドバイスってほどのものでもないんで
iptablesの問題だと判ったのであれば/etc/sysconfig/iptablesの内容を
変に加工せずに全部晒せばちゃんとしたアドバイス得られるかと
load data infile構文でデータをインサートした際にエラーが出た場合、エラー内容(エラーコードやメッセージ)を別に用意したテーブルに格納したいのですが、
どうやって取得すればいいでしょうか?Show warningsで直前の警告やエラーが取得出来ることは分かりましたが、調べても見つけることが出来ません・・・
バージョンは5.1.3.6です。
テーブルに格納する前にエラーを無くす方が先決だと思うのだが
>>871 すいません、今のところloda data infileで問題無くテーブルへインサート出来ているんです。
ただ、この先何かしらエラーは出てくるだろうから、それらのエラーコードやメッセージを保管しておきたいとなりました。
そのうえでわざと間違いをしてエラーコードがどこから出てくるのか、それは取得可能なのかを知りたいんです。
show warningsの結果もどこに格納されているの変わらない、一時テーブルのような物なのかそれともログファイルか何かに記録されていて、
それらをインサートのたびに読み込んでDBに突っ込むのか分からない。
エラーが出る際に戻り値の様な物が戻ってくるのか、それを取得してエラー内容を引きずり出す必要がありtお思う真sいた
吸いません、酔っ払ってるんで文章めちゃくちゃですがお許しください。
HTML5で業務アプリケーションを作ろうと思っているのですが、文字コードは何を選択するのがベストでしょうか?
全角 = 2バイト、半角 = 1バイトと考えている人が多く、UTF-8を使おうか悩んでいます。
utf8mb4
charなら文字数だけど
一部の人の名前入れられないとか論外だからUTF-8。
MySQLはutf8mb4
別に論外じゃないけどな。
仮に論外ならユニコード定義外の文字でも入力出来なきゃ駄目だろ。
現実的に可能な範囲でベストを尽くすべきという意味においては同意だけど。
全テーブル全カラムを対象に
日本語(というか非アスキー)が含まれているテーブルの
一覧を作りたいんだけど
どうしたらそれなりに高速に調べられるかな
1000件ぐらいまでだったら普通に検索しても速度は変わらないと思うけど
10万件を超えるのなら Mroonga の導入を検討するとか
揚げ
生物の生育範囲のような、例えばpH1.0〜3.3というような、幅のある条件をもつ複数の生物を
条件検索で絞り込ませるDBはどのように作ればいいのでしょうか。
pHの欄に、1.0、1.1、1.2・・・・3.2、3.3などと延々入力しておかなければならないのでしょうか。
これだと幅が広い領域を持つ生物の時はとても手間がかかります。
もっとスマートなやり方があるのでしょうか。
最小と最大入れて範囲指定で検索でいいと思うが
データベースの最小値欄に1.0、最大値欄に3.3と入力しておくだけで、
範囲指定の検索ボックスで、下限が3、上限が5 と指定すれば、
>>882であげた
生育条件(pH1.0〜3.3)の生物を結果として出してくれる?
生育pH3.1〜5.7のような生物Pがいた場合、下限3、上限5と条件検索すれば、
これも同時に結果に出してくれるのでしょうか。
http://www.rsch.tuis.ac.jp/~nagai/SYS/SYS22.html この例のように、1つのアイテムが1つの固有値を持つものは、where文で
範囲指定すればいいとわかるのですが、上記のように
1つのアイテムが、幅のある数値を持つものはどうすればいいのか悩んでいます。
pHというフィールドの中に1.0from3.3と入れたらプログラムは理解してくれますか。
それともminとmaxというフィールドをそれぞれ作って1.0、3.3という値を入れておくのでしょうか。
もちろん情報が2つあるんだから2項目にminとmax入れておくんだよ
もしかして検索条件も範囲なの?
その場合、すこしでも重なってたらひっかかるのか、完全に内包されてる場合だけなのか
とかいろいろ条件あると思うんだけど、必要な要件並べてみてよ
>>886 ありがとうございます。そうです、検索条件も範囲です。
複数の生物についてデータベースを作り、同一の生育条件のものを拾い出すデータベースです。
例えばメダカは絶対に水温25℃ぴったりじゃないと死んでしまうってことはなく、
生きられる水温に幅がありますよね。
そのように、似たような条件で生きられる生物は他にもいろいろいるわけですが、
それらを条件検索で絞って出てくるように作りたいのです。
なので検索条件は、重なる部分を少しでも内包するものを拾う必要があると思います。
カラムが minvalue maxvalue とすると
特定の値が範囲内かは、
値 BETWEEN minvalue AND maxvalue
で探せるから
最小値 BETWEEN minvalue AND maxvalue
と
最大値 BETWEEN minvalue AND maxvalue
をORでつなげば重なり、ANDでつなげば内包になるんじゃない?
まあいろいろ試してみて
あーあと範囲が検索範囲より両側とも大きい場合を含めるなら別にその比較もいるね
>>888 ありがとう。
andはアレかつコレですよね。
Aの範囲とBの範囲が重なりを内包するものを探せということは、
betweenAの範囲の最小値かつAの範囲の最大値、and
betweenBの範囲の最小値かつBの範囲の最大値 ということで、andでつなげば
でる!と考えました。
>>889 生育条件範囲が検索範囲より両側とも大きい場合も
同じ式でいけるかと思いましたが違うのかな。
>>890 これはとてもポピュラーな問題なんだけど、「不要なもの」以外を取るようにすれば楽。
生物.max < 検索.min → 水槽の最小水温でも熱すぎて死んじゃう生物
か、
生物.min > 検索.max → 水槽の最大水温でも冷たすぎて死んじゃう生物
が、検索結果に「不要なもの」だよね。なので、その逆を出せばいいよ。
pH1.0で生きられる生物なんているの?
例だから別にどうでもいいんだけど
それアカンやつや
EXPLAINの出力について質問です。
keyがセカンダリインデックスでExtraにUsing whereとUsing indexの両方が出力される場合、
ExtraがUsing indexだけの場合とどういう違いがあるのでしょうか?
>>985 インデックスだけでは該当するレコードを絞り切れない場合に "Using where" が出る。
それが出たとき、結果のレコード数は10なのに、rows が 50 とかになってない?
1レコード取り出したいのに、rows が 1000 とかになってたら見直したほうがいいかも。
>>896 回答ありがとうございます。
Using whereが出た時も出ない時も結果のレコード数・rowsともに複数行でした。
WHERE句で複合インデックスの2つ目以降のキーも使われた場合Using whereが追加されるとかでしょうか?
>>897 > Using whereが出た時も出ない時も結果のレコード数・rowsともに複数行でした。
同じ数字でしたか?
899 :
NAME 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)
);
このやり方だとエラーでるんですが
構文で間違ってる所あります?
>>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とでました。
TEMSU_B,
903 :
名無しさん@そうだ選挙に行こう:2014/12/14(日) 02:39:55.61 ID:yOOGWEyF
>>902 すみませんでした。
書き込んだときのタイプミスです。すみません
904 :
名無しさん@そうだ選挙に行こう:2014/12/14(日) 02:44:09.26 ID:yOOGWEyF
(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できました!ありがとうございます!
神様がいるスレ (^ 人 ^) ありがたや
太郎と次郎の平均点を三郎に入れてどうするんだろうか
三郎 : アッー!
一郎:うっ
911 :
NAME IS NULL:2014/12/16(火) 02:32:54.31 ID:GtMu71uM
みなさんはどうやってMySQL勉強しました?
漢のブログ見た
あれこれ図書館でその手の本を借りまくって
データベースで図書館というとあれですね?
タイーホ
916 :
NAME 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
917 :
NAME IS NULL:2014/12/17(水) 18:47:23.54 ID:aelyae1c
訂正
`created` >= '1日前'
でした
インデックス追加する必要がない
919 :
NAME IS NULL:2014/12/17(水) 19:07:10.61 ID:aelyae1c
>>918 それは意外でした
後学の為にぜひ理由を教えてください
>>918じゃないが、unique_key 1件あたりのレコード数はどのくらいなの
921 :
NAME IS NULL:2014/12/17(水) 21:28:21.95 ID:aelyae1c
>>920 unique_key 対するデータは1つになっているので・・・
もしかしてunique_keyを条件にした時点で他のレコードを探す必要がないので要らないってことですか?
だとしたら、理解できました
皆さん、ありがとうございました
はい
レコード長(サイズ)で教えて欲しいのですが、
InnoDBで、大きいvarchar型をいくつか利用するとレコード長がオーバーしてしまう状況です。
varchar型をtext型にすれば、回避できるのでしょうか。
MySQL初心者です。
NULL不可のDATE型のカラムに不正な日付をINSERTした際、0000-00-00という値でINSERTが完了してしまいますね。
これをエラーを返してROLLBACKさせたいのですが、DB側の機能では不可能でしょうか?
>>924 日付判定はアプリ側の仕事ってのがMySQLのスタンスだから
INSERT、UPDATEトリガで例外を発生させるぐらいしかないかも。
IF DAYOFYEAR(NEW.datecolumn) IS NULL THEN
SIGNAL SQLSTATE '23000' SET MESSAGE_TEXT = 'invalid date'
END IF;
>>924 sql_modeでNO_ZERO_DATEを my.iniだかmy.cnfだかに設定する
mysql sql_mode あたりでぐぐれば出てる
>>925 >>926 ありがとうございました。
sql_mode = STRICT_ALL_TABLESでうまくいきました。
>>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
■質問です
MySQLを初めて使うのですが、
phpMyadminから設定を行ったのですが、
データをいくつ登録しても、
出力するページ側では1つしか出力されません。(phpMyadmin側ではデータは登録されている)
phpMyadminにて一度設定した後に下記を後から修正したのですが
それが原因てことはありますでしょうか?
主キー
ユニークインデックス
インデックス
全文インデックス
また、上記のそれぞれの意味を初心者向けに解説しているサイトなどあれば教えていただけますと幸いです
931 :
930:2014/12/28(日) 14:35:41.77 ID:???
すみません自己解決しました。
接続側のphpの記述に問題がありました。
失礼しました
ガンバ
Barracuda で ROW_FORMAT=ROW_FORMAT=COMPRESSEDにしたら
900MB弱あったテーブルが500MB以下になった。すごっw
934 :
NAME IS NULL:2014/12/30(火) 05:24:23.22 ID:ZOTTcmcS
MySQLを利用してWebサイトを作っています
ユーザーが入力した文字(名前や自己紹介文)をDBへ登録する際、
HTML特殊文字(&や<>等)は予めエスケープしてからDBへ登録するのと、
DBへの登録はそのままで、表示する際にエスケープするのは
どちらが一般的なのでしょうか?
エスケープして登録した方が、表示の度に毎回エスケープしなくていいので良いと思うのですが、
値を検索する際に困りそうな気がして悩んでます
そのデータは絶対にHTMLに流すことしかしないの?
HTML前提じゃないのに格納時にエスケープするのはおかしいよね?
ま、前提だとしても基本的には生データで入れるけどね。
保存のためなのか表示のためなのか切り分けろ
どこかに
ページ送りの部分のソース(他の機能は一切不要)を初心者向けに解説しているサイトないでしょうか?
なんですぐ解説サイトって検索機能とか余計な事まで一緒にやろうとするんだろう
ページ送りってなんやねん。ここはDBの板なんだからPHPとかWebのことならそういう板で聞けよ
多分、limit offset と order by で順番に取ってくるやつのことだと思うけど
そのままググれば見つかりそうなもんだけどな。
>>934 エスケープして格納したいのなら、検索キーワードもエスケープすりゃええ。
インジェクションとか大丈夫か?
942 :
937:2014/12/30(火) 14:31:25.63 ID:???
>>939 その通りでございます。
エスパーですね
943 :
NAME IS NULL:2014/12/30(火) 18:00:06.82 ID:ZOTTcmcS
>>935 ありがとうございます
生データで入れるのが一般的なんですね。参考になりました
>>940 ありがとうございます
そういうやり方もあるんですね
>>941 SQLインジェクションは処理しますので大丈夫です
お気遣いありがとうございます
944 :
NAME IS NULL:2014/12/31(水) 03:07:24.54 ID:sJ8tBVVY
やるんだったら、一応、カラムにBINARY属性を付ける方がいいよな。
ブログの様なシステムを制作しており、そのブログの設定はMySQLではなく静的ファイルに保存するようにしています。
他のシステムを見ると設定自体もMySQLに保存しているようなのですが、設定は1レコードのみのテーブルを用意して保存しているのでしょうか?
設定をRDBに保存するとどうしても無駄が多いように感じてしまうのですが、何か特殊な設定があるのでしょうか?
よろしくお願いします。
なんで1レコード?
nameとvalueのテーブル作って
(1ページあたりの記事数,5),
(背景の色,#f00),
(タイトル,mYbloG),
って放り込めばいいんじゃないの?
947 :
945:2015/01/04(日) 15:06:56.96 ID:???
ありがとうございます。
たしかにそうですね。設定毎のフィールドを用意することを勝手にイメージしてました。
その方法でも設定が少量であればRDBとして無駄に思えるのですが、その方法が一般的になるでしょうか?
設定を参照する度にnameを検索することが少々無駄に感じてしまいます。
まあ何回かやってみれば
テキスト使うのが馬鹿らしくなるのでわかると思う
使い方慣れるまでは面倒かもしれないけど
>>947 製作者がそういう風にしたほうが便利だと思ったからやってるだけ。
あなたは静的ファイルのほうが無駄がないと思っているからそうしているだけ。
よそはよそ、うちはうち。
だから別に気にしなくていいよ。
DBに持たせているとBLOG記事と一緒にバックアップを取ることもできて
便利のような気がするけど。
後はloginid,name,valueとしてユーザー毎に設定を保持できるように
するのも楽だし(もちろん静的ファイルでも可能だけど)。
>設定を参照する度にnameを検索することが少々無駄に感じてしまいます。
静的ファイルから読みだすのと対して変わらないような。
>>947 ユニークIDを付けて、運用時はそれをキーに検索したらどうかな。
952 :
945:2015/01/04(日) 17:33:53.17 ID:???
皆様有難うございます。
15年来設定をテキストファイルで保存していたため、どうもRDBをRDBとして使う以外のことに抵抗があるだけなのかも知れません。
現在はテキストファイルに固定長で保存しているためにポインタをシークするだけで検索などは不要のため、どうも一々RDBに問合せを出すということが無駄に感じていました。
いくつかのWebシステムを読んでみたのですが、MovableTypeは少し特殊な方法かも知れませんが、多くの場合
>>946さんの方法で行っているようです。
私もバックアップの事を考えている中でMySQLに入れることを考えたのですが、OpenPNEは画像ファイルもアクセス制限のためにDBに入れるなど、システム毎にいろいろな方法があるんですね。
ありがとうございました。
954 :
945:2015/01/04(日) 22:38:47.41 ID:???
気持ち悪いというか、valueフィールドはchar型にしなければならないので、ブール値や数値を一々変換するのが少々手間がかかる上に無駄に感じていますね。
そのために設定テーブルを作ると考えたのですが、それであれば設定を追加する度にテーブルを変更する必要が有り、1レコードしか無いテーブルを持つことになるのでそれも無駄に感じてしまいます。
私のシステムを変更してみたので、しばらく使ってみようと思います。
何故世界中の多くのシステムでDBが使われているのか
それを考えたら答えは出るよな
無駄だと思うのは設計が間違っているか、DBを必要としないか
今作っているシステムがテキストファイル保存で事足りるならそれでええと思うよ
956 :
NAME IS NULL:2015/01/05(月) 19:39:05.10 ID:ECYaSO8s
テキストファイルだとブール値や数値は
いちいち変換しないのかな
957 :
NAME 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にすることによって処理速度が上がったりしますか?
【質問】
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ット
>>957 tinyintにすれば処理速度はあがります
個人的には、tinyintが好きではないのでsmallintを使います
データの大きさにもの凄くシビアであれば、tinyintを使った方がいいのだと思います。
mysqlのバージョンが変われば、データ型の取り扱いが変わる。(MySQL3.23の頃とchar型が違う)
こんなこともあるので、あまり多くのデータ型を使いたくないのが本音ではあります。
ただ、smallintとintegerでは、違いがかなりあるので、ある程度の使い分けは仕方なし。と考えています。
>>959 処理速度は上がるんですね!
解説も参考になります
ありがとうございました
intやtinyintの()の中の数字は、表示幅だからあんまり関係ない
速度が上がるということについて信頼の置けるソースがなかな見つからず。
963 :
958:2015/01/16(金) 09:02:38.93 ID:???
カーソルロケーションを見失っている感じではあるんですよね。
INSERT INTOでExcuteしてレコードを追加するのをやめてみました。
VB6なので、カーソルロケーションをadUseClientに指定した上で、レコードをオープン
addNewでレコードを追加して、Updateすると
double型項目に71.4をセットしても、更新可能になりました。
SQL文で、Excuteするときに、カーソルロケーションを指定することって可能ですか?
965 :
958:2015/01/16(金) 14:02:53.59 ID:???
>>964 思っています。
あと、わざわざこういう言い方するのは悪意を感じて好きではないです。
指摘したいことがあるなら、指摘してください。
>>965 MySQL以外のDBだと発生しないという事を確認すること
その上で、他の人が再現する上で必要な情報を書くこと
例えばテーブルの定義、インサートするサンプルデータ
VBでやらないといけないなら、その部分のソースも
最低限、ここまでは書かないと誰もコメントくれないと思う。
967 :
958: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の値を変更しようとすると、「このレコードは他のユーザーによって変更されています」
カーソルロケーションを見失った時のような動きになります。
968 :
958: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で起こった現象が再現できます
「err=-2147217864」でググってみた?
970 :
958:2015/01/16(金) 17:24:07.00 ID:???
>>969 調べてはみました。
INSERT INTO で、double型に「71.4」をセットしてレコードを登録したときのみ発生するのかは分かりませんでした。
自分には見つけられそうに無いので、申し訳ないですが原因を教えてください。
972 :
958:2015/01/19(月) 08:28:20.33 ID:???
>>971 >なんでも人に頼るのはよくないよ。googleったら俺もすぐ見つけられたし。
調べた上で、分からなかったので質問しています。
ありがとう御座いました。
973 :
958: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
教えていただきありがとう御座いました。
ODBC最近使ってないけど、そんな頻繁にまともに接続できない事態に陥るかね。
>>973が事実なら相当ひどいが。
Win2kとか化石使ってることのほうがひどい。
MySQL+PHPのPDOで内部結合した後のfetchなんですが
表に内容が違うカラムがあった場合に、変数的に同じ名前になってしまいます。
テーブルA、テーブルBに果物というカラムがあって
それぞれ、りんご、みかんだった場合
$result = $stmt->fetch(PDO::FETCH_ASSOC);
$result["果物"]はみかんになってしまいます。
foreachで回してみても、りんごはどこにも居ないわけですが
これはテーブル設計が駄目で
対応はテーブルAにテーブルBを内部結合、またはテーブルBにテーブルAを内部結合といった
対策をとるしかないのでしょうか。
AS で名前つけるとかViewを作るとか
select A.果物 as A_果物, B.果物as B_果物 from 〜
979 :
976:2015/01/26(月) 14:20:07.04 ID:???
>>977,978
なるほどこういう機能があったんですね
素早いご回答ありがとうございます。
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 は使用していません。
もっとこうした方がいいとか、助言があればよろしくお願いします。
>>980 > 文字コードがまちまちで
> sjis を無理矢理バイナリとして格納している
4.1以上へのアップグレードはこういうの直さないとうまくいかないから
アプリ修正も視野に入れた方がいいです
>>975 そう?
Win2kは、まだ10台くらいある
Xpは30台くらい
うちは全部で200台くらいだけど、そのくらいの規模で一々MSのご都合に合わせてPC全部買い換えるとこがどれくらいあるんだろ。
200台ってクライアントじゃないの?MySQL入れるの?
まあそれでもクライアントならパフォーマンスやハードのサポート切れたりするから
Win2kはないなあさすがに
>>984 975の話しの流れは、クライアントの話しだよ
クライアントがWin2kで、ODBC接続する話しの流れからだから。
>>983 いろいろ言いたいけど、ピンポイントでいうなら、なぜ買い換えるという発想になるの?
>>986 なんでこんな関係ない話しを広げようとするのか分からないけど・・・
買い換えるという発想にならないから、Win2kやXPも残っているという話しなんですが。
どうして、これに食いつくのか理解出来ない。
>>987 食いついたとか、広げようとか、そんな豪勢なもんじゃないよ。
何でPCを買い換えるんだろうなって思っただけで。
管理者じゃないんだろうし、どうでもいい話でした。
普通OS入れ替えだよね
990 :
980: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 しか使ってないので、こういう不自然な処理を
普通にしてたのを久しぶりに思い出しました。
まあ、とりあえず叩けば映るので、必要に迫られるかさくっと挿入できる
いい案が浮かぶまで温存させておくことにします。
991 :
958: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
992 :
958:2015/02/06(金) 18:15:22.05 ID:???
ごめんなさい。
手持ちのソースからコード抜粋したので余計な部分も載ってます。
SQL文だけ参考にしてみてください
ターミナルの設定の問題。CJKの文字幅設定がどっかにあるじゃろ。
Cjkにチェックを入れても変わらないですね。。
あ、ぱっと見でCJKの問題だろうとは思ったんだけど、それってmysqlが作ってる表自体がずれてるって話かな。
ならmysqlの出力設定になんかあるんでないの