SQLite Part.10

1NAME IS NULL2012/08/16(木) 21:54:16.20ID:???
組み込み型データベース SQLite について語るスレッドです。

SQLite
http://www.sqlite.org/

・C/C++ API
 http://www.sqlite.org/c3ref/intro.html

・Syntax
 http://www.sqlite.org/lang.html

・Limits
 http://www.sqlite.org/limits.html

・Support
 http://www.sqlite.org/support.html

2NAME IS NULL2012/08/16(木) 21:54:47.06ID:???

3NAME IS NULL2012/08/16(木) 21:55:28.81ID:???
【ツール】
 http://www.sqlite.org/cvstrac/wiki?p=ManagementTools

・TkSQLite
 http://reddog.s35.xrea.com/wiki/TkSQLite.html
・PupSQLite
 http://www.eonet.ne.jp/~pup/software.html
・SQLite Manager (Firefox add-on)
 http://code.google.com/p/sqlite-manager/
 https://addons.mozilla.org/ja/firefox/addon/5817

【ラッパ】
 http://www.sqlite.org/cvstrac/wiki?p=SqliteWrappers

・System.Data.SQLite (ADO.NET 2.0 Provider)
 http://sqlite.phxsoftware.com/
・SQLite ODBC Driver (ODBC)
 http://www.ch-werner.de/sqliteodbc/
・SQLite JDBC driver (JDBC)
 http://www.xerial.org/trac/Xerial/wiki/SQLiteJDBC
・SQLite Java Wrapper/JDBC Driver (JDBC、Java)
 http://www.ch-werner.de/javasqlite/
・SQLiteJDBC (JDBC)
 http://www.zentus.com/sqlitejdbc/ ※ページ行方不明

4NAME IS NULL2012/08/16(木) 21:56:04.72ID:???
【ネタ】

・OS X ハッキング! SQLiteが広げるこれからのアプリケーション
 http://journal.mycom.co.jp/column/osx/236/

・SQLite Java Wrapperのコンパイル
 http://syo.cocolog-nifty.com/freely/2007/10/sqlite_java_wra_f79c.html

・生まれ変わるPHP - Zend Engine 2、SQLiteの実力は?
 http://news.mynavi.jp/special/2004/php5/007.html

・SQLite性能評価その1
 http://www.sutosoft.com/room/archives/000450.html

・Fulltext index on SQLite
 http://www.dodgson.org/omo/t/?date=20061001

・SQLite の全文検索を Python から使ってみる (1)
 http://plaza.rakuten.co.jp/kugutsushi/diary/200707270001/

・SQLite Full Text Search with MeCab
 http://reddog.s35.xrea.com/wiki/SQLite%20Full%20Text%20Search%20with%20MeCab.html

・MSDN Magazine: 働くプログラマ - SQLite の内部
 http://msdn.microsoft.com/ja-jp/magazine/ff898405.aspx

・アドビ、SQLite Consortiumに参加で開発を支援
 http://builder.japan.zdnet.com/db-sql/20368174/

・SQLiteに参加、Berkeley DBの置き換え狙うOracle
 http://news.mynavi.jp/news/2010/07/06/032/index.html

・How SQLite Is Tested
 http://www.sqlite.org/testing.html

5NAME IS NULL2012/08/16(木) 21:56:41.67ID:???
【書籍】

・SQLite入門 第2版 (西沢直木 著)
 http://www.amazon.co.jp/dp/479811944X
 入門用にはとりあえずこの一冊?

・新標準SQLite
 http://www.amazon.co.jp/dp/4797354739

・SQLite ポケットリファレンス
 http://www.amazon.co.jp/dp/4774143944

・Pocket詳解 SQL辞典 (堀江美彦 著)
 http://www.amazon.co.jp/dp/4798018619
 各種 RDBMS 対応の SQL のリファレンス本で、SQLite にも対応。
 が、ざっと見たところ SQLite に関してはあまり緻密に調べられておらず
 不正確なところもあるように見受けられる。

