1 名前:nobodyさん [2005/08/03(水) 21:00:39 ID:TuHx69hT] 国産フレームワーク、Ethnaでいい意味で手抜きなプログラミングライフを。 Ethna -PHPウェブアプリケーションフレームワーク- ethna.jp/ SourceForge.jp: Project Info - Ethna sourceforge.jp/projects/ethna/
117 名前:nobodyさん mailto:sage [2006/01/27(金) 09:15:55 ID:???] 完全にスレ違いだが。 >>116 これはちょっと・・・・Ethnaとの越えられない壁を感じる。 まず、ローマ字綴りのファイル名とかいきなりorz。 setter/getterはせめてisset確認して欲しいとか。 ShiftJIS使うなとか。 もしかして、JJ?
118 名前:nobodyさん mailto:sage [2006/01/27(金) 09:43:54 ID:???] >>117 ローマ字はキモイな。 でも形にして公開するあたりは評価に値する。 内容は見てないけど。
119 名前:nobodyさん mailto:sage [2006/01/27(金) 11:37:31 ID:???] >>116 ttp://pharon.lolipop.jp/table_mente/menu.php これformの内容がまったくエスケープされてないんだが。 修正の所でaaaで検索してみそ。
120 名前:nobodyさん [2006/01/27(金) 20:59:08 ID:IoK0izfX] Ethnaのスクリプトを一ファイルにまとめる機能って Actionも含めて一ファイルにするんですか? システム関連のファイルのみ?
121 名前:nobodyさん mailto:sage [2006/01/29(日) 12:00:04 ID:???] >>120 やった事ないからわからないんですが、たいしてパフォーマンスは改善されなかった って書いてあったような気がします。 予想だけど、actionは無理じゃないかな。 Ethnaのソースコードはそんなにファイル数ないからあまり効果ないのでは。
122 名前:nobodyさん mailto:sage [2006/01/30(月) 08:44:39 ID:???] Ethna-0.2.0正式リリース
123 名前:nobodyさん mailto:sage [2006/01/31(火) 01:04:57 ID:???] Ethna-0.2.0 リリースキター 藤本神のblogでも、時間がとれるようになったからどんどんフィードバック していきたいみたいな事が書いてあって、期待大。
124 名前:nobodyさん mailto:sage [2006/01/31(火) 02:13:43 ID:???] ロゴの投票やってるのでどうぞ。 ttp://ethna.jp/ethna-logo.html 4が一番人気だけど、なんかのロゴに似てるな。 なんだろう。
125 名前:nobodyさん mailto:sage [2006/01/31(火) 04:34:55 ID:???] 確かにどこかで見たような気がする・・なんだっけ。 シンプルに4番って気もするけど、個人的には遊びゴコロを感じる1番を押したい
126 名前:nobodyさん mailto:sage [2006/01/31(火) 07:20:37 ID:???] EthnaってMojaviでいうModuleないの? Actionだけだとファイルがごちゃごちゃになりそうな気がするんだけど
127 名前:nobodyさん mailto:sage [2006/01/31(火) 10:30:34 ID:???] >>128 ないと思う。 action_foo_bar_baz と 自分で階層を作るのかな? 工夫すればそれっぽい事はできそうだけど。
128 名前:nobodyさん mailto:sage [2006/01/31(火) 10:52:09 ID:???] やっぱり? 個人的には 人間が容易に把握できると言われる オブジェクトのプロパティー数=7+-2個程度が 一つのディレクトリにいれておくActionファイル数としても ちょどいいと思う。
129 名前:nobodyさん mailto:sage [2006/02/02(木) 13:49:37 ID:???] Windows 2K+PHP 5.2.1なんですが・・・ C:\>pear install Ethna-0.2.0.tar.gz parsePackageName(): "0.2.0.tar.gz" is neither a valid version nor a valid state in "Ethna-0.2.0.tar.gz" invalid package name/package file "Ethna-0.2.0.tar.gz" Cannot initialize 'Ethna-0.2.0.tar.gz', invalid or missing package file Package "Ethna-0.2.0.tar.gz" is not valid install failed となりました。 一応ご報告まで。
130 名前:nobodyさん mailto:sage [2006/02/02(木) 15:27:31 ID:???] Ethna-0.2.0正式版がでてからWindows上できちんと動作してます? Ethnaのディレクトリをinclude_path(*)に加えても、 Warning: main(Ethna/Ethna.php): failed to open stream: No such file or directory in D:\foo\bar\app\Bar_Controller.php on line 20 とかいわれるし・・・。PHP 5.2.1とPHP4.4.2の両方で試したけど。 (*)php -i > info.txt include_path .;D:\PHP\PEAR;D:\PHP\Ethna .;D:\PHP\PEAR;D:\PHP\Ethna
131 名前:nobodyさん mailto:sage [2006/02/02(木) 15:58:51 ID:???] >>130 Ethna ディレクトリの親ディレクトリを include_path に加えなはれ。 ていうか PEAR のディレクトリが include_path に入ってるなら pear install Ethna-0.2.0.tgz だけで済むのに。
132 名前:130 mailto:sage [2006/02/02(木) 16:17:36 ID:???] >>131 動きました。 助かりました。ありがとう。 すみません>>129 も私でした。 他のパッケージはインストールできるのですが、Ethnaは 1) pear install Ethna-0.2.0.tar.gz 2) pear install Ethna-0.2.0.tgz どちらもだめですね。うむむ。 1) [ethna-users:0191] より。 ちなみに2)の場合はこんなメッセージでした。 D:\>pear install Ethna-0.2.0.tgz No releases available for package "pear.php.net/Ethna" Cannot initialize 'Ethna-0.2.0.tgz', invalid or missing package file Package "Ethna-0.2.0.tgz" is not valid install failed
133 名前:nobodyさん mailto:sage [2006/02/03(金) 01:35:22 ID:???] >>132 ダウンロードしたEthnaが置いてあるディレクトリに移動するとか、 Ethnaのある場所を指定してやれば良いんじゃないの?
134 名前:130 mailto:sage [2006/02/03(金) 08:50:06 ID:???] >>133 そういう意味だったの・・・。 てっきりダウンロードから自動でやってくれるのかと・・・。 失礼しました。
135 名前:nobodyさん mailto:sage [2006/02/03(金) 18:12:16 ID:???] 今更だけど・・・ pear install ****/Ethna-0.2.0.tar.gz でも動くよね?
136 名前:130 mailto:sage [2006/02/04(土) 14:25:12 ID:???] >>135 pear install prdownloads.sourceforge.jp/ethna/18710/Ethna-0.2.0.tar.gz でインストールできることを他のマシンで確認しました。
137 名前:nobodyさん mailto:sage [2006/02/12(日) 00:59:00 ID:???] AppObjectは面倒くさくて使う気になれないんですが、使うとどういう点で幸せになれますか? いまいちピンときません。
138 名前:nobodyさん [2006/02/12(日) 16:10:39 ID:HHAh2SKQ] >>137 テーブルを永続オブジェクトとして扱える。 ↓ SQLを使わずに永続オブジェクトを通してテーブルにアクセスできる。 ↓ DB非依存のコードになる。 ↓ ちょっと幸せ
139 名前:nobodyさん mailto:sage [2006/02/12(日) 21:05:40 ID:???] >>138 AppObject自体が mysql にべっとりだけど?
140 名前:nobodyさん mailto:sage [2006/02/12(日) 22:52:49 ID:???] >>139 まぁ、AppObjectを使うのはその考え方(O/Rマパ)を採用してるみたいなところあるから。 自分の使うRDBMSに合うように書き換えれば済む話だからあまりMySQLべっとりは本質的ではないと思う。
141 名前:nobodyさん mailto:sage [2006/02/13(月) 07:20:58 ID:???] >138 一晩、AppObject使ってみておっしゃることが少し理解できました。 というかオブジェクト指向がなんで必要なのか、Ethnaのおかげでうっすらわかってきました。 あと、これ便利でした。 [AppObjectを生成するコマンドラインツール] ethna.jp/pipermail/users/2006-January/000165.html
142 名前:nobodyさん [2006/02/15(水) 23:25:12 ID:ysMvv2cd] サンプルみたいなものは無いの? 実際にEthna使ってるアプリのソース見てみたいんだけど。
143 名前:nobodyさん mailto:sage [2006/02/16(木) 02:24:28 ID:???] 僕も色々見てみたいんだが、Ethna使ってるのってあんまりサンプル出回ってないよな。 公式にあるのと、MLに1,2個上がってるからそれ見るぐらいしか。
144 名前:nobodyさん mailto:sage [2006/02/16(木) 14:55:18 ID:???] Ethnaよさげなんだけど ・moduleがない ・compositeViewがない これが問題
145 名前:nobodyさん mailto:sage [2006/02/16(木) 21:04:10 ID:???] >>144 moduleとcompositeViewってなに? 何かいいことあるの? Ethnaしか知らんので、教えてくれればうれしい。
146 名前:nobodyさん mailto:sage [2006/02/16(木) 21:55:18 ID:???] moduleはAction-View-Templateのコンテナ。 クラスが増えすぎた時にごちゃごちゃにならない。 compositeViewはCompositeパターンを適用したView。 複数のAction-Viewを組み合わせて 一枚の画を作る時にとっても便利 from Mojavi3
147 名前:nobodyさん mailto:sage [2006/02/17(金) 11:34:05 ID:???] ActionFormにて あるフォームに値が入ると周辺のフォームもrequiredになるフォームグループ。 それぞれのフォーム定義に 'group' => 'hoge', ってしとくと _validateする前にざざっとissetで値が入ってるか調べてrequiredしたりしなかったり。 type=radio,checkbox,select等に「その他」の項目を作ってそれを選んだ時だけ すぐ下のtype=textに書かせるような疑似コンボボックス。 'combo' => array( '8' => 'other' ), ってしとくと value="8" をPOSTすっと <input type="text" name="other">がrequiredされるという。微妙。 需要ある?
148 名前:nobodyさん mailto:sage [2006/02/17(金) 13:25:02 ID:???] あります! 是非アップお願いしまっす。 コードを気軽に投稿できる場所があるといいですねぇ。
149 名前:nobodyさん [2006/02/17(金) 15:38:48 ID:pZsluFn9] >>144 そうかモジュール構造にしたいか、、 diary.eth.jp/?date=20060201 にある Ethna Viewコンポーネント(from GREE by 小泉さん) というのがcompositeViewになる。のでもうちょっとまってて。
150 名前:nobodyさん mailto:sage [2006/02/17(金) 16:50:25 ID:???] >>149 関係者 or 藤本神ご本人? 期待してます。wktk
151 名前:nobodyさん mailto:sage [2006/02/17(金) 20:01:19 ID:???] >149 は モジュール構造というか、どっちかというと >144が言うところの compositeView の事だと思っていたのですが。。。
152 名前:nobodyさん mailto:sage [2006/02/17(金) 21:29:24 ID:???] >>150 そういういらん確認はしないほうがいいんじゃね? 関係ない人が参加しようとしてるときにテンション下がりそうだし。 期待してるだけでいいじゃん
153 名前:nobodyさん mailto:sage [2006/02/18(土) 00:17:12 ID:???] >>151 モジュールは保留だけどCompositeViewは作り中ってことでは? >>152 いや俺自身何の面識もない部外者なんだけど… なんでテンションが下がるの?
154 名前:nobodyさん mailto:sage [2006/02/18(土) 18:55:13 ID:???] セイセイセイ
155 名前:nobodyさん mailto:sage [2006/02/23(木) 21:50:51 ID:???] Ethnaに関係なんだけどさ。 [ethna-users:0215] W+D Vol31に載ってたDNS検索の実装 31号なんて見当たらんのだが。どこに売ってるんだ?
156 名前:nobodyさん [2006/02/23(木) 22:58:50 ID:InB2CvHj] このスレみると join できないって書いてあるけど、 ethna.jp/ethna-changes.html を見ると、 Ethna_AppObjectのJOIN検索がSQLエラーになる(ことがある)問題を修正 とか書いてあるね。
157 名前:nobodyさん mailto:sage [2006/02/24(金) 03:16:50 ID:???] >>155 過去にWEB+DB MAGAZINEに執筆したことのある人のところには 今週のはじめくらいに届いてる。 うちにもあるよ。
158 名前:nobodyさん mailto:sage [2006/02/24(金) 08:18:52 ID:???] >>157 なるほど。 じゃあもうすぐ発売されるのね。 楽しみに待っとく。ノシ
159 名前:nobodyさん mailto:sage [2006/02/26(日) 02:52:08 ID:???] >>156 でも@todoには「複数テーブルのJOIN対応」と書いてあるし JOINしたクエリを返す_SQLPlugin_SearchTableは未実装。 更新履歴のはJOINでなくてANDという意味だったりして。 >>157 定期購読も早く届く。
160 名前:nobodyさん mailto:sage [2006/02/26(日) 12:22:12 ID:???] >>159 たしかに未実装と言えば未実装なんだけど、_SQLPlugin_SearchTableは 継承先クラスでベタなSQLを書いてやれば動作するっていう意味では 実装済みとも言える。 AppObjectにJOINする側のプロパティとJOINする側のテーブルとJOIN条件を 記述するプロパティとその記述方法があれば、具体的に_SQLPlugin_SearchTable も実装できるね。ただ、ORMではその記述方法は一般的にやや複雑になりがち。 MapleのActiveRecordもJOIN条件を記述するルールは「へー」って感じだった。
161 名前:nobodyさん mailto:sage [2006/02/26(日) 22:51:40 ID:???] ethna.jp/index.php?ethna-tutorial-form-complexvalidate これ見てるんだけど prepareの中で $this->form なんて無くね?
162 名前:nobodyさん mailto:sage [2006/02/26(日) 22:54:36 ID:???] >>161 ソースも確認しないでエスパー回答するけど、 $this->af->form じゃね?
163 名前:nobodyさん mailto:sage [2006/02/27(月) 00:00:12 ID:???] >>161-162 既出 ethna.jp/ethna-request.html
164 名前:nobodyさん mailto:sage [2006/02/27(月) 00:37:43 ID:???] >>163 わかってるなら wikiなんだから直してよ〜
165 名前:nobodyさん mailto:sage [2006/02/27(月) 00:40:08 ID:???] てか、直しました。
166 名前:nobodyさん mailto:sage [2006/03/01(水) 19:12:57 ID:???] 2月の肉の日リリースはないのは28日までだから?
167 名前:nobodyさん mailto:sage [2006/03/01(水) 20:29:34 ID:???] バージョンおかしくない?
168 名前:nobodyさん mailto:sage [2006/03/06(月) 23:22:03 ID:???] Sessionってどうやって使ったらいいのでしょう? ActionFormはSessionでも保ってくれていいんじゃないかと思うんだけどなー。
169 名前:nobodyさん mailto:sage [2006/03/10(金) 00:41:44 ID:???] >168 確かに。 hiddenつくるのめんどうだし
170 名前:nobodyさん mailto:sage [2006/03/11(土) 16:47:54 ID:???] >>168 使い方って、 $this->session->set('hoge', $hage); $hage = $this->session->get('hoge'); こういうことじゃなくて? formの値は$formに保持してるでしょ? そういうことじゃなくて?
171 名前:nobodyさん mailto:sage [2006/03/13(月) 00:08:04 ID:???] 配列strに$this->af->set()する方法がわからないです。 読むのはできるんだけどなー。
172 名前:nobodyさん mailto:sage [2006/03/13(月) 00:22:34 ID:???] 方法があると思い込んでたけど、ないみたい。 Ethna_ActionForm.php に function setArray($name,$name2, $value) { $this->form_vars[$name][$name2] = $value; } を追加してみた。 何か問題でるかなぁ。
173 名前:nobodyさん mailto:sage [2006/03/14(火) 01:54:35 ID:???] $this->af->set('hage', array('hoge' => 'fuga')); って無理?コード読んで無いけど。
174 名前:nobodyさん mailto:sage [2006/03/14(火) 12:25:45 ID:???] >173 出来ました。 ありがとうございます。 でも、 hage[’hoge’] hage[’moge’] hage[’poge’] とかあった場合、 hage[’moge’]だけをセットしたいとかってできますかね? 上のだと全部置き換わっちゃうので。
175 名前:nobodyさん mailto:sage [2006/03/14(火) 12:29:23 ID:???] $this->af->set('hage', array('moge' => $hage['moge']));
176 名前:nobodyさん mailto:sage [2006/03/14(火) 22:55:59 ID:???] 配列型のformって、 var $form = array( 'hage' => array( 'name' => '禿', 'form_type' => FORM_TYPE_TEXT, 'type' => array(VAR_TYPE_STRING), ), ); こんな風に書きますよね。 だから連想配列をセットするっていう感覚が無いなぁ。 連想配列をセットするときはもっぱら $this->af->setAppを使うと思うんだけど・・・。
177 名前:nobodyさん mailto:sage [2006/03/15(水) 00:20:47 ID:???] >175 ちょっと理解できませんでした。 これだと、$hageの中身が$hage['moge']だけになっちゃうんじゃないかと思うんですが。 >176 配列なら連想配列じゃなくても添字が数字でも構わないんですが $this->af->set 出来るんでしょうか?
178 名前:nobodyさん mailto:sage [2006/03/15(水) 16:37:02 ID:???] afって言われるとアナルファックと思ってしまうのは 俺だけ?
179 名前:nobodyさん mailto:sage [2006/03/16(木) 02:43:35 ID:???] $arg = $this->af->get('hage'); $arg['moge'] = 'moge'; $this->af->set('hage', $arg);
180 名前:nobodyさん mailto:sage [2006/03/17(金) 00:44:30 ID:???] >179 出来ました。なるほど! 感謝です。 ちょっと使いづらいかなぁと素人考え的には思いますけど、これでなれたほうがいいのかなぁ。
181 名前:179 mailto:sage [2006/03/24(金) 22:57:08 ID:???] 俺も素人だから、詳しいところはよくわからない。 MLに投げるのが一番じゃないか?
182 名前:nobodyさん mailto:sage [2006/03/27(月) 09:28:29 ID:???] >>170 便乗質問です。 例えば、 ActionA -> ViewB(画面表示) -> ActionC -> ViewD(画面表示) という流れの中で、ActionAでSessionに値を保存し、 ViewBで取り出して画面に埋め込むと正しく表示されるのですが、 ViewDで取り出しても値が残っていないようで表示されません。 ViewBとActionCの間で何か処理しないとダメなのでしょうか? Sessionなのでずっと値を保持してくれていると思っていたのですが…。 直接は関係ないと思いますが、$this->sessionと $this->backend->sessionは何か違うのでしょか? 環境はPHP5.1.2+Ethna0.2.0です。
183 名前:nobodyさん mailto:sage [2006/03/27(月) 15:27:28 ID:???] >>182 処理は不要。 $this->session->remove したり、上書きしない限り保持されたままだと思う。 session自体は値をseriarizeしてファイルに保存してるだけなので、 shellで直接覗いてみては? /{project}/tmp にsess_xxxxxxxxなファイルがあるから。 $this->backend->session は使ったことないからわかりません。
184 名前:nobodyさん mailto:sage [2006/03/27(月) 19:05:55 ID:???] >>183 レスありがとうございます。 確かにtmpディレクトリ下にsess_xxxxという名前のファイルがありますね。 恐らく、セッション情報はファイルで保存されているが、画面間の遷移で 上手く持ち回せていないような感じです。 一般的にセッションIDをhiddenやURLパラメータ、クッキーで持ち回すようにすると思いますが、 Ethnaを利用した場合、この辺は意識しなくて良いはずということなのでしょうか? Ethna_Sessionクラスの定義を見ると、何やらクッキーの操作が書かれていますが、 例えばブラウザ側がクッキーを拒否する設定にしてあると、 Session機能が使えないということはありませんか?
185 名前:nobodyさん mailto:sage [2006/03/27(月) 19:20:13 ID:???] >>184 Ethnaだけでなくphp.iniの設定も影響するのでは? 自分は session.use_cookies = 1 session.use_only_cookies = 1 にしてるんでcookieを禁止すると当然セッションは利用できませんね。
186 名前:nobodyさん mailto:sage [2006/03/27(月) 20:19:22 ID:???] >>185 クッキーに関してPHPのセッション設定とブラウザの設定を行ったところ、 Ethnaのセッション機能が上手く機能するようになりました。 フレームワークとは言っても、所詮PHPの上に構築されたものなので、 この辺の設定は影響するのは当たり前ですよね。 アドバイス、どうもありがとうございました。
187 名前:nobodyさん mailto:sage [2006/03/28(火) 04:45:19 ID:???] prefilterで設定したメンバ変数とかをアクションで使いたい場合って どうするのが一番スマートでしょう?
188 名前:nobodyさん mailto:sage [2006/03/29(水) 22:25:28 ID:???] HTMLのリンクの値はどうやってActionで取得するの? 画面A: <a href="index.php?action_admin_Hoge=true&uid=1>リンク</a> Hogeクラスでuidの値1を取得しようとして、 $this->af->get('uid'); だと取得できない。 ちなみに、$UID=$_GET['uid']; だとHogeクラスで取得可です。 ※ActionFormクラスにuid書いてあります。
189 名前:nobodyさん mailto:sage [2006/03/29(水) 23:52:13 ID:???] >>188 HTMLいい加減に書いてるのか? &は&にして、hrefがケツの"が抜けてるのが原因とか。
190 名前:nobodyさん mailto:sage [2006/03/29(水) 23:52:48 ID:???] &は&amp;
191 名前:nobodyさん mailto:sage [2006/03/30(木) 00:08:30 ID:???] 29の日リリースは???
192 名前:nobodyさん mailto:sage [2006/03/30(木) 01:55:10 ID:???] >>189 >>190 後ろの"はタイポです。&を&にしてみましたが、結果同じで$_GET['uid'] ならうまく行くんですがねぇ。 う〜ん、何がいけないんだろう? そもそも、$this->af->get('uid')で値取得するという方法自体はあってます?
193 名前:nobodyさん [2006/03/30(木) 02:43:29 ID:3Q5YeNEn] 普通は取得できるはず
194 名前:189 mailto:sage [2006/03/30(木) 08:39:35 ID:???] >>192 POSTメソッドの時は$_POSTのみがactionFormに送られて、 GETメソッドの時は$_GETがactionFormに送られる。 なので、 <form action="?action_admin_hoge&uid=1" method="POST"> とした場合、$this->af->get('uid')は得られない。 もちろん、ControllerのActionFormに送る部分をオーバーライドして定義すれば 問題ない。 そういうことではなく、ただのリンクで? であれば、ActionFormを継承で定義してるつもりがgenerate_actionで 自動生成されるvar $formで上書き定義されているとかかな?
195 名前:189 mailto:sage [2006/03/30(木) 08:43:02 ID:???] >>188 というか、Hogeクラスってなんだ? 何を継承したクラスだ? $this->af->getできるのは、ActionClass/ViewClass内と「登録済みの」AppManagerだ。どこでgetしてる?
196 名前:nobodyさん mailto:sage [2006/03/30(木) 09:29:33 ID:???] とりあえず棚。 現象が再現する最小限のソースを書いて。
197 名前:nobodyさん mailto:sage [2006/03/30(木) 10:40:26 ID:???] >>194 >>196 ありがとうございます。 再現スクリプトを書いていたら、>>194 さん指摘の var $formが上書き定義されていたのが原因だった事がわかりました。 ありがとうございました!! >>195 HogeクラスはEthna_ActionClassを継承したActionClassでした。
198 名前:nobodyさん mailto:sage [2006/04/07(金) 09:59:34 ID:???] すいません、Ethnaとはちょっと関係ないですが、配列の質問です。 selectリストボックスの作り方を教えてください。 WEB+DB PRESS Vol.27にリストボックスを つくりには、の部分で以下のような感じの記述があります。 $gender = array( 1 => array('name' => '男'), 2 => array('name' => '女'), ); これを月(1月〜12月)をforで回して作りたいのです。 どのように作ったら良いですか? また、今月をselectedにした状態で表示したいのですが、 どのように実現させたらいいですか? テンプレートでは以下のように書いています。 {select list=$app.month name="month" value=$form.month}月 よろしくお願いします。m(__)m
199 名前:nobodyさん [2006/04/08(土) 03:14:33 ID:NDJpgQtZ] AppObjectのPostgres対応化断念。 さようならEthna・・・。
200 名前:nobodyさん mailto:sage [2006/04/08(土) 14:58:41 ID:???] >>199 なんで? どこでひっかかる?
201 名前:nobodyさん mailto:sage [2006/04/08(土) 15:03:52 ID:???] >>199 さようならPostgres のほうがいいよ
202 名前:nobodyさん mailto:sage [2006/04/08(土) 15:11:42 ID:???] >>199 >>200 同様どこでひかかるの?
203 名前:nobodyさん mailto:sage [2006/04/08(土) 17:21:13 ID:???] >>202 Ethna_AppSQL::unescapeSQL() あたりじゃないかな。 自分もMySQLに依存しないようにPEAR::DB対応にしようとして、それで挫折した。 Ethna_AppSQL::unescapeSQL() でエスケープに addslashes() を使ってることも問題なんだけど。
204 名前:200 mailto:sage [2006/04/08(土) 20:25:37 ID:???] >>199 それなら$dsn取ってきて、それぞれのRDBMにあわせた処理すればいいだけじゃん。 これくらいで諦めるのはもったいないですよ。 function escapeSQL(&$var) { $ctl =& Ethna_Controller::getInstance(); $dsn = current($ctl->dsn) ; $db_type = substr($dsn, 0, strpos($dsn, ':')); if (!is_array($var)) { if (is_null($var)) { $var = 'NULL'; } else { switch($db_type){ case 'pgsql' : $var = pgsql_escape_string($var) ; break ; default : $var ='¥'' . addslashes($var) . '¥''; } } return; }
205 名前:200 mailto:sage [2006/04/08(土) 20:30:11 ID:???] あ、unescapeか。スマソ。 でも、RDBMにあわせたunescape自体が結構面倒そう。 ライブラリ探すか、力技使うしか無いと思うが。
206 名前:nobodyさん mailto:sage [2006/04/08(土) 21:07:01 ID:???] 予めこういうところが設定の書き換えだけで切り替えられるようになってるともっといいのにね。
207 名前:nobodyさん mailto:sage [2006/04/09(日) 01:17:55 ID:???] mysqlとpostgresとsqliteくらいつかえればたいていの人が満足するのかな。 oracleとか使ってる人いる?
208 名前:nobodyさん mailto:sage [2006/04/09(日) 02:37:42 ID:???] ノ
209 名前:nobodyさん mailto:sage [2006/04/09(日) 05:54:19 ID:???] >>207 できるなら、MSSQLの対応も。
210 名前:202 mailto:sage [2006/04/09(日) 10:16:14 ID:???] mantis でも使われている adodb あたりも考えたことがあるんだけど これも面倒そうなんだよね。
211 名前:nobodyさん mailto:sage [2006/04/09(日) 15:08:46 ID:???] 私はpostgreSQLですが、AppObjectを使わないという選択肢をとってます。 ちょっとさびしいけどねぇ。 postgreSQLは日本では結構なユーザがいるので、非対応はコミットしてくる人を減らてるような気がします。 偉い人がんばれ
212 名前:nobodyさん mailto:sage [2006/04/10(月) 23:20:29 ID:???] >>209 MSSQL をわざわざ PHP から使うのか
213 名前:nobodyさん mailto:sage [2006/04/11(火) 10:05:10 ID:???] PHPからOracle使ってる俺がきましたよ。
214 名前:nobodyさん mailto:sage [2006/04/11(火) 11:45:21 ID:???] Oracleは普通に使われてると思う。 MSSQLはPHPで使ってる人が少なすぎて、MSSQLモジュール自体が メンテされずに、大分怪しいものになってるという噂も聞く。
215 名前:nobodyさん mailto:sage [2006/04/14(金) 19:12:28 ID:???] アクションから別のアクションを呼ぶのってどうやればいいんですか? バリデートエラーのときに、前のアクションを実行して戻したいときのような
216 名前:nobodyさん mailto:sage [2006/04/14(金) 20:16:35 ID:???] DBで、queryした後のエラー判定とかってできないでしょうか? ethnaとおってるからisErrorが効かないようなんですが
217 名前:nobodyさん mailto:sage [2006/04/14(金) 23:31:20 ID:???] >>215 parent::prepare(); とか