Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
dgw generating Go struct from potgresql table d...
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Akira Chiku
July 03, 2017
Programming
1.7k
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
dgw generating Go struct from potgresql table definition
Akira Chiku
July 03, 2017
More Decks by Akira Chiku
See All by Akira Chiku
Goの標準ライブラリで扱うフォントと画像
achiku
1
2.3k
gocon-2018-how-we-go-test-with-rdbms.pdf
achiku
6
5.8k
詳解 BTC Payment
achiku
3
3.7k
Async, Persistent, Fast, and Stable "Enought" Queue/Worker Using Go and PostgreSQL
achiku
5
9k
非同期Jobの設計と実装
achiku
0
390
How We Built Testable HTTP API Server
achiku
6
7.9k
PyCon JP 2014 Python + Hive on AWS EMRで貧者のログ集計
achiku
0
4k
Other Decks in Programming
See All in Programming
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
200
AIで効率化できた業務・日常
ochtum
0
140
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
14
5.7k
IBM Bobを活用したレガシーアプリの最新化
oniak3ibm
PRO
1
200
OSもどきOS
arkw
0
580
例外の正しい扱い方 そのエラー try-catchして大丈夫?
jinwatanabe
0
260
PHPで使える日時の表現と、その知り方 #frontend_phpcon_do
o0h
PRO
0
260
LLMによるContent Moderationの本番運用の裏側と品質担保への挑戦
suikabar
3
720
dRuby over BLE
makicamel
2
380
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.7k
ローカルLLMでどこまでコードが書けるか -拡張版 / How much code can be written on a local LLM Extended
kishida
11
4.3k
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
21
6.9k
Featured
See All Featured
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
49
10k
GraphQLとの向き合い方2022年版
quramy
50
15k
Principles of Awesome APIs and How to Build Them.
keavy
128
18k
Un-Boring Meetings
codingconduct
0
320
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
410
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
2
330
16th Malabo Montpellier Forum Presentation
akademiya2063
PRO
0
150
Lightning talk: Run Django tests with GitHub Actions
sabderemane
0
200
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.2k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
3.5k
Facilitating Awesome Meetings
lara
57
7k
Transcript
EHX (FOFSBUJOH(PTUSVDU GSPN1PTUHSF42- HPMBOHUPLZP+VM "LJSB$IJLV
NF /BNF"LJSB$IJLV 5XJUUFS!@BDIJLV (JU)VC!BDIJLV (PPHMF4FBSDI"LJSB$IJLV'JSF
BHFOEB Ø #BDLHSPVOE Ø 8IBU Ø 8IZ Ø )PX
CBDLHSPVOE
CBDLHSPVOE QSPEVDU Ø QSPEVDU Ø "QQCBTFEJOTUBOU BOESFMPBEBCMFWJSUVBMQMBTUJD 7*4"QSFQBJEDBSEGPSFWFSZPOF
Ø J04 "OESPJE Ø IUUQTWBOEMFKQ
CBDLHSPVOE QSPEVDUTJ[F Ø TJ[F BTPG+VM Ø
PGFOEQPJOUT JOUFSOBM"1* Ø PGFYUFSOBMTFSWJDFT Ø OPUJODMVEJOH4FOUSZ/FX3FMJD4UBUVT1BHFJP Ø PGUBCMFT 1PTUHSF42- Ø PGMJOFT (PDPEFXJUIPVUWFOEPSEJS Ø 5PUBM Ø 8JUIPVUUFTUDPEF
XIBU
EHX Ø IUUQTHJUIVCDPNBDIJLVEHX Ø *UHFOFSBUFT(PTUSVDU BOETJNQMF5BCMF3PX%BUB(BUFXBZ GVODUJPOTNFUIPETGSPN1PTUHSF42-UBCMFEFOJUJPOT Ø 5BCMF3PX%BUB(BUFXBZ
Ø 1SJNJUJWFGPSNPGNBQQJOHCFUXFFO(PBOE3%#.4 UBCMFBOESPX OPUMJLF"DUJWF3FDPSE%BUB.BQQFS Ø IUUQTNBSUJOGPXMFSDPNFBB$BUBMPHUBCMF%BUB(BUFXBZIUNM Ø IUUQTNBSUJOGPXMFSDPNFBB$BUBMPHSPX%BUB(BUFXBZIUNM Ø VTFS@BDDPVOUUBCMF6TFS"DDPVOUTUSVDU Ø AUZQF6TFS"DDPVOUTUSVDUAXJUIA*%A A&NBJMA A-BTU/BNFA BOEA'JSTU/BNFABUUSJCVUFT Ø A6TFS"DDPVOU$SFBUF 2VFSZFS ANFUIPEUPJOTFSU SFDPSE Ø A(FU6TFS"DDPVOU#Z1L QLJOU AGVODUJPOUPTFMFDU SFDPSECZQL
&YBNQMF CREATE TABLE user_account ( id bigserial primary key
, email text not null unique , last_name text not null , first_name text not null );
// UserAccount represents public.user_account type UserAccount struct { ID
int64 // id Email string // email LastName string // last_name FirstName string // first_name } // Create inserts the UserAccount to the database. func (r *UserAccount) Create(db Queryer) error { err := db.QueryRow( `INSERT INTO user_account (email, last_name, first_name) VALUES ($1, $2, $3) RETURNING id`, &r.Email, &r.LastName, &r.FirstName).Scan(&r.ID) if err != nil { return errors.Wrap(err, "failed to insert user_account") } return nil } // GetUserAccountByPk select the UserAccount from the database. func GetUserAccountByPk(db Queryer, pk0 int64) (*UserAccount, error) { var r UserAccount err := db.QueryRow( `SELECT id, email, last_name, first_name FROM user_account WHERE id = $1`, pk0).Scan(&r.ID, &r.Email, &r.LastName, &r.FirstName) if err != nil { return nil, errors.Wrap(err, "failed to select user_account") } return &r, nil }
4JNJMBSBQQSPBDI Ø YP Ø IUUQTHJUIVCDPNLORYP Ø 4VQQPSUJOH1PTUHSF42-.Z42-0SBDMF.442-4FSWFS 42-JUF Ø
EHXJTIFBWJMZJOTQJSFECZYP Ø TRMCPJMFS Ø IUUQTHJUIVCDPNWBUUMFTRMCPJMFS Ø 4VQQPSUJOH1PTUHSF42-.Z42-.442-4FSWFS Ø 3BJMTTUZMF EBUBCBTFSTU03.
'FBUVSF Ø EHXDBOQSPQFSMZEFUFDUDPNQPTJUFQSJNBSZLFZT BOEBVUP HFOFSBUJOHDPMVNOT Ø SFUVOJOHBVUPHFOFSBUFEAVVJEA
ACJHTFSJBMA FUD Ø EHXIBTDPOHVSBCMFUZQFNBQQJOHCFUXFFO1PTUSHF42-BOE (P Ø EHXQSPWJEFTDVTUPNUFNQMBUFGFBUVSF Ø EFWFMPQFSTDBOVTFUIFJSPXOUFNQMBUFGPSTUSVDU NFUIPE BOEGVODUJPO
/PU'FBUVSF Ø EHXEPFTOUDBSFBCPVUSFMBUJPOT Ø POMZTUSVDUXJUIA$SFBUFANFUIPE BOEGVODUJPOXIJDI TFMFDUTSPXCZ1,BSFHFOFSBUFE
Ø *UTUBZTCFJOHNJOJNBMUBCMFSPXEBUBHBUFXBZ Ø EHXPOMZTVQQPSUT1PTUHSF42- Ø XFBSFDVSSFOUMZOPUVTJOHPUIFS3%#.4PUIFSUIBO 1PTUHSF42-
XIZ
"CJUPGIJTUPSZ Ø 8FSTUTUBSUFECVJMEJOHUIFQSPEVDUXJUIIBOEDSBGUFESBX42- Ø CBDLJO (PCBTFE DPEFSTU03.MJCSBSJFTBSFCJUTIBLZ Ø SFFDUJPOTFWFSZXIFSF
HFOFSBUFE42-OPUBMXBZFDJFOU Ø TJODF*DBNFGSPN%KBOHP03. 42-"MDIFNZXPSME *LOPX 03.JTHSFBUJONBOZXBZT Ø CVU*UIPVHIUNBZCFDPEFSTU03.JTOPUGPS(PBUUIBU NPNFOU Ø TUBSUFEXSJUJOHSBX42-GPSPVSQSPEVDU Ø NPRBEB BOE*GFMUQSFUUZDPOEFOUXSJUJOHDPNQMFY42- Ø IPXFWFS JUXBTFYUSFNFMZSFQFUJUJWF CPSJOH BOEFSSPSQSPOFUP DSFBUFTJNQMF42- Ø QSPCMFNXBTOPUDPNQMFY42- CVUSBUIFSTJNQMF BOETNBMM42- XJUIMPUTPGDPMVNOT Ø BUUIFTBNFUJNF XFBQQSFDJBUFEIPX03.IBWFCFFOTBWJOHPVS UJNF
%FOFQSPCMFN Ø %FOFQSPCMFNXIJDIXFTIPVMETPMWF Ø NBOVBMMZXSJUJOHJOTFSUSPXTFMFDUCZQL42-BSFFWJM Ø DPMT BSHT BOEQMBDFIPMEFSTIBWFUPCFFYBDUMZJOPSEFS
Ø UIFNPTUGSFRVFOUQBUUFSO JOPVSQSPEVDU JODMVEJOH UFTUEBUBQSFQBSBUJPO Ø TJODFPVSQSPEVDUEPFTOUZFUSFBMMZIBWFBOBMZUJDTGFBUVSF XJUIDPNQMFYEBUBNBOJQVMBUJPO Ø %FOFQSPCMFNTXIJDIXFMFBWFVOTPMWFE Ø XSJUJOH42-XJUINVMUJQMFKPJOT DBTFFYQSFTTJPO BOEDPNQMFY QSFEJDBUFT Ø PGBMM42-JOPVSQSPEVDU Ø UIJTJTXIFSFSBX42-SPDLT Ø EZOBNJD42-DPOTUSVDUJPOEFQFOEJOHPOVTFSJOQVU Ø NBZCFXFTIPVMEVTFRVFSZCVJMEFS CVUOPUZFUJNQMFNFOUFE XIJDINFBOTOPUUIBUOFDFTTBSZBUUIFNPNFOU
IPX
IPX Ø IUUQTHJUIVCDPNBDIJLVEHX Ø 6TFGVMJGZPVVTFXJUIHPHFOFSBUFDPNNBOE
%FNP
2"
2" 8FBSFIJSJOH