・基礎から学ぶWebデータベースプログラミング (堀川久 著)
 http://www.amazon.co.jp/dp/4274065294
 前半は SQL の基礎について、後半は Ruby で Web アプリの作成についての説明。
 PostgreSQL, MySQL, SQLite の仕様の違いにも触れられている。
 が、 SQLite は SQLite2 ベースなので情報が古いかも。

・PHP+SQLite実践サンプルブック (豊崎直也 著)
 http://www.amazon.co.jp/dp/4883374297
 内容不明。7年前の本。

・The Definitive Guide to Sqlite (Mike Owens 著)
 http://www.amazon.co.jp/dp/1590596730

・SQLite (Developer's Library) (Chris Newman 著)
 http://www.amazon.co.jp/dp/067232685X

・Using SQLite (Jay A. Kreibich 著)
 http://www.amazon.co.jp/dp/0596521189

6NAME IS NULL2012/08/16(木) 21:56:54.46ID:???
テンプレここまで。
SQLiteスレもついにスレ番2桁目に突入です。

7NAME IS NULL2012/08/17(金) 00:25:14.78ID:SazVH8Xb
SQLiteでの同時処理について質問です。
あるテーブルで値を+1する処理を行っています。

UPDATE sample_table SET count=count+1 WHERE num = $num

処理が呼ばれるとsample_tableのcountが1増えます。
ですがこが同時に100回行っても100増えません。
ゆっくりと100回行うと100増えます。

おそらく前の処理をしている最終に読み取った値に+1をしているのでうまく増えていないということだと思うんですがどのようにすれば行った回数分countを増やせるでしょうか。

8NAME IS NULL2012/08/17(金) 18:35:23.58ID:???
>>7
前の処理のロック区間中にUPDATEしようとしてエラーになった分が更新されていない、とか
更新される前のcountの値を読み込んでインクリメントしたので前と同じ値を上書きしてしまっている、とか

いくつか原因は考えられるけど、情報が足りないので答えられないです。
・そもそも「同時処理」とは何を想定している?
・「同時に100回行う」ための手段(orコード)は?(SQL文だけ貼られても何がしたいのか分からない)
・「ゆっくり」とは何をどうしたの?

972012/08/17(金) 20:59:58.15ID:5J6i+lyv
>>8
回答ありがとうございます。

こちらのcount+1を行うものはWEBサイトにおいておりまして、特定のアクセスが行われると+1されるというものになります。
そのため不特定多数の場所からアクセスがある状況です。
アクセスカウンターのようなものをSQLite3で行っておりアクセス毎に+1されます。

同時処理についてですが、こちらはWEB上から処理を行うようになっております。
そのため複数の箇所から同時に多数の要求があった場合に処理が複数走ることを指します。

100回行うコードというのはありません。
テストのためにApacheのabというツールで10アクセス10スレッドで100のアクセスを行いました。
その際に+100ほど数値が増えないといけないのですが、実際には30程度しか増えておりませんでした。

ゆっくりというのは手動でアクセスを100回した場合のことを指しております。
F5でリロードを100回するのに近いと思います。
そのためゆっくりアクセスを行うというニュアンスで使用いたしました。

質問内容に不備があり申し訳ありませんでした。
対策が思いつかないのでアドバイスなどいただけると助かります。

10NAME IS NULL2012/08/17(金) 22:09:50.59ID:???
ただの排他漏れだろ
アクセスカウンタ作ったことないの?

11NAME IS NULL2012/08/17(金) 22:25:47.30ID:???
>>9
質問する時はコードも貼ること。
もちろん、100回のクエリが全部成功してるかどうかは確認したんだよね?

1272012/08/17(金) 23:00:01.29ID:SazVH8Xb
>>9
アクセスカウンタは作ったことあります
排他制御も知ってはおりますが、SQLiteではどのように排他制御を行うのでしょうか?

>>10
100回のアクセスが成功していることは確認しています。
アクセスのテストについては申し訳ないですがツールを使用しているためコードがありません。
カウントの部分については

$connect = count_db();
$countup = $connect ->prepare("UPDATE sample_table SET count=count+1 WHERE num = $num");
$countup ->execute();

となります。

13NAME IS NULL2012/08/18(土) 01:21:41.82ID:???
>>12
SQLiteはそこら辺のDBMSと同じで別に何もしなくても「排他制御」はされるよ。
「100回のアクセス」とやらが成功しているのをどうやって確認したのか知らないけど、どう考えてもSQLクエリの実行が失敗してる。

見たところPHP+PDOって感じだけど(質問する時は言語名くらい書くこと)、count_db()が何だか分からないし、
prepareなのにプレースホルダ使ってないし、クエリの実行結果が成功かどうか確認しているようにも見えないし、
とりあえずPHPとPDOとデータベースを先に勉強した方が良いと思うよ。

あと、テーブル構造とか変数が何だか分からないから、クエリ自体があってるのかすら確認できないけど、まあそれはいいや。

1472012/08/18(土) 01:37:10.10ID:ZAlPZ/Vl
>>13
アクセスの成功に関しては負荷ツール側で全てのリクエストがHTTPステータス200で終了していることで確認しました。
ですのでSQLクエリの実行が失敗していると見てよいのかの判断がついておりませんでした。

排他制御は行われているとの事なのでカウントがプラスされていない時点でクエリが正常に実行されていないと見るべきでした。
申し訳ありません。

count_db()については
function count_db()
{
$connect = new PDO("sqlite:./sample_table.sql3");
return $connect ;
}
となります。

テーブル構造は
sample_table
------------------
|num | count |
------------------
|index | 1 |
|contact | 30 |
------------------
このようになってます。
num側にページアドレス・count側にアクセス数が入っています。

PDOとデータベースの勉強のためにまずは簡単なアクセスカウンターを作ってみようかと思って作成いたしました。

15NAME IS NULL2012/08/18(土) 02:45:18.67ID:???
>>14
ページアドレスがnum…。まあいいけど。

データベースにしてもPDO(と言うかPHP)にしても入門書は腐るほど出版されてるから、
とりあえず適当なのを買ってきて読めば一通りのことは出来るようになると思う。

あと、HTTPの仕組みとかも勉強した方がいいかもね。
SQLクエリの実行結果は [DBMS] → [PHP]
HTTPステータスは [PHP(と言うかWEBサーバ)]→[WEBブラウザ]

ちなみに、今回のは排他制御がかかってる時に同時にUPDATEしようとしてエラーになったらどうするか、の考慮が漏れてるのが問題。
おそらくロック待ちのタイムアウト値が設定されていないので、100回のうちエラーになった分はスルーされてる。

これだけレスしておいてあれだけど、微妙にスレ違い(今のところあんまりSQLite関係ない)だし、ヒントも書いたので、
あとはWEBプログラミング板の適当なスレに移動した方が幸せになれるかもしれない。勉強頑張れ。

1672012/08/18(土) 10:12:45.63ID:ZAlPZ/Vl
>>15
ありがとうございます。
排他中の制御に関してはまったく考慮しておりませんでした。
前の処理が終わるまで順番に待っているだろう
くらいの認識でした。

amazonあたりで評価の高そうな本をいくつか見てみたいと思います。
ありがとうございました。

17NAME IS NULL2012/08/19(日) 12:50:44.77ID:???
外部結合しているテーブルの行をを一度に消す方法はないのでしょうか?
delete TBL_A from TBL_A left join TBL_B on TBL_A.keyid = TBL_B.id where TBL_B.keyid = 4;

delete from TBL_A from TBL_A left join TBL_B on TBL_A.keyid = TBL_B.id where TBL_B.keyid = 4;
など紹介されているものを色々試してみたのですが、どうしてもsyntaxerrorがdelete直後の単語ででてしまいます。
テーブルごとに削除するしかないのでしょうか…?

18NAME IS NULL2012/08/19(日) 12:58:41.83ID:???
DELETEはFROM一つしか書けないよ。JOINも当然書けない。
メインのテーブルのレコードを削除したとき必ず従属テーブルのレコードを削除するならトリガーに書きなよ。

19NAME IS NULL2012/08/19(日) 13:10:56.17ID:???
>>18
回答ありがとうございました。
トリガー使ったことないのですが、挑戦してみます。

20NAME IS NULL2012/09/01(土) 21:03:38.85ID:???
ばか

21NAME IS NULL2012/09/02(日) 10:39:44.98ID:???
そんな事言うんじゃないよ

22NAME IS NULL2012/09/04(火) 15:49:22.12ID:F14l33sJ
sqliteのファイルを読み込む際に、そのファイルがsqliteのファイルであるかどうかを確認することはできますか?
sqlite以外のファイルを読み込んだ際に当たり前ですがエラーが出るのでそれに対処したいと思っています。
読み込むsqliteのファイル名に規則性がないので振り分けができないので、ファイルがsqliteファイルであるかどうか確認する方法があれば教えてもらえると助かります。

23NAME IS NULL2012/09/04(火) 18:33:24.81ID:???
3.7.14

24NAME IS NULL2012/09/04(火) 18:48:09.39ID:???
>>22
自分で結論にたどり着いてるみたいだけど…。

>sqliteファイルであるかどうか確認する方法
>sqlite以外のファイルを読み込んだ際に当たり前ですがエラーが出る

25NAME IS NULL2012/09/04(火) 19:16:39.20ID:???
>>24
ワロタ
確かに、エラーが出てるとわかってるならそれでいいじゃんとなるけどねw

事前に判断することができるか?という希望に答えるとすると、
C言語的にはファイルを開いて先頭16バイトバイナリ読込して、
"SQLite format 3\x00"とmemcmpして見れば一応わかる。
ただし、こんなものは偽装はできるし、このヘッダ部は正常でも、sqlite的に演算したら
ファイルが破損していた場合は結局エラーになるので価値は・・・疑問かな。
sqlite3_openv2がエラーを返すならそれで判断するのが良いよ。


26NAME IS NULL2012/09/08(土) 22:56:07.38ID:???

27NAME IS NULL2012/10/01(月) 13:04:19.93ID:Miyu12UY
SQLite3使ってますがカラムの追加は最後尾にしか出来ないでしょうか?
| 1 | 2 | 3 | 4 |
とあった場合
| 1 | 2 | 3 | 3.5 | 4 |
としたいと思ってます。

28NAME IS NULL2012/10/01(月) 18:41:19.91ID:???
>>27
http://www.sqlite.org/lang.html
http://www.sqlite.org/lang_altertable.html
http://www.sqlite.org/lang_select.html

質問する時は、何をするために、どういうSQL文を使って、結果がどうなって、それが目的とどう違ったか、くらいは書くこと。
じゃないと ドキュメント読んで下さい くらいしか答えられない。

29NAME IS NULL2012/10/01(月) 20:48:13.89ID:???
>>27
ALTERならどのDBMSでもそうじゃないの?
テーブルを作り直してINSERTすればいいじゃん。

30NAME IS NULL2012/10/01(月) 21:13:45.41ID:???
そういう話なら、alter table文の最後に"before カラム名"とか"after カラム名"をつけると、テーブルをselect *で見た時に、
意図した場所に入ったように見せる(物理ディスク上はどうせ最後に追加される)ことができるRDBMSは結構あると思う。

けど、もしかしたらSQL標準には無かったかもしれない。

と言うか>>27の目的はselect文で順番を変えるだけで済むような。

31NAME IS NULL2012/10/02(火) 09:44:14.60ID:???
select *しか知らいないと予想してみる

32NAME IS NULL2012/10/02(火) 10:27:01.41ID:mMJozPXq
SQLite3はMySQLみたいに任意の場所に追加は出来なかったと思う
どうしても順序通りに作りたいなら
テーブル作り直して、Insertしかないと思う。

SQLite3で before カラム名 が出来るかどうかは試したこと無い。

33NAME IS NULL2012/10/02(火) 14:19:36.21ID:mMJozPXq
SQLiteってあんまし触ったこと無かったけど
insert into test('test','test2') values ('1','2'),('3','4');
って出来ないの?
insert into test('test','test2') values ('1','2');
なら出来るんだけど、複数insertするとときの作法がよくわからない。

34NAME IS NULL2012/10/02(火) 15:03:40.02ID:???
>>28にもあるようにドキュメント読めばすぐに解決できるだろうが
http://www.sqlite.org/lang.html

35NAME IS NULL2012/10/02(火) 15:10:52.98ID:mMJozPXq
なるほどね
さすがにLiteっていうだけあって色々制限あるね

というかこれからの質問は

ドキュメント読めばすぐに解決できるだろうが
http://www.sqlite.org/lang.html

のテンプレ張れば解決だな

36NAME IS NULL2012/10/02(火) 19:11:09.49ID:???
と言うか最初からテンプレにある。>>1にアンカ張れば解決。

37NAME IS NULL2012/10/02(火) 23:24:28.10ID:???
sqlite> .version
SQLite 3.7.14 2012-06-30 ********
sqlite> CREATE TABLE jedict (jword TEXT, eword TEXT);
sqlite> INSERT INTO jedict ('hon', 'book') , ('kon', 'navy'), ('mon', 'gate');
sqlite> select group_concat(jword, '_') from jedict;
hon_kon_mon

38NAME IS NULL2012/10/03(水) 08:58:58.06ID:7gCK7EIm
>>37
これで挿入は出来るんだけどカラム増やすためにDB作り直したときにいっつもこまってるんだよね
sqlite> CREATE TABLE jedict (jword TEXT, eword TEXT)

sqlite> CREATE TABLE jedict (jword TEXT, eword TEXT, hword TEXT);
にしたとき
INSERT INTO jedict ('hon', 'book') , ('kon', 'navy'), ('mon', 'gate');
だと困るからいっつも
INSERT INTO jedict ('hon', 'book', '') , ('kon', 'navy', ''), ('mon', 'gate', '');
こんな感じに書き直してから挿入するので手間がかかってしょうがない



39NAME IS NULL2012/10/03(水) 10:20:22.92ID:CNQU59aT
hword カラムを not null default '' にして追加したあと
INSERT INTO jedict (jword, eword) values ('hon', 'book') , ('kon', 'navy'), ('mon', 'gate');
じゃダメ?

40NAME IS NULL2012/10/03(水) 19:31:42.90ID:7gCK7EIm
そういう手もあるか

そもそもSQLiteで移植ってみんなどうやってんの?
MySQLとかならphpyAdminとか使ってラクラク出来るけどSQLiteでそういうのあるの?

41NAME IS NULL2012/10/03(水) 19:47:28.65ID:???
ごめん、移植ってのがよく分からない。

流れ的に>>38みたいにDB作り直して中のデータの一部or丸ごとをコピーすること?
それとも他のRDBMSにデータを持って行ったり、持って来たりすること?

42402012/10/03(水) 20:11:21.92ID:/OiJBnwO
>>41
DB作り直して中のデータを丸ごとコピーしたりすること
言葉足りずで申し訳ない

43NAME IS NULL2012/10/03(水) 21:01:38.97ID:???
そもそも、中身を丸ごとコピーしないといけないような重要なDBを、
構造を変えて作り直す状況があんまり無いんじゃ…。

44NAME IS NULL2012/10/03(水) 21:27:07.87ID:???
>>42
sqlで出来るならそれで。
できないならぶっちゃげぱっとスクリプト書いちゃうな。

45NAME IS NULL2012/10/03(水) 21:33:00.19ID:???
年中作り直すのは設計に問題がある。
カラムの追加ぐらいでいちいち作り直さない。

46402012/10/03(水) 21:45:30.94ID:/OiJBnwO
さすがにカラム追加するだけで作り直しとかはないけど
拡張して追加よりは作り直したほうがいい場合が年に1回くらいあったりしてたんで
みんなどうやってんのかと思って。

47NAME IS NULL2012/10/03(水) 21:53:02.00ID:???
年中作りなおすなんて書いてないだろ。
質問者は、作りなおすハメになったのが設計の甘さかどうかなどは問わず、
「みんな、どうするのかな?」って軽いつもりで聞いてるんだろ。

エラソーに設計に問題がーとか言ってるのは意図を汲めない馬鹿丸出しの発言だろ。
SE/PGだけが業務でコンピュータを使いう時代じゃないんだ。
少しは考えろよ。

48NAME IS NULL2012/10/03(水) 21:55:52.76ID:???
>>47
訂正、業務かどうかも前提とすべきではなかったな。

49NAME IS NULL2012/10/03(水) 22:44:52.67ID:???
「作り直す時のテクニックをみんなで考えよう」じゃなくて「みんなどうやってんの?」だからなー。
業務だったらそんなマズい設計にはならないし、趣味だったら入れなおすほどのデータなんて扱わない人が大半だろうから、
質問者へのレスとしては間違ってないと思うぞ。年中云々は知らんけど。

仮に前者を問いかけたつもりなんだとしたら聞き方を間違えてる。

50sage2012/10/04(木) 10:04:32.41ID:???
phpMyadminみたいにWEB上でお手軽に出来るのがあればいちいちスクリプト組んだりコマンド流したりやんなくていいんだろうけどね

俺はデータをどっかに持ってく場合は
各値を'で囲んで取り出して1レコードを()でくくる感じで吸い出す
('a', 'b', 'c')
こんな感じ。
あとは引越し先にinsertで突っ込む。
1回だけ構造が違うところに突っ込むことがあったけど、そんときは
('a', 'b', '', 'c')
って感じにして対応した。
そんときは80万レコードあったので2個目の,のあとに'', を追加するスクリプト組んで書き換えた。

このやり方がスマートかどうかはわかんないけど、おれは引越しするときはいつもこんな感じでしてる。

51NAME IS NULL2012/10/04(木) 11:55:58.87ID:???
>>47
いったい誰と戦っているんだよ?空気脳さん.

52NAME IS NULL2012/10/07(日) 06:57:54.73ID:???
3.7.14.1

53NAME IS NULL2012/10/09(火) 09:14:57.50ID:???
PHP上からSQLiteファイル内のデータを全部引っこ抜くようなのって無いんだっけ?
全レコードを>>50みたいな感じでおいらも引っこ抜いてるんだけど。

54NAME IS NULL2012/10/14(日) 21:06:47.63ID:???
keyとvalueしかない構造だから悩まない

55NAME IS NULL2012/10/14(日) 21:10:10.22ID:???
突然どうした?

56NAME IS NULL2012/10/15(月) 10:31:13.09ID:???
追加とか変更とかは適当にコマンド流すけど
何か変更することあればFirefoxのSQLiteManagerってやつでいじってる

それ以上のことやろうと思うならそもそもSQLiteとか使わずMySQLとか使ってるしな

57NAME IS NULL2012/10/23(火) 19:10:42.58ID:???
だからどうした?

58NAME IS NULL2012/10/25(木) 17:03:37.52ID:???
以下の様なデータが格納されているデータベースで

1
1
1
2
2
3
3
3
4

とあるデータで各値が何回出てくるかカウントするってことは出来ますか?

1=3回
2=2回
3=3回
4=1回

みたいな検索結果を得たいと思ってます。

59NAME IS NULL2012/10/25(木) 18:29:44.22ID:???
table名 theTable
カラム名 a int

a
--
1
1
1
2
2
3
3
3
4
--

select a, count(*) as cnt from theTable group by a order by a

60NAME IS NULL2012/10/25(木) 19:00:24.67ID:???
>>59
解凍ありがとうございます。
こういう組み合わせ知らなかったので凄い勉強になりました。

61NAME IS NULL2012/10/25(木) 20:50:40.94ID:???
まさかこんなレベルでプログラマじゃないよなw

62NAME IS NULL2012/10/25(木) 20:55:25.95ID:???
>>58-61
スレ違い。

SQL質疑応答スレ 13問目
http://toro.2ch.net/test/read.cgi/db/1343899481/

63NAME IS NULL2012/10/26(金) 11:16:29.38ID:???
SQL知らなくても凄腕のプログラマもいるし

64NAME IS NULL2012/11/02(金) 09:43:36.96ID:jaaHOkOC
SQLiteって別ドメインであってもファイルにアクセスさえ出来れば、どこに置いてても操作できる?

65NAME IS NULL2012/11/08(木) 09:55:55.42ID:???
http://www.sqlite.org/faq.html#q5

5) Can multiple applications or multiple instances of the same application access a single database file at the same time?

