Rich Hickey: Deconstructing the Database

  Рет қаралды 100,994

InfoQ

InfoQ

Күн бұрын

Пікірлер: 33
@benhill70
@benhill70 12 жыл бұрын
Rich's talks are always great. I would love to hear him debate someone knowledgeable with an opposing view.
@softwareminimalist
@softwareminimalist 4 жыл бұрын
There is nobody with an opposing view, because his view is the correct solution and everyone thinking about it and using it for a while knows it :)
@ultimateichigo
@ultimateichigo 6 жыл бұрын
I listened to this entire talk replacing the notion of a database with Web API. It still makes sense!
@YuriyBrazhnyk
@YuriyBrazhnyk 5 жыл бұрын
Yeah, that is why there is PouchDB and such. Master-master replication to clients... wooohooo
@acobster
@acobster 3 жыл бұрын
​@@YuriyBrazhnyk PouchDB is great but I don't think it has the same notion of time.
@robwillful
@robwillful 12 жыл бұрын
What about the throughput cost? Aren't you pushing out and pushing back up the entire weight of the db when the live index is sent out or the storage is pulled when its needed for a query?
@regedit33
@regedit33 8 жыл бұрын
Does anyone know an libre/open source DBMS implementing this architecture?
3 жыл бұрын
There is CRUX DB with a similar architecture (and even based on Clojure too)
@acobster
@acobster 3 жыл бұрын
Late to the party, but check out Datahike!
@tux1968
@tux1968 12 жыл бұрын
this talk is new enough to be encoded in WebM and viewable without Flash. Does it have ad's or something that prohibits youtube from making it available this way?
@vicsteiner
@vicsteiner Жыл бұрын
The perceivers would be doing queries in which language? And where is the semantics, or how perceivers would now the meaning of the data without having a clear data model. Because besides the worry with time which I completely agree there is no data model as such been proposed and an architecture and computational processes in a physical system without a formal system backing it.
@tux1968
@tux1968 12 жыл бұрын
Hey apeiro, Had three other people try and they had same problem as me. It may be that you have h.264 support in your browser, whereas I only have WebM. In fact some videos that used to work for me have stopped, yet other continue to work. Maybe this is just a temporary problem going on behind the scenes.
@Milhouse77BS
@Milhouse77BS 12 жыл бұрын
Another great talk!
@SebInsua
@SebInsua 12 жыл бұрын
I panicked at 0:21:37 because of the dirt marks on the screen. !!!!
@jjames1977
@jjames1977 11 жыл бұрын
I was thinking it would be useful to be able to map a file into memory, and construct a value by appending records to the file. Because there is an impedance mismatch for functional code, when it takes time to read and write values to a file. It would be useful to manipulate a value directly in the file.
@softwareminimalist
@softwareminimalist 4 жыл бұрын
Ask the designers of storage solutions to provide drivers working through transactions with persistent data on the system level, and you will get that :) But thats another layer.
@CliffordHeath
@CliffordHeath 11 жыл бұрын
Wonderful stuff. It worries me however that you can't, in general, get serialisable isolation level with this approach. If you added that, you'd lose the ability to read-cache to the same extent, because you need read-locks that apply to every transaction that wishes to add any novelty. But it worries me even more that Rich doesn't mention this problem.
@OlegKiorsak
@OlegKiorsak 11 жыл бұрын
/bookmarking this to watch some day
@sergeysmyshlyaev9716
@sergeysmyshlyaev9716 11 жыл бұрын
As far as I understand, Datomic has serializable isolation level. Moreover, it is not just serializable, it is actually serialized, because all transactions are processed sequentially by one thread of control in transactor.
@CliffordHeath
@CliffordHeath 11 жыл бұрын
Sergey Smyshlyaev I haven't dug deep into Datomic, but I don't think it can prevent phantom reads, since it lacks the kind of locks that would make that possible. Serialising the individual updates that make up compound transactions does not serialise the transactions; phantoms can still occur. Most applications are fine with repeatable reads anyhow, and most DBMS default to that b/c serialisable is too costly. But maybe I've missed something...
@michaelgaare2121
@michaelgaare2121 10 жыл бұрын
Clifford Heath Datomic reads are consistent, in that when you do a read you must explicitly select the point in time that you want your read to happen. At any time, you can query against any time-version of the database. A database "value" - that is, the database at a specific point in time that you are reading against - is always as of a specific transaction, and never has any data from the "middle" of a transaction. About read caching: You're thinking about "updates" in terms of "this thing has changed and the way it used to be is gone" which is not a good fit for change in Datomic. What would be more accurate, is that when do a read at some point after point T, you see "this thing has this value as of T", and if there's some changes a T2, a read after that point can see "this thing has this value of as of T, it no longer has this value as of T2, it has a this other value as of T2". So for the purpose of caching, you never have to invalidate "this thing has this value as of T" because it always remains true.
@CliffordHeath
@CliffordHeath 10 жыл бұрын
Michael Gaare No Michael, I did not misunderstand updates. The simple fact is that with Datomic, if I want to look at the database value and then decide how to make changes, I cannot prevent another application supervening and inserting data that would have changed my decision. That means I cannot serialise transactions.
@apeiro8
@apeiro8 12 жыл бұрын
I believe it is viewable without flash (I'm viewing it w/o flash right now). Do you have HTML5-mode enabled?
@AngusMcIntyre
@AngusMcIntyre 12 жыл бұрын
.Net's LINQ goes a long way to injecting high-order querying into OO languages. It's nice but the mechanics are very complex.
@YoLninYo
@YoLninYo 11 жыл бұрын
ZODB for the win!
@vicsteiner
@vicsteiner Жыл бұрын
The idea of facts that might be true or have been true just sounds like a logical predicate that has a time stamp as one of its variables. It does not change in anything the logic of the relational data model (at least as a theory). The definition of information model to me is a bit floppy. I nice reference here would be the data based definition of information as semantic content by Floriano Floridi. Data is the lack of difference in the perceivable/perceived world. So, if you think as time as unidirectional space you can think as temporal changes as data as much as data of differences not changing over the temporal dimension.
@pohjoisenvanhus
@pohjoisenvanhus 4 жыл бұрын
Criticism first. It seems that a bunch of magic is still assumed in terms of storage CAP which just pushes the magic further down but doesn't eliminate it. Which makes me feel skeptical about the rest as if this is being shrugged off then how can I trust there wasn't some other blindspots? Database as a value? Yes, SQL tables are relational variables storing relations which are sets of tuples of the same type. I've been building temporal databases myself on top of SQL and it's not that pretty due to the extra work involved because the tools required aren't really always there. Also there's the whole SQL vs relational tension because like for example Chris Date says they aren't the same and that is pretty obvious when one looks at how SQL for performance reasons deviates from relational theory. According to Brian Beckman there's two traditions in programming languages of which one focuses on performance and thus starts from the raw hardware and adds abstraction to the point it feels like it can while the other one starts from math and reduces abstraction. The first is represented by FORTRAN, C and others while the other by LISP, Prolog, relational, etc. I'm not sure which one SQL is here. Perhaps the latter but the way SQL works compared to purely relational is very much tied to the hardware and efficiency aspect as Rich is pointing out. But the same ideas have been floating around elsewhere too like Rich says. Append only "databases" that are like logs which is very much what this sounds like. This one seems slightly superior though due to the audit capabilities baked directly into the model. I like the idea of reifying transactions to make the changes traceable. Good talk but like others have said there wasn't that much consideration of any alternate points of view.
@rostislavsvoboda7013
@rostislavsvoboda7013 12 жыл бұрын
Stuff like this works only if no time dilation occurs which might be OK for you if you don't want to leave this miserable locality called Earth :)
@UnicornLaunching
@UnicornLaunching 6 жыл бұрын
58:50 Aristotelian Form | Perceiver 1:01:30 :O :O :O 1:03:44 LMAO
@DanBaughman
@DanBaughman 12 жыл бұрын
dude the first ten minutes of this video talks about application data caching and the other side comlpaining about ui programmers
@dlekic
@dlekic 12 жыл бұрын
Database system as desribed by Rich is going to be 10x slower than traditional RDBMS... And probably take 10x more space on the disk as well.
The Value of Values with Rich Hickey
31:44
InfoQ
Рет қаралды 135 М.
"Simple Made Easy" - Rich Hickey (2011)
1:01:39
Strange Loop Conference
Рет қаралды 108 М.
VIP ACCESS
00:47
Natan por Aí
Рет қаралды 30 МЛН
Tuna 🍣 ​⁠@patrickzeinali ​⁠@ChefRush
00:48
albert_cancook
Рет қаралды 148 МЛН
"Turning the database inside out with Apache Samza" by Martin Kleppmann
47:43
Strange Loop Conference
Рет қаралды 190 М.
Mastering Chaos - A Netflix Guide to Microservices
53:14
InfoQ
Рет қаралды 2,3 МЛН
SQLite: How it works, by Richard Hipp
1:39:27
Prof. Dr. Jens Dittrich, Big Data Analytics
Рет қаралды 23 М.
Datomic with Rich Hickey
51:22
Java
Рет қаралды 19 М.
#01 - Relational Model & Algebra (CMU Intro to Database Systems)
1:23:38
CMU Database Group
Рет қаралды 28 М.
Database as a Value • Rich Hickey • GOTO 2012
56:23
GOTO Conferences
Рет қаралды 15 М.
Solving Problems the Clojure Way - Rafal Dittwald
1:02:26
Clojure/north
Рет қаралды 76 М.
Design, Composition, and Performance - Rich Hickey
55:25
Zhang Jian
Рет қаралды 33 М.
Introduction to NoSQL • Martin Fowler • GOTO 2012
54:52
GOTO Conferences
Рет қаралды 994 М.
Rails Conf 2012 Keynote: Simplicity Matters by Rich Hickey
36:53
VIP ACCESS
00:47
Natan por Aí
Рет қаралды 30 МЛН