버클리 DB + 파이썬

yeonisdead의 이미지

C/C++ 로 버클리 DB를 핸들링 하다가 Python을 사용하면서 매우 행복해 하고 있습니다.
특히 파이썬은 Dict,List 등의 열거형 데이타 지원이 빠방해서 Java보다 버클리 DB 핸들링이 더 쉬었는데요...

Mod Python을 이용하여 간단한 BBS를 만들어 보았습니다.
버클리 DB가 조금 생소하신 분들은 소규모 프로젝트에 MySQL 대신 버클리 DB를 이렇게 사용할 수 도 있겠구나
하고 참고가 되시길 바라며... 고수분들께서는 글 내용 아래 ToDo 를 구현해 보시는 것도 좋겠습니다.

Mod Python 설정 부분과 template 인 html 파일을 제외하면 소스파일은 딸랑 1개입니다.

내용은 http://yeonisalive.net/python/BerkeleyDB_BBS.php 에서 보실 수 있구요.
파일은 차마 부끄러워 올려놓지 않겠습니다...
(위 링크 페이지에 보시면 맨 아래쪽에 py와 html template 파일들을 압축하여 올려두었습니다.)

다 들 즐프합시다~~~~

Forums: 
sb778의 이미지

버클리 DB에 대해서는 이름만 들어봤는데, 좀 더 알고싶어지네요. 저는 가볍게 DB를 써야할 때 sqlite + pysqlite를 이용합니다. 지금도 만족하고 있지만 버클리 DB는 어떤 특징이 있는지 좀더 알아봐야겠습니다. 하지만 예전에 레드햇9에 오라클9을 설치하느라 삽질했던 기억이 생생해서, 설치가 어렵다면 그냥 포기해버릴 생각입니다. ^^a

yeonisdead의 이미지

Oracle 사 홈페이지에 들어가면 OS 별 설치파일 혹은 rpm 이 있습니다. Python을 설치하실 때 BDB 옵션을 주면 기본 설치가 되구요. JAVA, PHP, Perl, C/C++, Python 등 현재 유행하는 대부분의 프로그램잉 언어에서 사용할 수 있습니다. (저는 주로 C++과 Python에서 사용합니다.)

BDB는 MySQL의 모태입니다.(아니 대부분의 DBMS의 모태라 할 수 있죠.) DB 파일을 Binary 상태로 보면 매우 유사합니다. BDB에 SQL 인터페이스를 붙이고 RPC 로 데몬구성하고 또 Indexer 를 붙이면 MySQL이 되겠지요.(붙일 게 너무 많나요 ^^, 참고로 BDB RPC 소스도 BDB 설치판에 있습니다.)

또 네이트브 XML DB인 BDBXML 도 있는데요. 조만간 Python + ModPython + BDBXML + XSLT를 이용한 BBS 예제도 올려보도록 하겠습니다.(Firefox 1.5x 이상에서 XFORM을 사용할 예정입니다.)

그럼 화이팅입니다~~~

#! BORN TO CODE

#! BORN TO CODE

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.