抜粋意訳
NFSでマウントすればリモートアクセス出来るが、NFSのファイルロックは信頼性か低いものもありオススメしない

66NAME IS NULL2012/11/08(木) 13:44:03.61ID:NYXd8Y9V
SQLiteってクロスドメインとかいけるんだっけ

67NAME IS NULL2012/11/12(月) 06:32:33.62ID:???
ファイルって複数のテーブル突っ込んでサイズデカくなっても
ひとつのテーブルへの速度に影響ないレベル?

68NAME IS NULL2012/11/12(月) 12:11:03.33ID:Gm0PmwJY
検索はそんなにかわんない
でもinsertとかupdateとかとかになると件数が10万件とかあると多少違ってくる

69NAME IS NULL2012/11/12(月) 16:19:44.77ID:???
>>68
ありがと! 検索メインなのでまとめてみます!

70NAME IS NULL2012/11/13(火) 09:20:19.20ID:nIGWXzwT
SQLiteってDB自体を暗号化って出来る?

71NAME IS NULL2012/11/13(火) 11:25:00.29ID:???
SQLCipherってので暗号化できるみたいだけど半有料

72NAME IS NULL2012/11/13(火) 14:18:38.88ID:???
書き出しと読み出しの部分のソスを書き換えて...
なんてのは出来そう?

73NAME IS NULL2012/11/13(火) 19:05:43.34ID:???
>>70
>>1のSupportを参照。有料で別ライセンス(パブリックドメインではない)だけど本家が出してる。

74NAME IS NULL2012/11/13(火) 20:11:51.28ID:???
暗号化してインサートすればいいんじゃね?

75NAME IS NULL2012/11/14(水) 13:58:27.32ID:???
>>72 する手間かけるくらいなら >>74 の方が良いね

76NAME IS NULL2012/11/14(水) 14:22:17.72ID:???
そか IO部分はそのままという事ね。
すぐ 出来そうな感じはする。
出来ないけどorz

77NAME IS NULL2012/11/14(水) 15:01:33.23ID:???
>>74-75
暗号化してinsertしちゃったら
検索出来なくなるじゃん

78NAME IS NULL2012/11/14(水) 17:19:18.60ID:???
I/Oはそのままってだけですよ。

79NAME IS NULL2012/11/14(水) 19:33:12.83ID:???
>>77
検索キーも暗号化して検索すればいいんじゃね?

80NAME IS NULL2012/11/14(水) 19:42:07.35ID:???
部分文字列の比較とか難しくないか?
SUBSTRINGを使った場合位置が保証されるかとか。

81NAME IS NULL2012/11/16(金) 09:14:45.66ID:A4atXoQO
そりゃrotみたいな単純なもんならいいけど、暗号化とは言えないし、そもそもそれだと部分一致とかマルチバイトとか面倒だろ

82NAME IS NULL2012/11/16(金) 12:01:41.64ID:???
>>79
キーだけ暗号化した暗号文と
キーを含む文字列を暗号化した暗号文が
部分一致することは普通はあってはならない

83NAME IS NULL2012/11/16(金) 19:56:51.69ID:???
というか、一般にそれを暗号化とは言わない。
スレ違いなのでプログラム技術板あたりへどうぞ。

84NAME IS NULL2012/11/18(日) 18:11:07.08ID:???
出来ないなら普通に出来ないって言えばいいのに

85NAME IS NULL2012/11/18(日) 18:41:32.22ID:???
暗号化した文字の比較とかの話だからスレ違いってことでしょ

暗号化が出来る/出来ないの話なら>>73で出来るって結論が出てる

86NAME IS NULL2012/11/18(日) 21:39:05.44ID:???
馬鹿には無理

87NAME IS NULL2012/11/26(月) 18:23:42.86ID:???
sqliteってファイルベースのデータベースじゃん
その作成されるデータファイルのパーミッションやユーザ権限ってどうなってんの?
ユーザ毎に保存してくれる?

88NAME IS NULL2012/11/26(月) 19:29:19.32ID:???
最後の一行がよく分からないけど、実行したユーザの権限で作成されるよ。

89NAME IS NULL2012/11/27(火) 06:20:08.86ID:???
ありがとー

90NAME IS NULL2012/11/27(火) 21:34:23.08ID:???
sqlite3_close_v2 よいよね

91NAME IS NULL2012/12/13(木) 00:45:58.76ID:???
3.7.15

92NAME IS NULL2012/12/19(水) 16:46:02.85ID:???
SQLite3の1つのDBの中に、最大でいくつまでテーブルが作成できるのでしょうか?

93NAME IS NULL2012/12/19(水) 20:57:45.96ID:???
>>92
>>1
答えはないけどヒントは書いてある。

94NAME IS NULL2012/12/20(木) 20:48:57.64ID:???
3.7.15.1

95NAME IS NULL2012/12/24(月) 08:40:38.60ID:???
.netなんですけど1つ目のテーブル読みながら2つめにコピーしようと
してるんですがdatabase file is lockedになります
mdbでやってた時は動いててそれをsqliteに置き換えただけなのですが
原因わかりますでしょうか

96NAME IS NULL2012/12/24(月) 13:12:05.39ID:???
エスパーじゃないので分かりません
コードとかSQL文を貼ってみてはいかがでしょうか

97NAME IS NULL2012/12/25(火) 12:26:49.38ID:???
>>93
すみません
いろいろと調べているのですが見つかりません。

レコード数やフィールド数はビルドオプションで設定ができるのですが、テーブル数の設定は見つけることもできません。
定数ではなく、環境依存の値になってしまうのでしょうか?

98NAME IS NULL2012/12/28(金) 01:40:36.64ID:???
テーブル数の上限はたぶん未定義で環境(ディスク残量など)に依存。
ソースを見ても SQLITE_MAX_TABLES みたいなそれらしき記号定数なし。

ためしに機械的な名前(T_0, T_1, .. T_99999)でテーブルを10万個作成してみたが作れた。

99NAME IS NULL2012/12/29(土) 00:55:06.02ID:???
予想だけど…。

SQLiteは作ったテーブルやインデックス、ビュー、トリガーとかのスキーマ情報を、
同じファイル内の特殊な予約テーブル"sqlite_master"に格納してる。
で、レコード数の上限は2の64乗=18446744073709551616と書いてある。
これをテーブル情報だけで全部使い切るには1800京個くらいのテーブルを作る必要があるけど、
仮に1レコード1バイトしか使わなかったとしても全部使えばsqlite_masterテーブルだけで170億GBくらい必要。
実際にはテーブル情報以外にも格納するから、もう少し減るとは思うけど、事実上無制限。

と、ここまで書いて気がついたけどsqlite_masterが埋まる前にページ数の上限の方が先に来るのかな?
アーキテクチャをちゃんと読まないで適当に書いてるけど、sqlite_masterの各行に、それぞれのデータが
格納されているページ番号(の先頭)を指定してた気がするから、ページ番号とB-Treeの先頭の対応が1:1で、
それぞれのテーブルが全部1ページ内に収まってるとすれば、ページ数の上限は2の31乗-2=2147483646だと
書いてあるから、そっちの上限に先に到達するのかもしれない。


どっちにしても通常運用で支障が出ることはないくらい沢山作れそうだけど、
嘘をいっぱい書いてるかもしれないので詳しい人いたら解説お願いします。

あぼーん

新着レスの表示
レスを投稿する